/* ASCII only */ 
/* Header with topbar and main bar - responsive + anti-flash + mobile off-canvas */

:root{
  --topbar-h:40px;
  --bar-h:70px;
  --header-shadow:0 4px 8px rgba(0,0,0,.45);

  /* >>> Ajustes del panel movil (ancho) */
  --panel-w: 78vw;      /* ej. 72vw, 66vw */
  --panel-w-max: 400px; /* ej. 360px, 320px */

  /* >>> Espaciado del menu hamburguesa */
  --panel-link-gap: 25px;        /* separacion entre filas de links */
  --panel-link-pad-y: 14px;      /* alto tactil de cada link */
  --panel-links-pad-top: 20px;   /* padding superior del bloque de links */
  --panel-links-pad-bottom: 30px;/* padding inferior del bloque de links */

  /* >>> Mini-cards */
  --card-radius: 14px;
  --card-border: #E5E7EB;        /* gris claro */
  --card-hover: #F3F6FF;         /* hover sutil */
  --card-shadow: 0 2px 10px rgba(0,0,0,.06);
  --ico-border: #3666b3;         /* borde azul del icono */
  --section-title: #334155;      /* slate-700 */

  /* >>> Botones del panel (mismo look y tamano que links) */
  --panel-cta-h: 48px;
  --panel-cta-fs: 18px;
  --panel-cta-radius: 12px;
}

/* ===== PARCHE: cuando hay sesion (topbar oculta), su altura logica debe ser 0 ===== */
body.is-logged { --topbar-h: 0px; }
/* (defensivo) Fuerza la subnav a pegarse al header principal en desktop */
body.is-logged .mc-subnav { top: var(--bar-h); }

.site-header{
  position:fixed; top:0; left:0; right:0; z-index:1000;
}

/* ---------- Topbar ---------- */
.topbar{
  display:block;
  width:100%;
  height:var(--topbar-h);
  background:#3969b5;
  border-bottom:2px solid #d4c9ae;
  color:#fff;
}

/* BASE (mobile/tablet = 100%) */
.topbar-inner{
  width:100%;
  max-width:none;
  height:var(--topbar-h);
  margin:0;
  padding:0 12px;
  display:flex; align-items:center; justify-content:space-between;
}

.topbar a{ color:#fff; text-decoration:none; }
.topbar-mail{ display:inline-flex; align-items:center; gap:10px; font-size:14px; }
.topbar-right{ display:inline-flex; align-items:center; gap:16px; }
.topbar-ico{ display:inline-flex; align-items:center; }
.topbar .ico{ display:block; }
.topbar-mail .ico{ width:20px; height:20px; }
.topbar-ico .ico{ width:24px; height:24px; }

/* ---------- Barra principal ---------- */
.bar{
  height:var(--bar-h);
  background:#fff;
  border-bottom:1px solid #e5e5e5;
  box-shadow:var(--header-shadow);
}

/* BASE (mobile/tablet = 100%) */
.header-inner{
  width:100%;
  max-width:none;
  height:var(--bar-h);
  margin:0;
  padding:0 12px;
  display:flex; align-items:center; gap:12px; flex-wrap:nowrap; overflow:hidden;
}

.brand{ display:inline-flex; align-items:center; gap:8px; text-decoration:none; }
.logo{ display:block; width:80px; height:57.87px; }

/* Nav + acciones */
.main-nav{ margin-left:auto; display:flex; align-items:center; flex:1 1 auto; min-width:0; }

/* Boton de menu (movil) */
.menu-toggle{
  display:none; padding:8px 10px; border:1px solid #3969b5; background:#fff; color:#3969b5;
  border-radius:8px; cursor:pointer; margin-left:auto;
}

/* Icono de hamburguesa dentro del boton */
.menu-toggle .menu-icon{
  display:inline-block;
  width:22px;
  height:2px;
  background: currentColor;
  position: relative;
  vertical-align: middle;
}
.menu-toggle .menu-icon::before,
.menu-toggle .menu-icon::after{
  content:"";
  position:absolute;
  left:0;
  width:22px;
  height:2px;
  background: currentColor;
}
.menu-toggle .menu-icon::before{ top:-6px; }
.menu-toggle .menu-icon::after{ top:6px; }

/* Lista de links (desktop) */
.nav-links{
  list-style:none; margin:0; padding:0; display:flex; gap:16px; align-items:center;
  white-space:nowrap;
  overflow:hidden;
}
.nav-links a{
  color:#272626; text-decoration:none; padding:8px 6px; border-radius:8px;
  font-weight:700; /* Bold en desktop */
}
.nav-links a:hover{ background:#f2f6ff; }

/* Acciones auth (desktop) */
.auth-actions{
  display:inline-flex; gap:8px;
  white-space:nowrap;
  flex:0 0 auto;
}

/* ---------- Botones del header (override) ---------- */
.site-header .btn{
  display:inline-block;
  padding:10px 6px;
  border-radius:8px;
  font-size:14px;
  line-height:1.2;
  border:1px solid transparent;
  text-decoration:none;
  cursor:pointer;
  transition:transform .05s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.site-header .btn:active{ transform: translateY(1px); }

.site-header .btn-primary{
  background:#3969b5;
  color:#fff;
  border-color:#3969b5;
  box-shadow:0 2px 6px rgba(0,0,0,.2);
}
.site-header .btn-primary:hover{
  background:#4584ea;
  border-color:#4584ea;
}
.site-header .btn-outline{
  background:#fff;
  color:#3969b5;
  border-color:#3969b5;
}
.site-header .btn-outline:hover{ background:#f2f6ff; }
.site-header .btn-danger{
  background:#e53935;
  color:#fff;
  border-color:#e53935;
}
.site-header .btn-danger:hover{ background:#ff4d49; }

/* Spacer para header fijo */
.header-spacer{ height:calc(var(--topbar-h) + var(--bar-h)); }

/* ---------- Badge ---------- */
.sub-state-badge{
  margin-left:8px; padding:2px 8px; border-radius:999px; font-size:12px; line-height:1.6;
  border:1px solid #e5e5e5; background:#fff; color:#333; vertical-align:middle; white-space:nowrap;
}
.sub-state-badge.is-active{
  border-color:rgba(56,189,248,.45);
  background:rgba(56,189,248,.10);
  color:#0369a1;
}
.sub-state-badge.is-inactive{
  border-color:rgba(239,68,68,.45);
  background:rgba(239,68,68,.10);
  color:#b91c1c;
}

/* ---------- Anti-flash (SOLO CSS) ---------- */
[data-auth-only]{ display:none !important; }
body.is-logged li[data-auth-only]{ display:list-item !important; }
body.is-logged [data-auth-only]:not(li){ display:block !important; }

#btnLogout,
#btnLogoutMobile,
#navSubState,
#navSubStatePanel{ display:none !important; }
body.is-logged #btnLogout,
body.is-logged #btnLogoutMobile{ display:inline-block !important; }
body.is-logged #navSubState,
body.is-logged #navSubStatePanel{ display:inline-block !important; }

[data-anon-only]{ display:inline-block; }
body.is-logged [data-anon-only]{ display:none !important; }

body.is-logged:not(.is-subscriber) .site-header a[data-protected]{
  pointer-events:none !important;
  cursor:not-allowed !important;
  opacity:.6;
  filter: grayscale(.1);
}

body.is-logged .topbar{ display:none !important; }
body.is-logged .header-spacer{ height:var(--bar-h); }

/* ========== OFF-CANVAS MOVIL (<=1023px) ========== */
@media (max-width: 1023px){
  .menu-toggle{ display:inline-block; }
  .main-nav{ display:none; }
  .auth-actions{ display:none; }

  .nav-panel{
    position:fixed; top:0; left:0; height:100vh;
    width:var(--panel-w); max-width:var(--panel-w-max);
    background:#fff;
    box-shadow: 2px 0 16px rgba(0,0,0,.18);
    transform: translateX(-100%);
    transition: transform .28s ease;
    z-index: 30000; overflow:auto;
  }
  .nav-panel.is-open{ transform: translateX(0); }

  .panel-head{
    position:relative; display:flex; align-items:center; gap:10px;
    padding:16px 16px 8px 16px; z-index:0;
  }
  .panel-logo{ display:block; width:80px; height:57.86px; }
  .panel-title{
    position:absolute; left:50%; transform:translateX(-50%);
    margin:0; font-size:22px; line-height:1.2; text-align:center;
  }

  .panel-sep{ height:1px; background:#e5e5e5; margin:8px 16px; }

  .panel-auth{
    padding:12px 16px 24px 16px; display:flex; gap:8px; flex-wrap:wrap;
  }
  .panel-auth-top{ padding-top:0; }
  .panel-auth-bottom{ padding-top:0; padding-bottom:24px; }
  .panel-auth .btn{
    display:flex; align-items:center; justify-content:center;
    width:100%;
    height:var(--panel-cta-h);
    font-size:var(--panel-cta-fs);
    font-weight:700;
    border-radius:var(--panel-cta-radius);
    box-shadow: var(--card-shadow);
    line-height:1;
    text-align:center;
  }

  .panel-group{ padding:0 16px; }
  .panel-section-title{
    margin:10px 0 10px 0;
    font-size:12px; letter-spacing:.08em; text-transform:uppercase;
    color:var(--section-title);
    font-weight:700;
  }
  .panel-cards{
    list-style:none; margin:0 0 16px 0; padding:0;
    display:flex; flex-direction:column; gap:12px;
  }
  .panel-card{
    display:flex; align-items:center; gap:12px;
    padding:12px;
    border:1px solid var(--card-border);
    border-radius: var(--card-radius);
    text-decoration:none;
    background:#fff;
    box-shadow: var(--card-shadow);
    position:relative;
  }
  .panel-card:hover{ background:var(--card-hover); }
  .panel-card .item-ico{
    width:34px; height:34px; flex:0 0 34px;
    display:grid; place-items:center;
    border:2px solid var(--ico-border);
    border-radius:10px;
    font-size:18px; line-height:1;
  }
  .panel-card .item-text{
    color:#111827;
    font-weight:700;
    font-size:18px;
    line-height:1.25;
    display:inline-flex; align-items:center; gap:8px;
  }
  .panel-card .item-chevron{
    margin-left:auto; font-size:22px; color:#94A3B8;
  }

  .panel-links{
    list-style:none; margin:0;
    padding:var(--panel-links-pad-top) 16px var(--panel-links-pad-bottom) 16px;
    display:none; gap:var(--panel-link-gap);
  }
  .panel-links a{
    color:#272626; text-decoration:none;
    padding:var(--panel-link-pad-y) 8px;
    border-radius:8px;
    font-weight:700;
  }

  .nav-close{
    position:absolute; top:10px; right:10px;
    width:36px; height:36px;
    border:1px solid #e5e5e5; background:#fff; color:#333;
    border-radius:8px; cursor:pointer; font-size:18px; line-height:1;
    box-shadow:0 2px 6px rgba(0,0,0,.1);
    z-index:5; touch-action: manipulation;
  }
  .nav-close:active{ transform: translateY(1px); }

  .nav-overlay{
    position:fixed; inset:0; background:rgba(0,0,0,.35);
    opacity:0; visibility:hidden; transition: opacity .2s ease, visibility 0s linear .2s;
    z-index: 29990;
  }
  .nav-overlay.is-active{ opacity:1; visibility:visible; transition: opacity .2s ease; }
}

/* Bloqueo de scroll cuando el panel esta abierto */
html.menu-open, body.menu-open{ overflow:hidden !important; }

/* ---------- DESKTOP (>=1024px) = 85% centrado ---------- */
@media (min-width: 1024px){
  .topbar-inner, .header-inner{
    width:85%; max-width:none; margin:0 auto; padding:0 12px;
  }
}

/* Header por encima de overlays clasicos */
header.site-header, .site-header, #header { z-index: 20000 !important; }

/* ASCII only */
/* Anti-parpadeo del logo:
   Mientras la pagina esta booting, el logo no es clickeable.
   Cuando JS confirma que el usuario NO esta logueado, gate.js quita is-booting
   y vuelve a habilitar el logo. */
body.is-booting #site-logo {
  pointer-events: none !important;
  cursor: default !important;
}

/* ===== Sticky H2 placeholder (solo tablets/moviles) ===== */
.header-h2-sticky{
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  height: var(--bar-h);
  line-height: var(--bar-h);
  max-width: 86%;
  padding: 0 10px;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 400;
  font-size: 14px;
  color: #111827;
  opacity: 0;
  visibility: hidden;
  transition: opacity .18s ease, visibility 0s linear .18s;
  pointer-events: none; /* no bloquea clicks en logo/botones */
}

/* Solo activar en <=1023px; en desktop no se usa */
@media (max-width: 1023px){
  .header-h2-sticky.is-visible{
    opacity: 1;
    visibility: visible;
    transition: opacity .18s ease;
  }
}
