/* ===============================
   TOKENS BASE
   =============================== */
:root{
  --ink:#0f172a;
  --paper:#fbf7f2;
  --surface:#ffffff;
  --muted:#64748b;

  --brand:#b8860b;
  --brand-dark:#8b6508;

  --border: rgba(15,23,42,.12);

  --radius:18px;
  --radius-lg:24px;

  --shadow-sm: 0 6px 16px rgba(2,6,23,.06);
  --shadow-md: 0 16px 40px rgba(2,6,23,.10);
  --shadow-lg: 0 26px 70px rgba(2,6,23,.14);

  --container:1120px;

  --fs-h1:clamp(26px,5.2vw,40px);
  --fs-h2:clamp(20px,4.2vw,30px);
  --fs-h3:clamp(17px,3.2vw,22px);
  --fs-body:16px;

  --ring:0 0 0 4px rgba(184,134,11,.22);

  --transition-fast:.18s cubic-bezier(.2,.8,.2,1);
  --transition-med:.28s cubic-bezier(.2,.8,.2,1);
}

/* ===============================
   RESET
   =============================== */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:var(--fs-body);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  background:
    radial-gradient(900px 500px at 10% -10%, rgba(184,134,11,.12), transparent 60%),
    radial-gradient(800px 520px at 90% 0%, rgba(15,23,42,.08), transparent 55%),
    linear-gradient(180deg, #fdfbf8 0%, var(--paper) 35%, #ffffff 100%);
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

button{ font:inherit; }
:focus{ outline:none; }
:focus-visible{ box-shadow: var(--ring); border-color: rgba(184,134,11,.55); }
::selection{ background: rgba(184,134,11,.22); }

/* ✅ Underline SOLO para links de contenido (y solo dentro de secciones) */
main .section a:not(.btn):not(.btn-footer):not(.wa-float):hover{
  text-decoration: underline;
}

/* ===============================
   LAYOUT
   =============================== */
.container{
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:max(16px, env(safe-area-inset-left));
  padding-right:max(16px, env(safe-area-inset-right));
}
.section{ padding:clamp(36px,7vw,84px) 0; }

.section-head{
  text-align:center;
  margin-bottom:clamp(22px,5vw,40px);
}
.section-head h2{
  font-size:var(--fs-h2);
  margin:6px 0 10px;
  text-wrap:balance;
  letter-spacing:-.02em;
  line-height:1.15;
}
.section-head .section-sub{
  color:var(--muted);
  max-width:640px;
  margin:0 auto;
  text-wrap:pretty;
}
.kicker{
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--brand-dark);
  font-weight:800;
}
.lead{
  font-size:16px;
  color: rgba(15,23,42,.78);
  line-height:1.7;
}

/* ===============================
   HEADER / NAV
   =============================== */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(12px) saturate(160%);
  border-bottom:1px solid rgba(15,23,42,.10);
  transition:background .35s ease, box-shadow .35s ease;
}
.site-header.scrolled{
  background:rgba(255,255,255,.98);
  box-shadow:0 6px 24px rgba(0,0,0,.06);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:72px;
  padding:10px 0;
  gap:16px;
}

/* Brand */
.brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.brand-logo{
  width:42px;height:42px;
  display:grid;place-items:center;
  border-radius:999px;
  font-weight:900;font-size:18px;letter-spacing:.08em;
  color:#fff;
  background:radial-gradient(circle at 30% 0,#facc15,#b8860b 55%,#1e1b4b 100%);
  box-shadow:0 10px 26px rgba(2,6,23,.24);
}
.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.15;
}
.brand-title{ font-weight:800; font-size:15px; letter-spacing:.01em; }
.brand-sub{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--muted);
}

/* Menu */
.site-nav ul{
  display:flex;
  align-items:center;
  gap:18px;
  list-style:none;
  margin:0;padding:0;
}

/* ✅ Blindaje anti-underline / anti-borde raro SOLO dentro del header */
.site-header .site-nav a{
  text-decoration:none !important;
  text-decoration-line:none !important;
  border-bottom:0 !important;
  background-image:none !important;
}

/* Links normales del menú */
.site-nav a{
  position:relative;
  display:inline-flex;
  align-items:center;
  padding:6px 0;
  font-size:14px;
  font-weight:600;
  color:#111827;
  transition:color var(--transition-fast);
}
.site-nav a:hover{ color:var(--brand-dark); }

/* ✅ Barrita premium SOLO en links normales (no login) */
.site-nav a:not(.nav-login)::after,
.site-nav li:not(.nav-login) > a::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-3px;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg,#facc15,#b8860b);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform var(--transition-fast);
}
.site-nav a:not(.nav-login):hover::after,
.site-nav a:not(.nav-login):focus-visible::after,
.site-nav a:not(.nav-login).is-active::after,
.site-nav li:not(.nav-login) > a:hover::after,
.site-nav li:not(.nav-login) > a:focus-visible::after,
.site-nav li:not(.nav-login) > a.is-active::after{
  transform:scaleX(1);
}

/* ✅ Nunca barrita en el botón login (soporta class en <li> o en <a>) */
.site-nav .nav-login a::after,
.site-nav a.nav-login::after{
  content:none !important;
  display:none !important;
}

/* ===============================
   BOTÓN LOGIN (MISMAS DIMENSIONES/ESTILO + BORDE COMPLETO)
   - Mantiene: padding 8px 14px, font-weight 800, pill
   - Fix: borde con inset-shadow para que no se “corte”
   =============================== */
.site-header .nav-login > a,
.site-header a.nav-login{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;

  /* ✅ EXACTO como tu archivo */
  padding:8px 14px;
  border-radius:999px;
  font-weight:800;
  line-height:1;
  white-space:nowrap;

  /* ✅ Fix del borde incompleto */
  border:0 !important;
  box-shadow: inset 0 0 0 2px var(--brand);

  background:transparent;
  color:var(--brand-dark);

  text-decoration:none !important;
  -webkit-font-smoothing:antialiased;
  transform:translateZ(0);
  transition:background .2s ease, color .2s ease, transform .15s ease, box-shadow .2s ease;
}
.site-header .nav-login > a:hover,
.site-header a.nav-login:hover{
  background:var(--brand);
  color:#fff;
  transform:translateY(-2px) translateZ(0);
  box-shadow:
    inset 0 0 0 2px var(--brand),
    0 10px 24px rgba(184,134,11,.18);
}
.site-header .nav-login > a:active,
.site-header a.nav-login:active{
  transform:scale(.98) translateZ(0);
}

/* Burger */
.menu-btn{
  display:none;
  width:42px;height:42px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.6);
  background:rgba(248,250,252,.75);
  align-items:center;justify-content:center;
  flex-direction:column;gap:4px;
  cursor:pointer;padding:0;
}
.menu-btn span{
  width:20px;height:2px;
  border-radius:999px;background:#111827;
  transition:transform .2s ease, opacity .2s ease;
}
.menu-btn.is-open span:nth-child(1){ transform:translateY(4px) rotate(45deg); }
.menu-btn.is-open span:nth-child(2){ opacity:0; }
.menu-btn.is-open span:nth-child(3){ transform:translateY(-4px) rotate(-45deg); }

/* ===============================
   HERO VIDEO
   =============================== */
.hero-video{
  position:relative;
  min-height:clamp(300px,70vh,520px);
  overflow:hidden;
  border-radius:0 0 var(--radius-lg) var(--radius-lg);
  box-shadow:var(--shadow-md);
  margin:0 0 clamp(28px,6vw,50px);
}
.hero-media{
  width:100%;height:100%;
  object-fit:cover;
}
.hero-overlay{
  position:absolute;inset:0;
  display:flex;align-items:center;
  background:linear-gradient(120deg,rgba(15,23,42,.78),rgba(15,23,42,.15));
  padding:clamp(18px,4vw,36px) 0;
}
.hero-content{ color:#f9fafb; max-width:640px; }
.hero-kicker{
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.18em;
  margin:0 0 10px;
  color:#e5e7eb;
  font-weight:700;
}
.hero-content h1{
  font-size:var(--fs-h1);
  margin:0 0 12px;
  text-wrap:balance;
}
.hero-sub{
  margin:0 0 18px;
  color:#e5e7eb;
  text-wrap:pretty;
}
.hero-actions{
  display:flex;flex-wrap:wrap;gap:10px;
  align-items:center;
}

/* ===============================
   BUTTONS
   =============================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:44px;
  border-radius:999px;
  padding:11px 18px;
  font-size:14px;
  font-weight:800;
  letter-spacing:.01em;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform var(--transition-fast),
             box-shadow var(--transition-fast),
             background var(--transition-fast),
             border-color var(--transition-fast),
             color var(--transition-fast);
}
.btn:hover{ transform:translateY(-1px); box-shadow:var(--shadow-sm); }
.btn:active{ transform:translateY(0) scale(.99); }

.btn-brand{
  color:#fff;
  border-color: rgba(184,134,11,.35);
  background: radial-gradient(120% 120% at 15% 0%, #ffd47a 0%, var(--brand) 45%, var(--brand-dark) 100%);
}
.btn-brand:hover{ box-shadow: 0 16px 44px rgba(184,134,11,.18); }

.btn-ghost{
  background:rgba(255,255,255,.70);
  border-color: rgba(15,23,42,.14);
  color:#0f172a;
}
.btn-ghost:hover{ background:rgba(255,255,255,.92); }

/* ===============================
   WELCOME / ABOUT
   =============================== */
.welcome{ padding-top:clamp(36px,7vw,60px); }
.welcome-grid{ display:grid; gap:clamp(18px,5vw,40px); }
.welcome h2{ font-size:var(--fs-h2); margin-top:0; }

.welcome-highlights{ display:grid; gap:14px; }
.pill{
  border-radius:20px;
  padding:12px 14px;
  background:#fefce8;
  border:1px solid rgba(250,204,21,.35);
  box-shadow:0 8px 20px rgba(202,138,4,.08);
}
.pill h3{ margin:0 0 4px; font-size:15px; }
.pill p{ margin:0; font-size:14px; color:var(--muted); text-wrap:pretty; }

.about-grid{ display:grid; gap:clamp(18px,4vw,36px); }
.about h2{ font-size:var(--fs-h2); margin-top:0; }

.about-cards{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.about-card{
  border-radius:18px;
  padding:14px 16px;
  background:radial-gradient(circle at top left,#fef3c7 0,#fff7ed 40%,#ffffff 100%);
  border:1px solid rgba(248,250,252,.85);
  box-shadow:var(--shadow-sm);
}
.about-card h3{ margin:0 0 4px; font-size:15px; }
.about-card p{ margin:0; font-size:14px; color:var(--muted); text-wrap:pretty; }

/* ===============================
   CATALOGO
   =============================== */
.catalog{
  background:radial-gradient(circle at top,#fefce8 0,#faf5ff 40%,#f9f5f0 100%);
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  margin-top:clamp(28px,6vw,60px);
}

/* Tabs */
.catalog-head.navline{
  display:inline-flex;
  gap:6px;
  padding:4px;
  background:rgba(15,23,42,.04);
  border-radius:999px;
  border:1px solid rgba(148,163,184,.4);
  margin-bottom:18px;
  flex-wrap:wrap;
  justify-content:center;
}
.catalog-head .tab{
  border:0;background:transparent;
  padding:6px 12px;border-radius:999px;
  font-size:13px;font-weight:800;
  color:var(--muted);
  cursor:pointer;
  white-space:nowrap;
  transition:background var(--transition-fast),
            color var(--transition-fast),
            box-shadow var(--transition-fast),
            transform var(--transition-fast);
}
.catalog-head .tab.is-active{
  background:#111827;
  color:#f9fafb;
  box-shadow:0 8px 25px rgba(15,23,42,.5);
  transform:translateY(-1px);
}

/* Grid */
.catalog-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}

/* Cards */
.course-card{
  display:grid;
  grid-template-columns: 220px minmax(0,1fr);
  gap:12px;
  padding:10px;
  border-radius:18px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(148,163,184,.25);
  box-shadow:var(--shadow-sm);
  cursor:pointer;
  transition:transform var(--transition-fast),
             box-shadow var(--transition-fast),
             border-color var(--transition-fast),
             background var(--transition-fast);
  min-width:0;
}
.course-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:rgba(15,23,42,.25);
  background:#fff;
}

/* ✅ THUMB FIX: NUNCA RECORTA */
.course-thumb{
  border-radius:16px;
  overflow:hidden;
  position:relative;
  aspect-ratio: 4 / 5;
  background:#f5f2ea;
  display:grid;
  place-items:center;
}
.course-thumb img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  padding:10px;
  display:block;
}

/* Body */
.course-body h3{ margin:0 0 4px; font-size:15px; }
.course-body p{ margin:0 0 8px; font-size:14px; color:var(--muted); text-wrap:pretty; }

.chip{
  display:inline-flex;align-items:center;
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  border:1px solid rgba(184,134,11,.26);
  background: rgba(184,134,11,.10);
  color:#92400e;
}

/* CTA */
.course-cta{
  margin-top: 10px;
  background: transparent;
  border: 0;
  padding: 0;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-weight: 900;
  color: var(--brand);
  cursor: pointer;
}
.course-cta:hover{ text-decoration: underline; }
.course-cta:focus-visible{
  outline: 2px solid rgba(184,134,11,.55);
  outline-offset: 3px;
  border-radius: 8px;
}

/* ===============================
   UBICACIÓN
   =============================== */
.location.location-premium{
  position:relative;
  background:
    radial-gradient(900px 520px at 18% -10%, rgba(184,134,11,.12), transparent 60%),
    radial-gradient(900px 520px at 92% 110%, rgba(15,23,42,.08), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.45), rgba(255,255,255,0));
}

.location-grid{
  display:grid;
  gap:18px;
  align-items:stretch;
}

.location-card{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(15,23,42,.10);
  border-radius:22px;
  box-shadow:var(--shadow-sm);
  padding:clamp(16px, 3.5vw, 26px);
}

.location-card h2{
  margin:6px 0 10px;
  font-size:var(--fs-h2);
  line-height:1.12;
  letter-spacing:-.02em;
  text-wrap:balance;
}

.info-list{
  list-style:none;
  padding:0;
  margin:0 0 12px;
  display:grid;
  gap:10px;
}
.info-list li{
  font-size:14.5px;
  color: rgba(15,23,42,.85);
  line-height:1.5;
}
.location-note{
  font-size:13px;
  color:var(--muted);
  margin:10px 0 0;
}
.location-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:6px;
}
.location-actions .btn{ min-height:44px; }

/* ===============================
   MAPA (FIX: NO OSCURO + skeleton seguro)
   =============================== */
.map-card{
  position:relative;
  border-radius:22px;
  overflow:hidden;
  box-shadow:var(--shadow-md);
  background:#020617;
  min-height:320px;
  border:1px solid rgba(255,255,255,.08);
}

/* iframe arriba, SIN filtros */
.map-card iframe{
  width:100%;
  height:360px;
  border:0;
  display:block;
  position:relative;
  z-index:1;
  opacity:1 !important;
  filter:none !important;
  mix-blend-mode:normal !important;
}

/* Skeleton SOLO mientras carga (y se auto-apaga aunque JS falle) */
.map-skeleton{
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(2,6,23,.92), rgba(2,6,23,.80)),
    radial-gradient(600px 380px at 20% 20%, rgba(184,134,11,.20), transparent 55%);
  display:grid;
  place-items:center;
  padding:18px;
  opacity:1;
  visibility:visible;
  transition:opacity .25s ease, visibility .25s ease;
  animation: skeletonAutoHide .35s ease 2.8s forwards;
}
@keyframes skeletonAutoHide{
  to{ opacity:0; visibility:hidden; }
}
.map-card.is-loaded .map-skeleton{
  opacity:0;
  visibility:hidden;
  animation:none;
}

.map-badge{
  position:absolute;
  left:14px;
  bottom:14px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(2,6,23,.62);
  border:1px solid rgba(255,255,255,.14);
  color:#e5e7eb;
  font-size:12.5px;
  backdrop-filter:blur(10px);
  z-index:3;
}
.map-badge-dot{
  width:8px;height:8px;
  border-radius:999px;
  background:linear-gradient(135deg,#facc15,#b8860b);
  box-shadow:0 0 0 4px rgba(184,134,11,.18);
}

.skeleton-meta{
  width:min(420px, 92%);
  display:grid;
  gap:10px;
  align-items:center;
  justify-items:start;
}
.skeleton-meta .dot{
  width:10px;height:10px;
  border-radius:999px;
  background:rgba(250,204,21,.8);
  box-shadow:0 0 0 6px rgba(184,134,11,.18);
}
.skeleton-meta .line{
  height:10px;
  width:100%;
  border-radius:999px;
  background:rgba(255,255,255,.10);
}
.skeleton-meta .line.short{ width:72%; }
.skeleton-shimmer{
  position:absolute;
  inset:-40% -40%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.16), transparent);
  transform:rotate(18deg);
  animation:shimmer 1.6s linear infinite;
}
@keyframes shimmer{
  0%{ transform:translateX(-35%) rotate(18deg); }
  100%{ transform:translateX(35%) rotate(18deg); }
}

/* ===============================
   MODAL
   =============================== */
.modal-backdrop{
  position:fixed;inset:0;z-index:50;
  display:none;align-items:center;justify-content:center;
  padding:16px;
  background:rgba(15,23,42,.72);
}
.modal-backdrop.is-open{ display:flex; }

.modal{
  max-width:520px;width:100%;
  border-radius:22px;
  background:#f9fafb;
  box-shadow:var(--shadow-lg);
  position:relative;
  padding:18px 18px 20px;
  border: 1px solid rgba(15,23,42,.10);
}
.modal-header{ margin-bottom:10px; }
.modal-header .kicker{ color:#6b7280; }
.modal-header h2{
  margin:4px 0 0;
  font-size:18px;
}
.modal-desc{
  font-size:14px;color:var(--muted);
  margin:4px 0 10px;
  text-wrap:pretty;
}
.modal-meta{
  list-style:none;padding:0;margin:0 0 10px;
  font-size:14px;
}
.modal-meta li{ margin-bottom:4px; }
.modal-meta strong{ font-weight:700; }
.modal-note{ font-size:13px;color:#6b7280; }

.modal-close{
  position:absolute;top:10px;right:12px;
  border:0;background:transparent;
  font-size:24px;line-height:1;cursor:pointer;
  color:#4b5563;
}

/* ===============================
   FOOTER
   =============================== */
.site-footer{
  background:
    radial-gradient(1200px circle at 10% -20%, rgba(210,147,26,.12), transparent 55%),
    radial-gradient(900px circle at 90% 120%, rgba(14,165,233,.10), transparent 60%),
    linear-gradient(180deg, #0f172a 0%, #111827 100%);
  color:#e5e7eb;
  border-top:1px solid rgba(255,255,255,.08);
  padding-bottom:24px;
}
.site-footer .container{
  padding-top:36px;
  padding-bottom:36px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:22px;
  align-items:start;
}
.site-footer h2{
  font-size:20px;
  margin:0 0 10px;
  color:#fff;
}
.site-footer p{
  margin:0 0 12px;
  color:#cbd5e1;
  line-height:1.7;
  font-size:15px;
  max-width:520px;
  text-wrap:pretty;
}
.site-footer .info-list{
  list-style:none;padding:0;margin:10px 0 0;
  display:grid;gap:8px;
}
.site-footer .info-list li{ color:#e2e8f0;font-size:15px; }
.site-footer a{
  color:#fff;
  text-decoration:none;
  border-bottom:1px dashed rgba(255,255,255,.35);
  transition:.2s ease;
}
.site-footer a:hover{
  color:#fde68a;
  border-bottom-color:transparent;
}
.info-ico{
  width:22px;
  display:inline-flex;
  justify-content:center;
  margin-right:6px;
}
.footer-meta{ text-align:left; padding-top:4px; }
.footer-meta p{
  margin:0 0 8px;
  color:#e5e7eb;
  font-size:14px;
}
.footer-sub{ color:#94a3b8; font-size:13px; }
.footer-cta{
  margin-top:14px;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.btn-footer{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:999px;
  font-weight:800;font-size:14px;
  background:linear-gradient(135deg,#d2931a,#f5c451);
  color:#0b1020;
  box-shadow:0 10px 24px rgba(210,147,26,.25);
  border:1px solid rgba(255,255,255,.25);
  transition:.2s ease;
}
.btn-footer:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 30px rgba(210,147,26,.35);
}
.cta-sub{ font-size:12.5px; color:#94a3b8; }
.footer-copy{ font-weight:800; }

/* ===============================
   PRELOADER
   =============================== */
#preloader{
  position:fixed;inset:0;z-index:60;
  background:radial-gradient(circle at top,#facc15 0,#b8860b 38%,#111827 100%);
  display:grid;place-items:center;
  transition:opacity .35s ease, visibility .35s ease;
}
#preloader.hide{ opacity:0;visibility:hidden; }
.preloader-inner{
  background:rgba(15,23,42,.85);
  padding:16px 22px;border-radius:999px;
  display:inline-flex;align-items:center;gap:10px;
  box-shadow:0 20px 55px rgba(0,0,0,.6);
}
.preloader-spinner{
  width:22px;height:22px;border-radius:999px;
  border:3px solid rgba(248,250,252,.2);
  border-top-color:#facc15;
  animation:spin 800ms linear infinite;
}
.loading-text{ margin:0;font-size:13px;color:#f9fafb; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ===============================
   RESPONSIVE
   =============================== */
@media (min-width:720px){
  .welcome-grid{
    grid-template-columns:minmax(0,3fr) minmax(0,2fr);
    align-items:start;
  }
  .about-grid{
    grid-template-columns:minmax(0,3fr) minmax(0,2.2fr);
  }
  .about-cards{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .catalog-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .location-grid{
    grid-template-columns:minmax(0, 1.05fr) minmax(0, 1fr);
  }
  .footer-grid{
    grid-template-columns:minmax(0,2fr) minmax(0,1fr);
    align-items:end;
  }
  .footer-meta{ text-align:right; }
}

@media (max-width:799px){
  .menu-btn{ display:inline-flex; }

  .site-nav{
    position:absolute;
    inset-inline:0;
    top:100%;
    background:rgba(255,255,255,.98);
    border-bottom:1px solid rgba(148,163,184,.3);
    transform-origin:top;
    transform:scaleY(0);
    opacity:0;
    pointer-events:none;
    transition:transform .18s ease, opacity .18s ease;
  }
  .site-nav.open,
  .site-nav.is-open{
    transform:scaleY(1);
    opacity:1;
    pointer-events:auto;
  }

  .site-nav ul{
    flex-direction:column;
    align-items:flex-start;
    padding:6px 16px 12px;
    gap:0;
  }
  .site-nav li{
    width:100%;
    border-top:1px solid #f1f5f9;
  }
  .site-nav li > a{
    width:100%;
    padding:14px;
  }

  /* En móvil, al link normal le quitamos la barrita */
  .site-nav a:not(.nav-login)::after,
  .site-nav li:not(.nav-login) > a::after{ display:none; }

  .brand-text{ display:none; }

  .course-card{ grid-template-columns:1fr; }
  .course-thumb{ aspect-ratio: 16 / 9; }
}

@media (max-width:480px){
  .nav{ min-height:64px; }
  .brand-logo{ width:38px;height:38px;font-size:16px; }

  .hero-actions .btn{ width:100%; justify-content:center; }

  .catalog-head.navline{ width:100%; }
  .catalog-head .tab{ font-size:12.5px; padding:6px 10px; }

  .site-footer .container{ padding-top:28px;padding-bottom:28px; }
  .footer-cta .btn-footer{ width:100%; }
  .map-card iframe{ height:320px; }
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    scroll-behavior:auto !important;
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
  }
}

/* =========================================================
   NAV • Igualar altura de "Iniciar sesión" con el resto del menú (móvil)
   - Desktop: conserva tu diseño del archivo (8px 14px)
   - Móvil: iguala altura al menú (padding 14px)
========================================================= */

/* 1) Base = como tu archivo (desktop / normal) */
.site-header .nav-login > a{
  padding: 8px 14px;      /* 👈 tus dimensiones */
  font-weight: 700;       /* 👈 como tu archivo */
  line-height: 1;         /* evita “cortes” */
  border-radius: 999px;
  white-space: nowrap;
}

/* 2) Móvil: que mida lo mismo que "Contacto" y los demás items */
@media (max-width: 799px){
  .site-header .site-nav li.nav-login > a{
    width: 100% !important;     /* igual que los demás */
    padding: 14px !important;   /* 👈 misma altura del menú */
    box-sizing: border-box;
  }
}

/* =========================================
   FIX DEFINITIVO: misma altura para todos en MENÚ MÓVIL
   (incluye Contacto y el botón Iniciar sesión)
========================================= */
@media (max-width:799px){

  /* Todos los links del menú: misma altura visual */
  .site-header .site-nav li > a{
    display: flex !important;
    align-items: center !important;
    min-height: 48px !important;     /* altura uniforme */
    padding: 14px !important;        /* igual que tu menú */
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* Iniciar sesión: forzamos exactamente misma altura (sirve si nav-login está en LI o en A) */
  .site-header .site-nav li.nav-login > a,
  .site-header .site-nav a.nav-login{
    min-height: 48px !important;
    padding: 14px !important;
    width: 100% !important;
    justify-content: center !important;

    /* mantén tu estilo pill + borde perfecto */
    border-radius: 999px !important;
    border: 0 !important;
    box-shadow: inset 0 0 0 2px var(--brand) !important;

    background: transparent !important;
    font-weight: 800 !important;
    line-height: 1 !important;
  }
}

/* ================================
   FIX FINAL: NAV MÓVIL no debe pisar el botón "Iniciar sesión"
   - Links normales: padding 14px (full width)
   - Login: padding 8px 14px (como tu archivo)
================================== */
@media (max-width:799px){

  /* SOLO links normales */
  .site-header .site-nav li:not(.nav-login) > a{
    width: 100% !important;
    padding: 14px !important;
  }

  /* Login (si la clase está en el <li>) */
  .site-header .site-nav li.nav-login > a{
    width: auto !important;
    padding: 8px 14px !important;   /* ✅ tu dimensión */
    line-height: 1 !important;
    margin: 10px 16px 8px;          /* para que se vea bien dentro del menú */
  }

  /* Login (por si la clase está en el <a>) */
  .site-header .site-nav a.nav-login{
    width: auto !important;
    padding: 8px 14px !important;   /* ✅ tu dimensión */
    line-height: 1 !important;
    margin: 10px 16px 8px;
  }
}

/* =========================================================
   PATCH • NAV ALTURA UNIFORME + BORDE COMPLETO
   ✅ Soporta class en <li> o en <a>: .nav-login / .btn-login
========================================================= */

/* 0) Evita que el header recorte el botón o el menú móvil */
.site-header{ overflow: visible !important; }

/* 1) Normaliza altura de TODOS los links del nav (desktop) */
.site-header .site-nav a{
  display: inline-flex !important;
  align-items: center !important;
  line-height: 1 !important;
  padding-top: 8px;    /* iguala visual con el botón */
  padding-bottom: 8px;
}

/* 2) Botón / CTA login: borde perfecto SIN cambiar dimensiones */
.site-header .nav-login > a,
.site-header a.nav-login,
.site-header .btn-login,
.site-header a.btn-login{
  padding: 8px 14px !important;   /* tus dimensiones */
  border-radius: 999px;
  border: 0 !important;
  box-shadow: inset 0 0 0 2px var(--brand) !important;
  background: transparent;
  text-decoration: none !important;
}

/* Hover/active consistente */
.site-header .nav-login > a:hover,
.site-header a.nav-login:hover,
.site-header .btn-login:hover,
.site-header a.btn-login:hover{
  background: var(--brand);
  color: #fff !important;
  box-shadow:
    inset 0 0 0 2px var(--brand) !important,
    0 10px 24px rgba(184,134,11,.18);
}

.site-header .nav-login > a:active,
.site-header a.nav-login:active,
.site-header .btn-login:active,
.site-header a.btn-login:active{
  transform: scale(.98);
}

/* 3) Móvil: todos los items (incluido login) con la misma altura */
@media (max-width: 799px){
  .site-header .site-nav li > a{
    width: 100% !important;
    padding: 14px !important;     /* misma altura del menú */
    box-sizing: border-box;
  }

  .site-header .nav-login > a,
  .site-header a.nav-login,
  .site-header .btn-login,
  .site-header a.btn-login{
    width: 100% !important;
    padding: 14px !important;
    justify-content: flex-start !important;
  }
}


