/* ============================================================================
   CharlaMotor · telemetria.css
   Capa COMPARTIDA del formato "Telemetría editorial": tokens + atmósfera + nav.
   Enlázalo en TODAS las páginas migradas. El menú (markup) vive en nav.js.
   Cambiar paleta/atmósfera/estilo de la nav = editar SOLO este archivo.
   ============================================================================ */
:root{
  --ink:#070C1A;--ink-2:#0B1530;--panel:#0E1A38;--navy:#1B3568;
  --line:rgba(120,150,210,.16);--line-strong:rgba(140,170,230,.32);
  --amarillo:#FECB00;--plata:#C0C8D8;--dim:#7A879F;
  --verde:#33D98A;--ambar:#F6B73C;--rojo:#FF5A63;--white:#EAF0FB;
  --disp:'Chakra Petch',sans-serif;--ui:'Saira',sans-serif;--mono:'IBM Plex Mono',monospace;--body:'Raleway',sans-serif;
  /* alias heredados (los usan estilos/JS inline de páginas migradas) */
  --yellow:#FECB00;--yellow-dark:#E0B400;--navy-light:#7FA0DA;--navy-dark:#0A1124;--navy-dark-rgb:7,12,26;
  --silver:rgba(140,170,230,.28);--silver-light:rgba(120,150,210,.12);
  --text:#EAF0FB;--text-muted:#7A879F;--success:#33D98A;
  --radius:14px;--radius-sm:9px;--shadow:0 30px 60px -24px rgba(0,0,0,.7);

  /* ── Tokens añadidos (Fase 1: plantilla central) ──────────────────────── */
  /* Color */
  --martini:#A6E1F7;            /* azul claro de etiquetas/secundario */
  --panel-2:#0A142C;            /* fondo de celda/panel oscuro */
  --panel-grad:linear-gradient(180deg,rgba(16,28,60,.94),rgba(9,18,42,.97)); /* cabina oscura */
  --shadow-md:0 18px 40px -22px rgba(0,0,0,.65);
  /* Tamaños de texto (rem) — toca aquí para reescalar tipografía global */
  --fs-hero:clamp(34px,6vw,56px); /* títulos hero */
  --fs-h2:1.4rem;               /* títulos de sección/bloque */
  --fs-h3:1rem;                 /* subtítulos de bloque */
  --fs-cuerpo:16px;             /* párrafos de cuerpo */
  --fs-nota:0.92rem;            /* notas destacadas (p.ej. enlaces aclaratorios) */
  --fs-sec:0.82rem;             /* texto secundario / pies / labels martini */
  --fs-mini:0.72rem;            /* micro-texto, code labels */
}

/* Texto explicativo de cuerpo, FUERA de tarjetas/paneles: blanco, tamaño cuerpo.
   Color y tamaño juntos aquí para controlarlo desde un único sitio. */
.cuerpo-explicativo{color:var(--white);font-size:var(--fs-cuerpo);line-height:1.6;}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--ink) url('/fondo_azul.png') center top/cover no-repeat fixed;color:var(--white);font-family:var(--body);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* atmósfera de fondo: cuadrícula blueprint + glow + grano */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:46px 46px;-webkit-mask-image:radial-gradient(120% 90% at 70% 0%,#000 35%,transparent 80%);mask-image:radial-gradient(120% 90% at 70% 0%,#000 35%,transparent 80%);opacity:.5}
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(60% 50% at 78% 8%,rgba(27,53,104,.55),transparent 70%),radial-gradient(40% 40% at 8% 100%,rgba(254,203,0,.06),transparent 70%)}
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.wrap{position:relative;z-index:2;max-width:1240px;margin:0 auto;padding:0 28px}

/* limpiar restos del sistema de skins viejo en páginas a medio migrar */
.cm-nav,.pw-sidebar,.pw-live-indicator,.cm-burger{display:none!important}
.pw-body-wrap,.pw-main{display:block;position:relative;z-index:2}

/* ===== NAV (el markup lo inyecta nav.js) ===== */
.nav-shell{position:sticky;top:0;z-index:40;border-bottom:1px solid transparent;transition:background .3s,border-color .3s,box-shadow .3s}
.nav-shell.scrolled{background:rgba(7,12,26,.85);backdrop-filter:blur(12px) saturate(140%);border-bottom:1px solid var(--line-strong);box-shadow:0 12px 30px -18px #000}
.nav-shell header{padding:14px 28px;max-width:1240px;margin:0 auto;transition:padding .3s}
.nav-shell.scrolled header{padding:9px 28px}
.nav-top{display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand .wm{font-family:var(--body);font-weight:800;font-size:26px;letter-spacing:.01em;line-height:1}
.brand .a{color:var(--white)}.brand .b{color:var(--amarillo)}
.brand .tk{font-family:var(--mono);font-size:9px;letter-spacing:.16em;color:var(--dim);border:1px solid var(--line);padding:3px 6px;border-radius:2px;text-transform:uppercase}
nav.main{display:flex;gap:2px;align-items:stretch;justify-content:space-between;margin-top:11px;padding-top:11px;border-top:1px solid var(--line)}
/* Cada mundo: enlace a portada + panel desplegable al pasar el ratón */
.nav-world{position:relative;flex:1;display:flex;justify-content:center}
.nav-world-top{display:flex;align-items:center;gap:6px;text-decoration:none;padding:6px 10px;position:relative}
.nav-world-top .tx{font-family:var(--ui);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--plata);transition:color .2s;white-space:nowrap}
.nav-world-top .caret{font-size:9px;color:var(--dim);transition:color .2s,transform .2s}
.nav-world-top::after{content:"";position:absolute;left:10px;right:10px;bottom:-1px;height:2px;background:var(--amarillo);transform:scaleX(0);transform-origin:left;transition:transform .26s cubic-bezier(.2,.7,.2,1)}
.nav-world:hover .nav-world-top .tx,.nav-world.active .nav-world-top .tx{color:var(--white)}
.nav-world:hover .nav-world-top .caret{color:var(--amarillo);transform:rotate(180deg)}
.nav-world:hover .nav-world-top::after,.nav-world.active .nav-world-top::after{transform:scaleX(1)}
/* Panel desplegable (solo escritorio) */
.nav-panel{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);min-width:210px;background:rgba(9,15,32,.97);backdrop-filter:blur(12px) saturate(140%);border:1px solid var(--line-strong);border-radius:8px;box-shadow:0 20px 44px -20px #000;padding:8px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s,transform .2s,visibility .2s;z-index:50}
.nav-world:hover .nav-panel{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(2px)}
.nav-panel-in{display:flex;flex-direction:column;gap:1px}
.nav-panel a{display:block;text-decoration:none;font-family:var(--ui);font-weight:500;font-size:13px;color:var(--white);padding:9px 14px;border-radius:5px;white-space:nowrap;transition:background .15s,color .15s}
.nav-panel a:hover{background:rgba(254,203,0,.1);color:var(--white)}
.nav-panel a.on{color:var(--amarillo)}
.rgt{display:flex;align-items:center;gap:18px}
.club{font-family:var(--ui);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.06em;background:var(--amarillo);color:#0A1124;padding:9px 18px;border-radius:2px;text-decoration:none;box-shadow:0 0 0 1px var(--amarillo);transition:transform .15s,box-shadow .2s}
.club:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(254,203,0,.28)}
.live{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;color:var(--plata);letter-spacing:.1em}
.dot{width:8px;height:8px;border-radius:50%;background:var(--rojo);box-shadow:0 0 0 0 rgba(255,90,99,.6);animation:pulse 1.8s infinite}
.burger{display:none;width:42px;height:36px;border:1px solid var(--line-strong);border-radius:3px;background:transparent;cursor:pointer;position:relative;flex:0 0 auto}
.burger span{position:absolute;left:10px;right:10px;height:2px;background:var(--white);border-radius:2px;transition:.3s}
.burger span:nth-child(1){top:12px}.burger span:nth-child(2){top:17px}.burger span:nth-child(3){top:22px}
.burger.open span:nth-child(1){top:17px;transform:rotate(45deg);background:var(--amarillo)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:17px;transform:rotate(-45deg);background:var(--amarillo)}
.overlay{position:fixed;inset:0;z-index:60;display:flex;flex-direction:column;padding:84px 28px 36px;background:rgba(6,10,22,.98);overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .35s,transform .35s,visibility .35s}
.overlay.open{opacity:1;visibility:visible;transform:none}
.overlay::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:46px 46px;-webkit-mask-image:radial-gradient(120% 80% at 80% 0,#000 30%,transparent 75%);mask-image:radial-gradient(120% 80% at 80% 0,#000 30%,transparent 75%)}
.ov-head{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--line)}
.ov-list{position:relative;display:flex;flex-direction:column}
.ov-world{border-bottom:1px solid var(--line);opacity:0;transform:translateX(-16px)}
.overlay.open .ov-world{animation:ovin .5s cubic-bezier(.2,.7,.2,1) forwards}
.ov-top{display:flex;align-items:baseline;gap:14px;text-decoration:none;padding:15px 0 10px}
.ov-top .ix{font-family:var(--mono);font-size:12px;color:var(--amarillo);min-width:30px}
.ov-top .tx{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:clamp(20px,5.5vw,28px);line-height:.98;color:var(--white);transition:color .2s}
.ov-top:active .tx,.ov-top:hover .tx{color:var(--amarillo)}
.ov-subs{display:flex;flex-direction:column;padding:0 0 12px 44px}
.ov-sub{text-decoration:none;font-family:var(--ui);font-weight:500;font-size:15px;color:var(--white);padding:7px 0;transition:color .15s}
.ov-sub:active,.ov-sub:hover{color:var(--amarillo)}
.ov-foot{position:relative;margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:26px}
.ov-foot .club{padding:13px 24px;font-size:14px}
@keyframes ovin{to{opacity:1;transform:none}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,90,99,.6)}70%{box-shadow:0 0 0 9px rgba(255,90,99,0)}100%{box-shadow:0 0 0 0 rgba(255,90,99,0)}}

@media(max-width:1080px){
  nav.main{display:none}
  .rgt > .live{display:none}
  .burger{display:block}
}
@media(max-width:560px){
  .rgt > .club{display:none}
  .brand .tk{display:none}
}
