/*
Theme Name: Mediaweb
Theme URI: https://www.mediawebchile.com
Author: Mediaweb
Author URI: https://www.mediawebchile.com
Description: Tema independiente, minimalista y de alto rendimiento para Mediaweb, optimizado 100% para Elementor (contenedores Flexbox/Grid). Estetica "broadcast" dark-first basada en el Manual de Marca. Mobile-first y accesible.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mediaweb
Tags: elementor, flexbox, full-width-template, custom-logo, translation-ready
*/

/* ==========================================================================
   1. TOKENS DE DISENO (variables globales — mapeables a Elementor)
   ========================================================================== */
:root {
  /* --- Colores de marca (Manual) --- */
  --mw-green: #26D07C;          /* Pantone 7479 C — primario */
  --mw-gray:  #919D9D;          /* Pantone 443 C  — primario */
  --mw-dark:  #1D252D;          /* Pantone 433 C  — secundario (base broadcast) */
  /* PROHIBIDO: #FFB990 (Pantone 1555 C) — NO usar en ningun caso */

  /* --- Estados del verde --- */
  --mw-green-700: #1FA968;      /* hover */
  --mw-green-800: #178A54;      /* active */
  --mw-green-soft: rgba(38, 208, 124, .12);

  /* --- Escala neutra derivada del oscuro de marca --- */
  --mw-900: #141A1F;            /* fondo mas profundo */
  --mw-800: #1D252D;            /* fondo base (marca) */
  --mw-700: #222C35;            /* superficies elevadas / cards */
  --mw-600: #2C3741;            /* bordes fuertes / hover surface */
  --mw-500: #919D9D;            /* gris de marca — texto secundario */
  --mw-200: #C9D1D1;            /* texto tenue claro */
  --mw-100: #E9EDED;            /* texto */
  --mw-000: #FFFFFF;            /* titulos / blanco */

  /* --- Roles semanticos (dark-first) --- */
  --mw-bg:        var(--mw-800);
  --mw-bg-deep:   var(--mw-900);
  --mw-surface:   var(--mw-700);
  --mw-border:    rgba(145, 157, 157, .18);
  --mw-text:      var(--mw-100);
  --mw-text-muted:var(--mw-500);
  --mw-heading:   var(--mw-000);
  --mw-accent:    var(--mw-green);
  --mw-on-accent: var(--mw-800);   /* texto sobre verde (contraste AA) */

  /* --- Tipografia (stack de sistema — 0 KB) --- */
  --mw-font-base: "Helvetica Neue", Helvetica, Arial, "Liberation Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mw-font-head: var(--mw-font-base);

  /* Escala tipografica fluida (mobile-first, clamp) */
  --mw-fs-300: clamp(.8125rem, .78rem + .15vw, .875rem);
  --mw-fs-400: clamp(.9375rem, .9rem + .2vw, 1rem);
  --mw-fs-500: clamp(1.0625rem, 1rem + .35vw, 1.25rem);
  --mw-fs-600: clamp(1.25rem, 1.1rem + .6vw, 1.5rem);
  --mw-fs-700: clamp(1.5rem, 1.25rem + 1vw, 2rem);
  --mw-fs-800: clamp(1.875rem, 1.4rem + 1.9vw, 2.75rem);
  --mw-fs-900: clamp(2.25rem, 1.5rem + 3.2vw, 4rem);

  --mw-lh-tight: 1.1;
  --mw-lh-snug:  1.25;
  --mw-lh-normal:1.6;
  --mw-tracking-tight: -.02em;
  --mw-w-regular: 400;
  --mw-w-medium:  500;
  --mw-w-bold:    700;

  /* --- Espaciado (escala 4px) --- */
  --mw-space-1: .25rem;  --mw-space-2: .5rem;  --mw-space-3: .75rem;
  --mw-space-4: 1rem;    --mw-space-5: 1.5rem; --mw-space-6: 2rem;
  --mw-space-7: 3rem;    --mw-space-8: 4rem;   --mw-space-9: 6rem;  --mw-space-10: 8rem;

  /* --- Layout (alineado a Elementor) --- */
  --mw-container: 1140px;
  --mw-container-wide: 1400px;
  --mw-gutter: clamp(1rem, 3vw, 2rem);
  --mw-header-h: 72px;

  /* --- Radios, sombras, motion --- */
  --mw-radius-sm: 6px; --mw-radius: 12px; --mw-radius-lg: 20px; --mw-radius-pill: 999px;
  --mw-shadow: 0 10px 30px -12px rgba(0, 0, 0, .55);
  --mw-shadow-accent: 0 8px 24px -8px rgba(38, 208, 124, .45);
  --mw-ease: cubic-bezier(.2, .7, .2, 1);
  --mw-dur: .25s;
}

/* ==========================================================================
   2. RESET / BASE accesible (mobile-first)
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  font-family: var(--mw-font-base);
  font-size: var(--mw-fs-400);
  line-height: var(--mw-lh-normal);
  color: var(--mw-text);
  background-color: var(--mw-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--mw-font-head);
  color: var(--mw-heading);
  line-height: var(--mw-lh-tight);
  letter-spacing: var(--mw-tracking-tight);
  font-weight: var(--mw-w-bold);
}
h1 { font-size: var(--mw-fs-900); }
h2 { font-size: var(--mw-fs-800); }
h3 { font-size: var(--mw-fs-700); }
h4 { font-size: var(--mw-fs-600); }

p, ul, ol { margin-bottom: var(--mw-space-4); }

a { color: var(--mw-accent); text-decoration: none; transition: color var(--mw-dur) var(--mw-ease); }
a:hover { color: var(--mw-green-700); }

img, svg, video { max-width: 100%; height: auto; display: block; }

::selection { background: var(--mw-green); color: var(--mw-on-accent); }

/* Foco visible accesible */
:focus-visible {
  outline: 3px solid var(--mw-green);
  outline-offset: 2px;
  border-radius: 2px;
}

/* Utilidad de solo-lectores y skip-link */
.screen-reader-text {
  position: absolute !important;
  width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.mw-skip-link {
  position: absolute; left: var(--mw-space-3); top: -100px; z-index: 9999;
  background: var(--mw-green); color: var(--mw-on-accent);
  padding: var(--mw-space-3) var(--mw-space-4); border-radius: var(--mw-radius-sm);
  font-weight: var(--mw-w-bold);
}
.mw-skip-link:focus { top: var(--mw-space-3); color: var(--mw-on-accent); }

/* ==========================================================================
   3. LAYOUT helpers
   ========================================================================== */
.mw-container {
  width: 100%;
  max-width: var(--mw-container);
  margin-inline: auto;
  padding-inline: var(--mw-gutter);
}
.mw-site-main { min-height: 50vh; }
.mw-content { padding-block: var(--mw-space-8); }

/* Boton de marca reutilizable (para la cabecera de respaldo) */
.mw-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--mw-space-2);
  padding: var(--mw-space-3) var(--mw-space-5); white-space: nowrap;
  background: var(--mw-green); color: var(--mw-on-accent);
  font-weight: var(--mw-w-bold); border-radius: var(--mw-radius-pill);
  border: 0; cursor: pointer;
  transition: transform var(--mw-dur) var(--mw-ease), background var(--mw-dur) var(--mw-ease), box-shadow var(--mw-dur) var(--mw-ease);
}
.mw-btn:hover { background: var(--mw-green-700); color: var(--mw-on-accent); transform: translateY(-2px); box-shadow: var(--mw-shadow-accent); }
.mw-btn:active { transform: translateY(0); }
.mw-btn--sm { padding: .55rem 1.1rem; font-size: var(--mw-fs-300); letter-spacing: .01em; }

/* ===== Boton "Area de clientes" (CTA destacado) ===== */
.mw-cta {
  position: relative; overflow: hidden;
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .4rem .4rem .4rem 1.1rem;
  background: linear-gradient(135deg, var(--mw-green) 0%, var(--mw-green-700) 100%);
  color: var(--mw-on-accent); font-weight: var(--mw-w-bold); letter-spacing: .005em; line-height: 1;
  border: 0; border-radius: var(--mw-radius-pill); white-space: nowrap; cursor: pointer;
  box-shadow: 0 6px 18px -8px rgba(38, 208, 124, .55);
  transition: transform var(--mw-dur) var(--mw-ease), box-shadow var(--mw-dur) var(--mw-ease);
}
.mw-cta:hover { color: var(--mw-on-accent); transform: translateY(-2px); box-shadow: 0 12px 26px -8px rgba(38, 208, 124, .7); }
.mw-cta:active { transform: translateY(0); }
.mw-cta__ic { display: inline-flex; }
.mw-cta__ic svg { width: 18px; height: 18px; }
.mw-cta__label { line-height: 1; }
.mw-cta__arrow {
  display: inline-flex; align-items: center; justify-content: center; flex: none;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--mw-on-accent); color: var(--mw-green);
  transition: transform var(--mw-dur) var(--mw-ease);
}
.mw-cta__arrow svg { width: 13px; height: 13px; }
.mw-cta:hover .mw-cta__arrow { transform: translateX(3px); }
/* Brillo que recorre el boton al pasar el cursor */
.mw-cta::before {
  content: ""; position: absolute; top: 0; left: -60%; width: 45%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255, 255, 255, .35), transparent);
  transform: skewX(-18deg); pointer-events: none;
  transition: left .55s var(--mw-ease);
}
.mw-cta:hover::before { left: 130%; }

/* ==========================================================================
   4. CABECERA de respaldo (se reemplaza con Elementor Pro Theme Builder)
   ========================================================================== */
.mw-site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--mw-bg); /* solido en movil (sin backdrop-filter para no atrapar el drawer fixed) */
  border-bottom: 1px solid transparent;
  transition: background var(--mw-dur) var(--mw-ease), border-color var(--mw-dur) var(--mw-ease), box-shadow var(--mw-dur) var(--mw-ease);
}
/* El logo y las acciones (incl. la X) por encima del drawer movil */
.mw-site-branding, .mw-site-actions { position: relative; z-index: 95; }
/* Hairline verde de marca (recurso grafico "broadcast" del Manual) */
.mw-site-header::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 3px;
  background: linear-gradient(90deg, var(--mw-green), var(--mw-green-700));
}
.mw-site-header.is-scrolled {
  background: rgba(20, 26, 31, .92);
  border-bottom-color: var(--mw-border);
  box-shadow: 0 8px 30px -16px rgba(0, 0, 0, .7);
}
.mw-site-header__inner {
  display: flex; align-items: center; gap: var(--mw-space-4);
  max-width: var(--mw-container-wide);
  min-height: var(--mw-header-h);
  transition: min-height var(--mw-dur) var(--mw-ease);
}
.mw-site-header.is-scrolled .mw-site-header__inner { min-height: 60px; }
/* Mobile: logo a la izquierda; las acciones quedan a la derecha (nav es dropdown absoluto) */
.mw-site-branding { display: flex; align-items: center; margin-right: auto; }
.mw-logo { display: inline-flex; align-items: center; }
.mw-site-branding .custom-logo,
.mw-logo-img {
  max-height: 48px; width: auto; height: auto; display: block;
  transition: max-height var(--mw-dur) var(--mw-ease);
}
.mw-site-header.is-scrolled .custom-logo,
.mw-site-header.is-scrolled .mw-logo-img { max-height: 38px; }

.mw-logo-text {
  display: inline-flex; align-items: center; gap: var(--mw-space-2);
  color: var(--mw-heading); font-weight: var(--mw-w-bold);
  font-size: var(--mw-fs-600); letter-spacing: var(--mw-tracking-tight);
}
.mw-logo-text::before {
  content: ""; width: 14px; height: 14px; border-radius: 3px;
  background: var(--mw-green); box-shadow: 0 0 0 4px var(--mw-green-soft);
}

/* Acciones de la barra (CTA + toggle movil) */
.mw-site-actions { display: flex; align-items: center; gap: var(--mw-space-3); }
.mw-header-cta { display: none; font-size: var(--mw-fs-300); }
@media (min-width: 480px) { .mw-header-cta { display: inline-flex; } }

/* Menu */
.mw-menu,
.mw-menu .sub-menu { list-style: none; margin: 0; padding: 0; }
.mw-menu { display: flex; flex-direction: column; gap: var(--mw-space-2); }
.mw-menu li { position: relative; }
.mw-menu a {
  color: var(--mw-text); font-weight: var(--mw-w-medium);
  padding: var(--mw-space-2) 0; display: flex; align-items: center; gap: var(--mw-space-2);
}
.mw-menu a:hover, .mw-menu .current-menu-item > a { color: var(--mw-green); }

/* Indicador de submenu */
.mw-menu .menu-item-has-children > a::after {
  content: ""; width: 7px; height: 7px; flex: none;
  border-right: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(45deg); margin-top: -3px; opacity: .7;
  transition: transform var(--mw-dur) var(--mw-ease);
}

/* Submenu (mobile-first: lista anidada e indentada, sin vinetas) */
.mw-menu .sub-menu { padding-left: var(--mw-space-4); }
.mw-menu .sub-menu a { color: var(--mw-text-muted); }
.mw-menu .sub-menu a:hover { color: var(--mw-green); }

/* Boton de submenu (inyectado por JS; visible solo en movil) */
.mw-submenu-toggle {
  display: none; position: absolute; top: 0; right: 0; width: 52px; height: 46px;
  align-items: center; justify-content: center; background: transparent; border: 0;
  color: var(--mw-text); cursor: pointer;
}
.mw-submenu-toggle::before {
  content: ""; width: 9px; height: 9px; margin-top: -3px;
  border-right: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(45deg); transition: transform var(--mw-dur) var(--mw-ease);
}
.menu-item-has-children.is-open > .mw-submenu-toggle { color: var(--mw-green); }
.menu-item-has-children.is-open > .mw-submenu-toggle::before { transform: rotate(225deg); }

/* ===== Drawer movil: experiencia mejorada (<=1024px) ===== */
@media (max-width: 1024px) {
  /* Items grandes, con divisores y buen target de toque */
  .mw-menu { gap: 0; }
  .mw-menu > li { border-bottom: 1px solid var(--mw-border); }
  .mw-menu > li > a { padding: var(--mw-space-4) 0; font-size: var(--mw-fs-500); font-weight: var(--mw-w-medium); }
  .mw-menu .current-menu-item > a,
  .mw-menu .current-menu-ancestor > a { color: var(--mw-green); }

  /* Fila: enlace + boton de submenu en una linea; el submenu salta abajo */
  .mw-menu .menu-item-has-children { display: flex; flex-wrap: wrap; align-items: center; }
  .mw-menu .menu-item-has-children > a { flex: 1; }
  .mw-menu .menu-item-has-children > .sub-menu { flex-basis: 100%; }

  /* Submenu indentado con acento verde */
  .mw-menu .sub-menu { padding-left: var(--mw-space-4); margin-left: var(--mw-space-1); border-left: 2px solid var(--mw-border); }
  .mw-menu .sub-menu a { padding: var(--mw-space-3) 0; font-size: var(--mw-fs-400); }
  .mw-menu .sub-menu li:not(:last-child) { border-bottom: 1px solid rgba(145, 157, 157, .08); }

  /* Acordeon: submenus cerrados por defecto (con JS) */
  .mw-primary-nav.has-js .sub-menu {
    overflow: hidden; max-height: 0;
    transition: max-height var(--mw-dur) var(--mw-ease);
  }
  .mw-primary-nav.has-js .menu-item-has-children.is-open > .sub-menu { max-height: 1400px; }
  .mw-primary-nav.has-js .menu-item-has-children > .mw-submenu-toggle { display: inline-flex; }
  .mw-primary-nav.has-js .menu-item-has-children > a::after { display: none; }
  .mw-submenu-toggle { position: static; width: 48px; height: 48px; flex: none; }

  /* Entrada escalonada de los items al abrir */
  .mw-primary-nav.is-open .mw-menu > li { animation: mw-nav-item .32s var(--mw-ease) backwards; }
  .mw-primary-nav.is-open .mw-menu > li:nth-child(1) { animation-delay: .03s; }
  .mw-primary-nav.is-open .mw-menu > li:nth-child(2) { animation-delay: .06s; }
  .mw-primary-nav.is-open .mw-menu > li:nth-child(3) { animation-delay: .09s; }
  .mw-primary-nav.is-open .mw-menu > li:nth-child(4) { animation-delay: .12s; }
  .mw-primary-nav.is-open .mw-menu > li:nth-child(5) { animation-delay: .15s; }
  .mw-primary-nav.is-open .mw-menu > li:nth-child(6) { animation-delay: .18s; }
  .mw-primary-nav.is-open .mw-menu > li:nth-child(7) { animation-delay: .21s; }
  .mw-primary-nav.is-open .mw-nav-foot { animation: mw-nav-item .32s var(--mw-ease) .24s backwards; }
}
@keyframes mw-nav-item { from { opacity: 0; transform: translateX(-10px); } to { opacity: 1; transform: none; } }

/* Pie del drawer movil: CTA + contacto rapido */
.mw-nav-foot { margin-top: auto; padding-top: var(--mw-space-6); }
.mw-nav-cta { width: 100%; justify-content: center; padding: .55rem .55rem .55rem 1.25rem; font-size: var(--mw-fs-500); }
.mw-nav-contact { display: flex; gap: var(--mw-space-3); margin-top: var(--mw-space-3); }
.mw-nav-contact a {
  flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: var(--mw-space-2);
  padding: var(--mw-space-3); border: 1px solid var(--mw-border); border-radius: var(--mw-radius);
  color: var(--mw-text); font-weight: var(--mw-w-medium); font-size: var(--mw-fs-300);
  transition: border-color var(--mw-dur) var(--mw-ease), color var(--mw-dur) var(--mw-ease);
}
.mw-nav-contact a:hover { border-color: var(--mw-green); color: var(--mw-green); }
.mw-nav-contact svg { width: 18px; height: 18px; }
@media (min-width: 1025px) { .mw-nav-foot { display: none; } }

/* Toggle movil */
.mw-nav-toggle {
  display: inline-flex; flex-direction: column; justify-content: center; gap: 5px;
  width: 44px; height: 44px; padding: 10px; background: transparent;
  border: 1px solid var(--mw-border); border-radius: var(--mw-radius-sm); cursor: pointer;
}
.mw-nav-toggle__bar, .mw-nav-toggle__bar::before, .mw-nav-toggle__bar::after {
  content: ""; display: block; height: 2px; width: 100%;
  background: var(--mw-heading); transition: transform var(--mw-dur) var(--mw-ease), opacity var(--mw-dur);
}
.mw-nav-toggle__bar { position: relative; }
.mw-nav-toggle__bar::before { position: absolute; top: -7px; }
.mw-nav-toggle__bar::after  { position: absolute; top: 7px; }
.mw-nav-toggle[aria-expanded="true"] .mw-nav-toggle__bar { background: transparent; }
.mw-nav-toggle[aria-expanded="true"] .mw-nav-toggle__bar::before { top: 0; transform: rotate(45deg); }
.mw-nav-toggle[aria-expanded="true"] .mw-nav-toggle__bar::after  { top: 0; transform: rotate(-45deg); }

/* Nav movil: drawer a pantalla completa (mobile-first) */
.mw-primary-nav {
  position: fixed; inset: 0; z-index: 90;
  display: flex; flex-direction: column;
  background: var(--mw-bg-deep);
  padding: calc(var(--mw-header-h) + var(--mw-space-4)) var(--mw-gutter) calc(var(--mw-space-6) + env(safe-area-inset-bottom, 0px));
  overflow-y: auto; -webkit-overflow-scrolling: touch; overscroll-behavior: contain;
  opacity: 0; visibility: hidden; transform: translateY(-6px);
  transition: opacity var(--mw-dur) var(--mw-ease), transform var(--mw-dur) var(--mw-ease), visibility var(--mw-dur);
}
.mw-primary-nav.is-open { opacity: 1; visibility: visible; transform: none; }
body.mw-nav-open { overflow: hidden; }

/* ==========================================================================
   5. PIE de respaldo
   ========================================================================== */
.mw-site-footer {
  position: relative; background: var(--mw-bg-deep); border-top: 1px solid var(--mw-border);
  padding-block: var(--mw-space-8) var(--mw-space-5); margin-top: var(--mw-space-9);
  color: var(--mw-text-muted);
}
.mw-site-footer::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 3px;
  background: linear-gradient(90deg, var(--mw-green), var(--mw-green-700));
}

.mw-footer-grid { display: grid; grid-template-columns: 1fr; gap: var(--mw-space-7); }

.mw-footer-title {
  font-size: var(--mw-fs-500); color: var(--mw-heading);
  margin-bottom: var(--mw-space-4); padding-bottom: var(--mw-space-2); position: relative;
}
.mw-footer-title::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 32px; height: 2px;
  background: var(--mw-green); border-radius: 2px;
}

/* Marca */
.mw-footer-logo { display: inline-block; }
.mw-footer-logo img { max-height: 46px; width: auto; }
.mw-footer-slogan { color: var(--mw-green); font-weight: var(--mw-w-medium); margin: var(--mw-space-3) 0 var(--mw-space-2); }
.mw-footer-about { font-size: var(--mw-fs-300); max-width: 38ch; }

/* Redes */
.mw-social { list-style: none; display: flex; flex-wrap: wrap; gap: var(--mw-space-2); padding: 0; margin: var(--mw-space-4) 0 0; }
.mw-social__link {
  display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px;
  border-radius: var(--mw-radius-pill); background: var(--mw-surface); color: var(--mw-text);
  border: 1px solid var(--mw-border);
  transition: background var(--mw-dur) var(--mw-ease), color var(--mw-dur) var(--mw-ease),
              transform var(--mw-dur) var(--mw-ease), border-color var(--mw-dur) var(--mw-ease);
}
.mw-social__link:hover { background: var(--mw-green); color: var(--mw-on-accent); border-color: var(--mw-green); transform: translateY(-2px); }

/* Botones de utilidad (Estado de red / Blacklist) */
.mw-footer-tools { display: flex; flex-wrap: wrap; gap: var(--mw-space-2); margin-top: var(--mw-space-4); }
.mw-btn-ghost {
  display: inline-flex; align-items: center; gap: var(--mw-space-2);
  padding: .5rem 1rem; border-radius: var(--mw-radius-pill);
  background: transparent; border: 1px solid var(--mw-border); color: var(--mw-text);
  font-size: var(--mw-fs-300); font-weight: var(--mw-w-medium);
  transition: border-color var(--mw-dur) var(--mw-ease), color var(--mw-dur) var(--mw-ease), background var(--mw-dur) var(--mw-ease);
}
.mw-btn-ghost:hover { border-color: var(--mw-green); color: var(--mw-green); background: var(--mw-green-soft); }
.mw-status-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--mw-green);
  box-shadow: 0 0 0 0 rgba(38, 208, 124, .6); animation: mw-pulse 2s infinite;
}
@keyframes mw-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(38, 208, 124, .5); }
  70%  { box-shadow: 0 0 0 7px rgba(38, 208, 124, 0); }
  100% { box-shadow: 0 0 0 0 rgba(38, 208, 124, 0); }
}

/* Geolocalizacion del visitante (shortcode [mi_ubicacion]) */
.mw-footer-geo { margin-top: var(--mw-space-4); font-size: var(--mw-fs-300); color: var(--mw-text-muted); }
.mw-footer-geo a { color: var(--mw-green); }

/* Noticias */
.mw-news-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--mw-space-4); }
.mw-news-item__link { display: block; color: var(--mw-text); font-weight: var(--mw-w-medium); line-height: var(--mw-lh-snug); }
.mw-news-item__link:hover { color: var(--mw-green); }
.mw-news-item__date { display: block; font-size: var(--mw-fs-300); color: var(--mw-text-muted); margin-top: 2px; }
.mw-footer-more { display: inline-block; margin-top: var(--mw-space-5); color: var(--mw-green); font-weight: var(--mw-w-bold); font-size: var(--mw-fs-300); }
.mw-footer-more:hover { color: var(--mw-green-700); }

/* Enlaces */
.mw-footer-menu { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--mw-space-3); }
.mw-footer-menu a { color: var(--mw-text-muted); }
.mw-footer-menu a:hover { color: var(--mw-green); }

/* Contacto */
.mw-contact-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--mw-space-3); }
.mw-contact-list li { display: flex; align-items: center; gap: var(--mw-space-2); flex-wrap: wrap; }
.mw-contact-flag { font-size: 1.15em; }
.mw-contact-place { color: var(--mw-text-muted); min-width: 52px; font-size: var(--mw-fs-300); }
.mw-contact-list a { color: var(--mw-text); font-weight: var(--mw-w-medium); }
.mw-contact-list a:hover { color: var(--mw-green); }

/* Partners / sellos */
.mw-footer-partners {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--mw-space-7);
  padding-block: var(--mw-space-6); margin-top: var(--mw-space-7); border-top: 1px solid var(--mw-border);
}
.mw-partner img { max-height: 46px; width: auto; opacity: .82; transition: opacity var(--mw-dur) var(--mw-ease), transform var(--mw-dur) var(--mw-ease); }
.mw-partner:hover img { opacity: 1; transform: translateY(-2px); }

/* Barra inferior */
.mw-footer-bottom { text-align: center; padding-top: var(--mw-space-5); border-top: 1px solid var(--mw-border); }
.mw-copyright { color: var(--mw-text-muted); font-size: var(--mw-fs-300); margin: 0; }
.mw-copyright a { color: var(--mw-text-muted); }
.mw-copyright a:hover { color: var(--mw-green); }

/* ==========================================================================
   6. RESPONSIVE (Tablet >=768, Desktop >=1025)
   ========================================================================== */
@media (min-width: 600px) {
  .mw-footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1025px) {
  .mw-footer-grid { grid-template-columns: 1.5fr 1.2fr 1fr 1fr; gap: var(--mw-space-8); }
}

@media (min-width: 1025px) {
  .mw-nav-toggle { display: none; }
  .mw-header-cta { font-size: var(--mw-fs-400); padding-left: var(--mw-space-5); }

  /* Blur translucido solo en escritorio (en movil rompe el drawer fixed) */
  .mw-site-header {
    background: rgba(20, 26, 31, .72);
    backdrop-filter: saturate(160%) blur(14px);
    -webkit-backdrop-filter: saturate(160%) blur(14px);
  }

  /* Header en una fila: logo izq, nav centrado, CTA der */
  .mw-site-branding { margin-right: 0; }
  .mw-primary-nav {
    position: static; flex: 1; background: transparent; border: 0; padding: 0;
    max-height: none; overflow: visible; opacity: 1; visibility: visible; transform: none;
  }
  .mw-menu { flex-direction: row; align-items: center; justify-content: center; gap: clamp(1rem, 1.6vw, 1.75rem); flex-wrap: wrap; }

  /* Enlaces de primer nivel con subrayado animado (micro-interaccion) */
  .mw-menu > li > a { position: relative; padding: var(--mw-space-2) 0; white-space: nowrap; }
  .mw-menu > li > a::before {
    content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px;
    background: var(--mw-green); border-radius: 2px;
    transform: scaleX(0); transform-origin: left center; opacity: 0;
    transition: transform var(--mw-dur) var(--mw-ease), opacity var(--mw-dur) var(--mw-ease);
  }
  .mw-menu > li:hover > a::before,
  .mw-menu > li:focus-within > a::before,
  .mw-menu > li.current-menu-item > a::before,
  .mw-menu > li.current-menu-ancestor > a::before { transform: scaleX(1); opacity: 1; }

  /* Submenu como dropdown flotante */
  .mw-menu .sub-menu {
    position: absolute; top: calc(100% + 10px); left: 0; min-width: 280px; padding: var(--mw-space-2);
    background: var(--mw-bg-deep); border: 1px solid var(--mw-border); border-top: 2px solid var(--mw-green);
    border-radius: var(--mw-radius); box-shadow: var(--mw-shadow); z-index: 50;
    display: flex; flex-direction: column; gap: 2px;
    opacity: 0; visibility: hidden; transform: translateY(8px) scale(.98); transform-origin: top left;
    transition: opacity var(--mw-dur) var(--mw-ease), transform var(--mw-dur) var(--mw-ease), visibility var(--mw-dur);
  }
  /* Puente invisible para que el hover no se pierda al bajar al dropdown */
  .mw-menu .menu-item-has-children::after {
    content: ""; position: absolute; top: 100%; left: 0; width: 100%; height: 12px;
  }
  .mw-menu li:hover > .sub-menu,
  .mw-menu li:focus-within > .sub-menu {
    opacity: 1; visibility: visible; transform: translateY(0) scale(1);
  }
  .mw-menu .menu-item-has-children:hover > a::after,
  .mw-menu .menu-item-has-children:focus-within > a::after { transform: rotate(225deg); }
  .mw-menu .sub-menu a {
    white-space: nowrap; padding: var(--mw-space-2) var(--mw-space-3);
    border-radius: var(--mw-radius-sm);
  }
  .mw-menu .sub-menu a:hover { background: var(--mw-green-soft); color: var(--mw-green); }

  /* Submenus de 3er nivel se despliegan al lado */
  .mw-menu .sub-menu .sub-menu { top: 0; left: 100%; }
}

/* ==========================================================================
   7. NOTICIAS / BLOG (diseno basado en colores corporativos)
   ========================================================================== */
/* Cabecera de archivo / listado */
.mw-archive__header { text-align: center; margin-bottom: var(--mw-space-7); }
.mw-archive__title { font-size: var(--mw-fs-800); }
.mw-archive__title span { color: var(--mw-green); }
.mw-archive__title::after {
  content: ""; display: block; width: 64px; height: 3px; border-radius: 2px;
  background: var(--mw-green); margin: var(--mw-space-3) auto 0;
}
.mw-archive__desc { color: var(--mw-text-muted); margin-top: var(--mw-space-3); max-width: 60ch; margin-inline: auto; }
.mw-no-results { text-align: center; color: var(--mw-text-muted); padding-block: var(--mw-space-7); }

/* Grilla de tarjetas */
.mw-grid { display: grid; grid-template-columns: 1fr; gap: var(--mw-space-6); }

.mw-card {
  display: flex; flex-direction: column; overflow: hidden;
  background: var(--mw-surface); border: 1px solid var(--mw-border); border-radius: var(--mw-radius-lg);
  transition: transform var(--mw-dur) var(--mw-ease), border-color var(--mw-dur) var(--mw-ease), box-shadow var(--mw-dur) var(--mw-ease);
}
.mw-card:hover { transform: translateY(-4px); border-color: rgba(38, 208, 124, .4); box-shadow: var(--mw-shadow); }
.mw-card__media { display: block; aspect-ratio: 16 / 9; overflow: hidden; background: var(--mw-700); }
.mw-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--mw-ease); }
.mw-card:hover .mw-card__media img { transform: scale(1.05); }
.mw-card__placeholder { display: block; width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--mw-700), var(--mw-800)); position: relative; }
.mw-card__placeholder::after { content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 30%, var(--mw-green-soft), transparent 60%); }
.mw-card__body { display: flex; flex-direction: column; gap: var(--mw-space-3); padding: var(--mw-space-5); flex: 1; }
.mw-card__cat a, .mw-post__cat a {
  display: inline-block; font-size: var(--mw-fs-300); font-weight: var(--mw-w-bold);
  text-transform: uppercase; letter-spacing: .04em; color: var(--mw-green);
}
.mw-card__title { font-size: var(--mw-fs-600); line-height: var(--mw-lh-snug); }
.mw-card__title a { color: var(--mw-heading); }
.mw-card__title a:hover { color: var(--mw-green); }
.mw-card__excerpt { color: var(--mw-text-muted); font-size: var(--mw-fs-300); margin: 0; }
.mw-card__meta { margin-top: auto; color: var(--mw-text-muted); font-size: var(--mw-fs-300); display: flex; gap: var(--mw-space-2); align-items: center; }
.mw-card__meta .mw-dot { opacity: .5; }

/* ----- Entrada individual (single destacado) ----- */
.mw-reading-progress {
  position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 200;
  background: linear-gradient(90deg, var(--mw-green), var(--mw-green-700));
  transition: width .1s linear;
}
.mw-single-template { padding-bottom: var(--mw-space-9); }
.mw-single { max-width: 820px; }

/* Hero del articulo (imagen a sangre completa + overlay, o acento verde) */
.mw-post__hero {
  position: relative; isolation: isolate; overflow: hidden;
  padding-block: var(--mw-space-9); background: var(--mw-bg-deep);
  border-bottom: 1px solid var(--mw-border);
}
.mw-post__hero::after {
  content: ""; position: absolute; inset: 0; z-index: -2;
  background: radial-gradient(700px 360px at 75% -10%, var(--mw-green-soft), transparent 60%);
}
.mw-post__hero.has-img { padding-block: clamp(3rem, 12vh, 7rem); }
.mw-post__hero-img { position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%; object-fit: cover; }
.mw-post__hero-overlay {
  position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(20, 26, 31, .74) 0%, rgba(20, 26, 31, .9) 100%);
}
.mw-post__hero-inner { max-width: 880px; text-align: center; }
.mw-post__cat { margin-bottom: var(--mw-space-3); }
.mw-post__title { font-size: var(--mw-fs-900); margin: var(--mw-space-3) auto; max-width: 20ch; }
.mw-post__meta {
  color: var(--mw-200); font-size: var(--mw-fs-300);
  display: flex; gap: var(--mw-space-2); justify-content: center; align-items: center; flex-wrap: wrap;
}
.mw-post__meta .mw-dot { opacity: .5; }
.mw-post__avatar img { width: 28px; height: 28px; border-radius: 50%; vertical-align: middle; border: 1px solid var(--mw-border); }
.mw-post__author { color: var(--mw-heading); font-weight: var(--mw-w-medium); }

/* Cuerpo del articulo */
.mw-single-wrap { max-width: 820px; margin-inline: auto; padding-top: var(--mw-space-7); }
.entry-content > p:first-of-type::first-letter {
  float: left; font-size: 3.4em; line-height: .8; font-weight: var(--mw-w-bold);
  color: var(--mw-green); margin: .05em .14em 0 0;
}

/* Compartir */
.mw-share { display: flex; align-items: center; gap: var(--mw-space-2); margin-top: var(--mw-space-4); flex-wrap: wrap; }
.mw-share__label { font-size: var(--mw-fs-300); color: var(--mw-text-muted); font-weight: var(--mw-w-bold);
  text-transform: uppercase; letter-spacing: .04em; margin-right: var(--mw-space-1); }
.mw-share__link {
  display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px;
  border-radius: var(--mw-radius-pill); background: var(--mw-surface); border: 1px solid var(--mw-border); color: var(--mw-text);
  transition: background var(--mw-dur) var(--mw-ease), color var(--mw-dur) var(--mw-ease), transform var(--mw-dur) var(--mw-ease), border-color var(--mw-dur) var(--mw-ease);
}
.mw-share__link:hover { background: var(--mw-green); color: var(--mw-on-accent); border-color: var(--mw-green); transform: translateY(-2px); }

/* Caja de autor */
.mw-author {
  display: flex; gap: var(--mw-space-4); align-items: flex-start; margin-top: var(--mw-space-7);
  padding: var(--mw-space-5); background: var(--mw-surface); border: 1px solid var(--mw-border);
  border-left: 3px solid var(--mw-green); border-radius: var(--mw-radius-lg);
}
.mw-author__avatar img { width: 64px; height: 64px; border-radius: 50%; display: block; }
.mw-author__label { font-size: var(--mw-fs-300); color: var(--mw-green); font-weight: var(--mw-w-bold); text-transform: uppercase; letter-spacing: .04em; }
.mw-author__name { font-size: var(--mw-fs-600); margin: 2px 0 var(--mw-space-2); }
.mw-author__bio { color: var(--mw-text-muted); font-size: var(--mw-fs-300); margin: 0; }

/* Paginas normales (sin Elementor) */
.mw-page__header { padding-top: var(--mw-space-8); }
.mw-page__title { font-size: var(--mw-fs-800); text-align: center; }
.mw-page__title::after {
  content: ""; display: block; width: 64px; height: 3px; border-radius: 2px;
  background: var(--mw-green); margin: var(--mw-space-3) auto 0;
}
.mw-page__content { max-width: 820px; margin-inline: auto; padding-block: var(--mw-space-7) var(--mw-space-9); }

/* Tipografia del contenido */
.entry-content { font-size: var(--mw-fs-500); line-height: 1.75; color: var(--mw-text); }
.entry-content > * + * { margin-top: var(--mw-space-5); }
.entry-content h2 { font-size: var(--mw-fs-700); margin-top: var(--mw-space-7); }
.entry-content h3 { font-size: var(--mw-fs-600); margin-top: var(--mw-space-6); }
.entry-content a { color: var(--mw-green); text-decoration: underline; text-underline-offset: 3px; }
.entry-content a:hover { color: var(--mw-green-700); }
.entry-content img, .entry-content figure { border-radius: var(--mw-radius); }
.entry-content ul, .entry-content ol { padding-left: 1.4em; }
.entry-content li { margin-bottom: var(--mw-space-2); }
.entry-content blockquote {
  border-left: 3px solid var(--mw-green);
  padding: var(--mw-space-3) var(--mw-space-5); color: var(--mw-200); font-style: italic;
  background: var(--mw-green-soft); border-radius: 0 var(--mw-radius) var(--mw-radius) 0;
}
.entry-content code { background: var(--mw-800); padding: .15em .4em; border-radius: 4px; font-size: .9em; border: 1px solid var(--mw-border); }
.entry-content pre { background: var(--mw-900); padding: var(--mw-space-5); border-radius: var(--mw-radius); overflow: auto; border: 1px solid var(--mw-border); }
.entry-content pre code { background: none; border: 0; padding: 0; }
.entry-content table { width: 100%; border-collapse: collapse; }
.entry-content th, .entry-content td { border: 1px solid var(--mw-border); padding: var(--mw-space-3); text-align: left; }
.entry-content th { background: var(--mw-surface); color: var(--mw-heading); }

/* Etiquetas */
.mw-post__footer { margin-top: var(--mw-space-7); padding-top: var(--mw-space-5); border-top: 1px solid var(--mw-border); }
.mw-tags { list-style: none; display: flex; flex-wrap: wrap; gap: var(--mw-space-2); padding: 0; margin: 0; }
.mw-tags a {
  display: inline-block; padding: .3rem .9rem; border-radius: var(--mw-radius-pill);
  background: var(--mw-surface); border: 1px solid var(--mw-border); color: var(--mw-text-muted); font-size: var(--mw-fs-300);
}
.mw-tags a:hover { color: var(--mw-green); border-color: var(--mw-green); }

/* Navegacion entre entradas */
.mw-post-nav { margin-top: var(--mw-space-7); }
.mw-post-nav .nav-links { display: flex; justify-content: space-between; gap: var(--mw-space-4); }
.mw-post-nav a {
  display: flex; flex-direction: column; gap: 4px; padding: var(--mw-space-4) var(--mw-space-5); flex: 1;
  background: var(--mw-surface); border: 1px solid var(--mw-border); border-radius: var(--mw-radius);
  transition: border-color var(--mw-dur) var(--mw-ease);
}
.mw-post-nav a:hover { border-color: var(--mw-green); }
.mw-post-nav .nav-next { text-align: right; }
.mw-nav-sub { font-size: var(--mw-fs-300); color: var(--mw-green); font-weight: var(--mw-w-bold); }
.mw-nav-title { color: var(--mw-heading); }

/* Paginacion */
.pagination { margin-top: var(--mw-space-8); }
.pagination .nav-links { display: flex; gap: var(--mw-space-2); justify-content: center; flex-wrap: wrap; }
.pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center; min-width: 42px; height: 42px; padding: 0 .6rem;
  border-radius: var(--mw-radius-sm); border: 1px solid var(--mw-border); color: var(--mw-text); background: var(--mw-surface);
  transition: border-color var(--mw-dur) var(--mw-ease), color var(--mw-dur) var(--mw-ease);
}
.pagination .page-numbers:hover { border-color: var(--mw-green); color: var(--mw-green); }
.pagination .page-numbers.current { background: var(--mw-green); color: var(--mw-on-accent); border-color: var(--mw-green); font-weight: var(--mw-w-bold); }

@media (min-width: 600px) { .mw-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1025px) { .mw-grid { grid-template-columns: repeat(3, 1fr); } }

/* ==========================================================================
   8. Accesibilidad: reduce-motion
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
