/* ============================================================
   ChatZona — Sistema de diseño "Sala viva"
   Mobile-first · sin frameworks · cero peticiones externas
   ============================================================ */
:root{
  /* Color */
  --azul:#1564ff;          /* azul eléctrico de marca */
  --azul-deep:#0a3aa8;     /* azul profundo (hover, degradados) */
  --cielo:#eaf2ff;         /* tinte cielo para bandas */
  --cielo-2:#f4f8ff;
  --coral:#ff5a5f;         /* acento vivo (ligar / corazón) */
  --cta:#ff5a5f;           /* color de los botones de acción (Entrar) */
  --online:#22c55e;        /* presencia */
  /* Acentos por sección (paleta "multicolor vivo") */
  --news:#06b6d4;          /* noticias — turquesa */
  --videos:#8b5cf6;        /* vídeos — morado */
  --tools:#16a34a;         /* herramientas — verde */
  --ink:#11203a;           /* texto principal */
  --ink-2:#41506b;
  --gris:#5e6c86;          /* texto secundario (contraste AA ≥4.5:1 sobre blanco) */
  --linea:#e4e9f2;
  --blanco:#fff;
  --fondo:#fbfcff;
  --accent:var(--azul);            /* fallback; sobreescrito por .sec-news/.sec-videos/etc. */

  /* Forma y profundidad */
  --r:14px; --r-lg:20px;
  --bubble:18px 18px 18px 4px;   /* radio "bocadillo": esquina inf-izq viva */
  --sombra:0 1px 2px rgba(17,32,58,.06), 0 6px 20px rgba(17,32,58,.06);
  --sombra-h:0 8px 28px rgba(21,100,255,.16);
  --wrap:1180px;

  /* Tipografía */
  --display:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --body:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono","Cascadia Mono","JetBrains Mono","Roboto Mono",Menlo,Consolas,monospace;
}

*{box-sizing:border-box}
[hidden]{display:none!important}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);font-size:16px;line-height:1.6;
  color:var(--ink);background:var(--fondo);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:var(--body);line-height:1.18;letter-spacing:-.02em;color:var(--ink);font-weight:800}
a{color:var(--azul);text-decoration:none}
a:hover{color:var(--azul-deep)}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}

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

/* Skip link */
.skip{position:absolute;left:-999px;top:0;background:var(--azul);color:#fff;padding:10px 16px;z-index:200}
.skip:focus{left:8px;top:8px}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--linea)}
.header-inner{display:grid;grid-template-columns:1fr;gap:9px 14px;align-items:center;padding:calc(10px + env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) 10px max(16px,env(safe-area-inset-left))}
.brand{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:800;font-size:1.3rem;color:var(--ink)}
.brand:hover .brand-logo{opacity:.85}
.brand-logo{height:40px;width:auto;display:block;transition:opacity .14s}
/* mask: degradado en el borde derecho = pista de que la nav tiene scroll horizontal */
.main-nav{grid-column:1 / -1;display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;
  -webkit-mask-image:linear-gradient(to right,#000 90%,transparent);mask-image:linear-gradient(to right,#000 90%,transparent)}
.main-nav::-webkit-scrollbar{height:0}
.main-nav a{white-space:nowrap;padding:0 14px;min-height:44px;display:inline-flex;align-items:center;line-height:1.2;border-radius:999px;background:var(--cielo);color:var(--azul-deep);font-size:.9rem;font-weight:600}
.main-nav a[aria-current="page"]{background:var(--azul);color:#fff}
.main-nav a:hover{background:#dbe8ff}

/* ---------- Buscador en home ---------- */
.home-search-block{margin:8px 0 28px}
.home-search{display:flex;gap:0;max-width:620px;box-shadow:var(--sombra);border-radius:14px;overflow:hidden;border:1px solid var(--linea);margin-left:auto;margin-right:auto}
.home-search input{flex:1;min-width:0;min-height:50px;padding:13px 18px;border:0;font-size:1.05rem;background:#fff;color:var(--ink)}
.home-search input:focus{outline:none;box-shadow:inset 0 0 0 2px var(--azul)}
.home-search button{border:0;background:var(--azul);color:#fff;padding:0 24px;font-size:1rem;font-weight:700;cursor:pointer;white-space:nowrap;min-height:50px}
.home-search button:hover{background:var(--azul-deep)}
@media(max-width:480px){.home-search{max-width:100%;flex-direction:column;border-radius:14px}
  .home-search input,.home-search button{border-radius:0;min-height:48px}
  .home-search button{border-radius:0 0 13px 13px;border-top:1px solid rgba(21,100,255,.2)}}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;color:#fff;text-align:center;
  background:radial-gradient(120% 140% at 50% -20%, var(--azul) 0%, var(--azul) 40%, var(--azul-deep) 100%);
  padding:52px 0 48px}
.hero .wrap{position:relative;z-index:2}
.hero h1{color:#fff;font-family:var(--display);font-size:clamp(1.7rem,5vw,2.7rem);margin:0 0 12px}
.lead{font-size:1.1rem;line-height:1.55;color:var(--ink-2);max-width:72ch;margin:0 0 16px}
.hero .lead{max-width:620px;margin:0 auto 24px;font-size:1.08rem;color:#fff}
.quick-enter{display:flex;gap:8px;max-width:520px;margin:0 auto;background:#fff;padding:7px;border-radius:16px;box-shadow:0 12px 40px rgba(8,30,80,.28)}
.quick-enter input{flex:1;min-width:0;padding:13px 14px;border:0;border-radius:11px;font-size:1.05rem;color:var(--ink)}
.quick-enter input:focus{outline:none;box-shadow:0 0 0 3px rgba(21,100,255,.35)}
.quick-enter button{border:0;background:var(--cta);color:#fff;padding:0 20px;border-radius:11px;font-weight:700;cursor:pointer;font-size:1.02rem;white-space:nowrap}
.quick-enter button:hover{filter:brightness(.95)}
.hero-hint{margin:14px 0 0;font-size:.86rem;color:#fff}
/* Bocadillos ambientales (sutiles, decorativos) */
.hero-bubbles{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.18}
.hero-bubbles span{position:absolute;width:42px;height:42px;background:#fff;border-radius:14px 14px 14px 3px;
  animation:float 9s ease-in-out infinite}
.hero-bubbles span:nth-child(1){left:8%;top:30%}
.hero-bubbles span:nth-child(2){left:82%;top:22%;width:30px;height:30px;animation-delay:1.5s}
.hero-bubbles span:nth-child(3){left:70%;top:62%;width:54px;height:54px;animation-delay:.8s}
.hero-bubbles span:nth-child(4){left:18%;top:66%;width:26px;height:26px;animation-delay:2.2s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* ---------- Secciones ---------- */
.block{margin:34px 0}
.block-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:0 0 16px}
.block h2{font-size:1.4rem;margin:0;display:flex;align-items:center;gap:8px}
.block-head a{font-size:.9rem;font-weight:600}
.band{background:linear-gradient(var(--cielo-2),#fff);border-top:1px solid var(--linea);border-bottom:1px solid var(--linea);padding:6px 0 30px}

/* ---------- Tarjeta de sala = bocadillo (elemento firma) ---------- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:13px}
.room-card{position:relative;background:#fff;border:1px solid var(--linea);border-radius:var(--bubble);
  padding:16px 15px;display:flex;flex-direction:column;gap:7px;box-shadow:var(--sombra);
  transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}
.room-card:hover{transform:translateY(-3px);box-shadow:var(--sombra-h);border-color:#cdddff}
.room-emoji{font-size:1.7rem;line-height:1}
.room-name{font-weight:700;color:var(--ink);font-size:1.02rem}
.room-desc{font-size:.82rem;color:var(--gris);line-height:1.45}
.room-meta{margin-top:auto;display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--gris)}
/* "abierta": indicador NEUTRO (la sala existe y está disponible 24 h), no presencia
   real de usuarios. Sin verde pulsante para no fingir gente conectada ahora. */
.online{display:inline-flex;align-items:center;gap:5px;color:var(--gris);font-weight:600}
.online::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--azul)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 7px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.room-badge{color:#b91c1c;font-weight:700}
.tag{position:absolute;top:10px;right:10px;font-size:.66rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;padding:3px 7px;border-radius:999px}
.tag.nueva{background:#e7f9ee;color:#0a7d44}
.tag.destacada{background:#fff0e9;color:#c2410c}

/* Chips de país/ciudad (banderas) */
.chip-row{display:flex;flex-wrap:wrap;gap:9px}
.chip{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--linea);
  border-radius:999px;padding:8px 14px;font-weight:600;color:var(--ink);box-shadow:var(--sombra)}
.chip:hover{border-color:#cdddff;color:var(--ink)}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff;pointer-events:none}
.chip .flag{font-size:1.2rem}

/* ---------- Prosa SEO ---------- */
.prose{max-width:760px;margin-right:auto}
.prose h2{font-size:1.35rem;margin:1.6em 0 .5em}
.prose h3{font-size:1.1rem;margin:1.3em 0 .4em}
.prose p,.prose li{color:var(--ink-2)}
.prose ol,.prose ul{padding-left:1.2em}
.help-table{width:100%;border-collapse:collapse;margin:1em 0 1.6em;font-size:.92rem}
.help-table th{background:var(--cielo-2);text-align:left;padding:7px 10px;font-weight:600;border-bottom:2px solid var(--linea)}
.help-table td{padding:6px 10px;border-bottom:1px solid var(--linea);vertical-align:top}
.help-table td code,.help-table th code{background:var(--cielo-2);padding:1px 5px;border-radius:4px;font-size:.88rem}
@media(min-width:900px){.help-table td:first-child{white-space:nowrap}}
@media(max-width:600px){.help-table td code{overflow-wrap:anywhere}}

/* ---------- Sala: acceso al chat ---------- */
.breadcrumb{display:flex;flex-wrap:wrap;gap:7px;align-items:center;font-size:.88rem;color:var(--gris);margin:18px 0 4px}
.breadcrumb a{color:var(--gris)}
.breadcrumb a:hover{color:var(--azul)}
.breadcrumb .current{color:var(--ink);font-weight:600}
.room-h1{font-family:var(--display);font-size:clamp(1.5rem,4.5vw,2.1rem);margin:6px 0 8px;display:flex;align-items:center;gap:10px}
/* Twemoji: emojis y banderas como imagen, escalados al tamaño de fuente. */
img.emoji{height:1em;width:1em;margin:0 .06em 0 .1em;vertical-align:-.12em;display:inline-block}

/* Estado vacío reutilizable (noticias sin generar, etc.). */
.empty-state{text-align:center;padding:36px 20px;background:linear-gradient(135deg,#fff,var(--cielo-2));
  border:1px solid var(--linea);border-radius:var(--r-lg)}
.empty-state .empty-emoji{font-size:2.6rem;margin:0 0 6px}
.empty-state h2{margin:0 0 8px}
.empty-state p{color:var(--gris);max-width:46ch;margin:0 auto 14px}
.empty-state .btn{margin:4px}

/* Acento de color por sección (paleta multicolor): diferencia noticias/vídeos/trucos */
.sec-news h1,.sec-videos h1,.sec-tools h1{border-left:5px solid var(--azul);padding-left:12px}
.sec-news h1{border-left-color:var(--news)}
.sec-news .chip.active{--accent:#0e7490}   /* #0e7490 sobre blanco: 6.2:1 ✓ AA (--news 2.49:1 fallaba) */
.sec-videos .chip.active{--accent:#6d28d9} /* #6d28d9 sobre blanco: 7.1:1 ✓ AA (--videos 4.23:1 fallaba) */
.sec-tools .chip.active{--accent:#166534}  /* #166534 sobre blanco: 8.9:1 ✓ AA (--tools 3.30:1 fallaba) */
.sec-videos h1{border-left-color:var(--videos)}
.sec-tools h1{border-left-color:var(--tools)}
.sec-news .chip:hover{border-color:var(--news)}
.sec-videos .chip:hover{border-color:var(--videos)}
.sec-tools .chip:hover{border-color:var(--tools)}
/* Etiqueta de categoría en trucos: color más oscuro para contraste AA (#16a34a=3.30:1 fallaba; #0a7d44≈5.1:1 ✓) */
.cat-tag{align-self:flex-start;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:#0a7d44}

.enter-box{position:relative;overflow:hidden;
  background:radial-gradient(130% 150% at 0% 0%,#fff 0%,var(--cielo) 55%,#dfeaff 100%);
  border:1px solid #cfe0ff;border-radius:var(--r-lg);padding:26px 24px 22px;
  box-shadow:var(--sombra-h);text-align:center;margin:18px auto;max-width:680px}
.enter-box::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;
  background:linear-gradient(90deg,var(--azul),var(--coral))}
.enter-live{display:inline-flex;align-items:center;gap:7px;margin:0 0 12px;
  font-size:.8rem;font-weight:600;color:var(--ink-2);background:#fff;
  border:1px solid var(--linea);padding:5px 12px;border-radius:999px}
.enter-live .dot{width:8px;height:8px;border-radius:50%;background:var(--online)}
.enter-box h2{margin:0 0 6px;font-size:1.45rem}
.enter-box .chan{font-family:var(--mono);color:var(--azul);font-size:.85rem;margin:0 0 16px;overflow-wrap:anywhere}
.enter-row{display:flex;gap:9px;max-width:560px;margin:0 auto}
.enter-row input{flex:1;min-width:0;height:50px;padding:0 15px;border:1px solid #c7d6f0;
  border-radius:12px;font-size:1.04rem;background:#fff}
.enter-row input:focus{outline:none;border-color:var(--azul);box-shadow:0 0 0 3px rgba(21,100,255,.3)}
.enter-row button{border:0;background:linear-gradient(135deg,var(--coral),#ff3b6b);color:#fff;
  height:50px;padding:0 26px;border-radius:12px;font-weight:800;font-size:1.05rem;cursor:pointer;
  white-space:nowrap;box-shadow:0 6px 18px rgba(255,90,95,.35);transition:transform .15s,box-shadow .15s}
.enter-row button:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(255,90,95,.45)}
.enter-row button:active{transform:translateY(0)}
.enter-hint{margin:12px 0 0;font-size:.83rem;color:var(--gris)}
@media (prefers-reduced-motion:reduce){.enter-row button{transition:none}}
#chat-mount{margin-top:16px;border-radius:var(--r);overflow:hidden;background:#fff}
#chat-mount iframe{display:block}
.comments{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.comments li{background:#fff;border:1px solid var(--linea);border-radius:12px 12px 12px 4px;padding:10px 14px;font-size:.94rem}
.comments strong{color:var(--azul-deep)}

/* ---------- Botones y utilidades ---------- */
.btn{display:inline-block;background:var(--azul);color:#fff;padding:11px 20px;border-radius:12px;font-weight:700}
.btn:hover{background:var(--azul-deep);color:#fff}
.btn.ghost{background:#fff;color:var(--azul);border:1px solid var(--azul)}
.muted{color:var(--gris)}
.error-page{text-align:center;padding:64px 0}
/* Buscador en su propia página: input + botón redondeados e independientes
   (la clase .search del header los fusiona; aquí van separados). */
.search-page{display:flex;gap:8px;max-width:560px;margin:16px 0 26px}
.search-page input{flex:1;min-width:0;border:1px solid var(--linea);border-right:1px solid var(--linea);border-radius:12px}
.search-page input:focus{outline:none;border-color:var(--azul)}
.search-page button{border-radius:12px;background:var(--azul);color:#fff;padding:0 22px;min-height:44px}
.search-page button:hover{background:var(--azul-deep)}

/* ---------- Noticias ---------- */
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.news-card{background:#fff;border:1px solid var(--linea);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--sombra);transition:transform .14s,box-shadow .14s}
.news-card:hover{transform:translateY(-3px);box-shadow:var(--sombra-h);text-decoration:none}
.news-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;background:var(--cielo)}
.news-body{display:flex;flex-direction:column;gap:6px;padding:14px}
.news-cat{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#0e7490}
.news-title{font-weight:700;color:var(--ink);line-height:1.25}
.news-sum{font-size:.86rem;color:var(--gris);line-height:1.45}
.news-article .news-hero{width:100%;border-radius:var(--r);margin:10px 0 16px;aspect-ratio:1200/630;object-fit:cover}
.news-article .news-meta{font-size:.86rem;margin:0 0 8px}
/* Artículos relacionados (sección de noticias; no usar .comments que es de chat) */
.news-related{list-style:none;padding:0;margin:0;display:grid;gap:6px}
.news-related li{padding:10px 14px;border-left:3px solid var(--news);background:var(--cielo-2);border-radius:0 8px 8px 0}
.news-related a{font-weight:600;color:var(--ink);text-decoration:none}
.news-related a:hover{color:var(--news)}
/* Tarjetas sin imagen: borde superior de acento para no quedar vacías */
.news-card:not(:has(.news-thumb)) .news-body{border-top:4px solid var(--news);padding-top:16px}

/* ---------- Calculadoras ---------- */
.calc{background:linear-gradient(135deg,#fff,var(--cielo-2));border:1px solid var(--linea);border-radius:var(--r-lg);padding:22px;box-shadow:var(--sombra);margin:18px 0}
.calc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.calc-grid label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:.9rem;color:var(--ink-2)}
.calc-grid input,.calc-grid select{padding:11px 12px;border:1px solid var(--linea);border-radius:10px;font-size:1rem;font-weight:400}
.calc-grid input:focus,.calc-grid select:focus{outline:none;border-color:var(--azul)}
.calc-result{margin-top:16px;overflow-x:auto}
table.res{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;border:1px solid var(--linea)}
table.res th{text-align:left;padding:11px 14px;color:var(--gris);font-weight:600;border-bottom:1px solid var(--linea)}
table.res td{text-align:right;padding:11px 14px;font-weight:700;color:var(--ink);border-bottom:1px solid var(--linea)}
table.res tr:first-child td{color:var(--azul);font-size:1.15rem}

/* ---------- Vídeos ---------- */
.video-embed{position:relative;margin:12px 0 18px;border-radius:var(--r);overflow:hidden;background:#000;aspect-ratio:16/9}
.video-play{display:block;width:100%;height:100%;padding:0;border:0;cursor:pointer;background:#000;position:relative}
.video-play img{width:100%;height:100%;object-fit:cover;opacity:.85;transition:opacity .15s}
.video-play:hover img{opacity:1}
.video-play-btn{position:absolute;inset:0;margin:auto;width:72px;height:72px;display:grid;place-items:center;
  background:rgba(139,92,246,.92);color:#fff;border-radius:50%;font-size:1.6rem;box-shadow:0 6px 20px rgba(0,0,0,.4)}

/* ---------- Datos de ciudad ---------- */
.city-card{display:flex;gap:18px;flex-wrap:wrap;background:#fff;border:1px solid var(--linea);border-radius:var(--r);padding:18px;box-shadow:var(--sombra)}
.city-img{width:280px;max-width:100%;border-radius:12px;object-fit:cover;flex:0 0 auto}
.city-info{flex:1;min-width:240px}
.city-info p{color:var(--ink-2);margin-top:0}
.city-facts{list-style:none;padding:0;margin:10px 0 0;display:grid;gap:6px}
.city-facts li{background:var(--cielo-2);border-radius:8px;padding:7px 12px;font-size:.92rem}

/* ---------- Raíles (home / sala): ranking, votación, truco ---------- */
.home-rail,.room-rail{display:grid;grid-template-columns:1fr;gap:16px;margin:24px 0}
@media(min-width:760px){.home-rail,.room-rail{grid-template-columns:1fr 1fr}}
.rail-box{background:#fff;border:1px solid var(--linea);border-radius:var(--r);padding:18px;box-shadow:var(--sombra)}
.rail-box h2{font-size:1.15rem;margin:0 0 12px}
.rail-box .poll-option{margin-bottom:6px}
.news-mini{list-style:none;padding:0;margin:0 0 10px;display:grid;gap:9px}
.news-mini li{line-height:1.35}
.news-mini a{color:var(--ink);font-weight:600;text-decoration:none;border-bottom:1px solid transparent}
.news-mini a:hover{color:var(--news);border-bottom-color:var(--news)}
.rail-daily{background:linear-gradient(135deg,#fff, #f3effe)}
.rail-daily .frase{margin:0 0 12px;padding:0 0 0 12px;border-left:3px solid var(--videos);
  font-style:italic;color:var(--ink-2);line-height:1.45}
.rail-daily .frase cite{display:block;margin-top:6px;font-style:normal;font-weight:600;font-size:.85rem;color:var(--gris)}
.daily-links{margin:0;font-size:.92rem}
.daily-links a{color:#6d28d9;font-weight:600;text-decoration:none}
.daily-links a:hover{text-decoration:underline}

/* ---------- Deportes ---------- */
.results{display:grid;gap:8px}
.result{background:#fff;border:1px solid var(--linea);border-radius:10px;padding:10px 14px;display:flex;flex-wrap:wrap;gap:4px 12px;align-items:center}
.result .r-comp{font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--azul-deep);background:var(--cielo);padding:2px 7px;border-radius:6px}
.result .r-match{flex:1;min-width:200px}
.result .r-meta{font-size:.8rem;color:var(--gris)}

/* ---------- Votaciones / Rankings ---------- */
.poll-form{background:#fff;border:1px solid var(--linea);border-radius:var(--r);padding:18px;display:flex;flex-direction:column;gap:10px;max-width:560px}
.poll-option{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--linea);border-radius:10px;cursor:pointer}
.poll-option:hover{border-color:var(--azul);background:var(--cielo-2)}
.poll-row{margin-bottom:14px}
.poll-row-head{display:flex;justify-content:space-between;margin-bottom:4px;font-weight:600}
.poll-bar{height:14px;background:var(--cielo);border-radius:999px;overflow:hidden}
.poll-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--azul),#3f86ff);border-radius:999px}
.poll-votes{font-size:.8rem;color:var(--gris);margin-top:2px}
.ranking{list-style:none;padding:0;margin:0;display:grid;gap:8px;counter-reset:rk}
.ranking li{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--linea);border-radius:12px;padding:10px 14px}
.rk-pos{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:var(--cielo);color:var(--azul-deep);font-weight:800;font-size:.85rem}
.ranking li:nth-child(1) .rk-pos{background:#ffe9a8;color:#7a5500}
.rk-name{flex:1;font-weight:600;color:var(--ink)}
.rk-votes{color:#d83a3f;font-weight:700}

/* ---------- Novedades musicales ---------- */
.music-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.music-card{display:flex;flex-direction:column;gap:4px;text-align:center}
.music-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px;box-shadow:var(--sombra)}
.music-card:hover{text-decoration:none}
.m-title{font-weight:700;font-size:.85rem;color:var(--ink);line-height:1.2;margin-top:4px}
.m-artist{font-size:.78rem;color:var(--gris)}

/* ---------- FAQ ---------- */
.faq details{background:#fff;border:1px solid var(--linea);border-radius:12px;margin-bottom:10px;overflow:hidden}
.faq summary{cursor:pointer;padding:14px 16px;font-weight:700;color:var(--ink);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+ ";color:var(--azul);font-weight:800}
.faq details[open] summary::before{content:"– "}
.faq details[open] summary{border-bottom:1px solid var(--linea)}
.faq details p{margin:0;padding:12px 16px;color:var(--ink-2)}

/* ---------- Tarot / Horóscopo / Frase ---------- */
.tarot-card{display:flex;gap:20px;flex-wrap:wrap;align-items:center;background:linear-gradient(135deg,#1b1140,#3a1d6e);
  color:#fff;border-radius:var(--r-lg);padding:24px;margin:18px 0;box-shadow:var(--sombra)}
.tarot-face{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  min-width:140px;font-size:3.4rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  border-radius:16px;padding:22px}
.tarot-face span{font-size:.95rem;font-weight:700;letter-spacing:.02em}
.tarot-text{flex:1;min-width:240px}
.tarot-text h2{color:#fff;margin:0 0 8px}
.tarot-text p{color:#e7e0ff}
.tarot-advice{background:rgba(255,255,255,.1);padding:10px 14px;border-radius:10px;margin-top:12px}
table.res.horoscope th{width:110px;white-space:nowrap;vertical-align:top}
table.res.horoscope td{text-align:left;font-weight:500;color:var(--ink-2)}
@media(max-width:600px){
  table.res.horoscope,table.res.horoscope tbody,table.res.horoscope tr,
  table.res.horoscope th,table.res.horoscope td{display:block;width:auto}
  table.res.horoscope th{border-bottom:0;padding-bottom:2px}
  table.res.horoscope td{padding-top:2px}
}
.frase-dia{background:linear-gradient(135deg,var(--cielo),#fff);border:1px solid var(--linea);
  border-left:4px solid var(--videos);border-radius:12px;padding:16px 18px}
.frase-dia blockquote{margin:0;font-size:1.08rem;font-style:italic;color:var(--ink)}
.frase-dia cite{display:block;margin-top:6px;font-size:.85rem;color:var(--gris);font-style:normal}
.daily-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.daily-card{display:block;background:#fff;border:1px solid var(--linea);border-radius:var(--r);padding:18px;box-shadow:var(--sombra)}
.daily-card:hover{transform:translateY(-2px);box-shadow:var(--sombra-h);text-decoration:none}
.daily-card .ic{font-size:1.8rem}
.daily-card .t{display:block;font-weight:700;color:var(--ink);margin:6px 0 2px}
.daily-card .d{font-size:.85rem;color:var(--gris)}

/* El banner de cookies fue reemplazado por el CMP de InMobi (TheMonetizer). */

/* ---------- Paginador ---------- */
.pager{display:flex;align-items:center;justify-content:center;gap:14px;margin:24px 0 8px;flex-wrap:wrap}
.pager-info{color:var(--gris);font-size:.9rem}

/* ---------- Footer ---------- */
.site-footer{background:#0c1a30;color:#aeb9cd;margin-top:48px;padding:40px 0 calc(18px + env(safe-area-inset-bottom))}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:26px}
.footer-grid h2{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:#fff;margin:0 0 12px}
.footer-grid a{display:block;color:#c3cddc;padding:11px 0;font-size:.9rem}
.footer-grid a:hover{color:#fff}
.footer-legal{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;border-top:1px solid #1d2c45;
  margin-top:28px;padding-top:16px;color:#aeb8c9;font-size:.85rem}
.footer-legal a{color:#c3cddc}

/* ---------- Responsive ---------- */
@media(min-width:760px){
  .header-inner{grid-template-columns:auto 1fr;gap:14px}
  .main-nav{grid-column:auto;overflow-x:auto;overflow-y:visible}
  .hero{padding:74px 0 64px}
}

/* ---------- Ajustes finos móvil ---------- */
@media(max-width:480px){
  /* inputs a 16px: evita el auto-zoom de iOS al enfocar */
  input,select,textarea{font-size:16px}
  /* resultado de calculadora: no desbordar en pantallas estrechas */
  .calc-result{overflow-x:auto}
  .calc-result table.res th,.calc-result table.res td{word-break:break-word}
  /* tarjeta de tarot y resultados deportivos: liberar min-width para no forzar
     scroll horizontal a 320px */
  .tarot-text,.tarot-face{min-width:0}
  .tarot-face{width:100%}
  .result .r-match{min-width:0;flex-basis:100%}
}

/* Pantallas muy estrechas: el CTA (input + botón "Entrar") se apila para que el
   apodo tenga sitio que teclear. */
@media(max-width:360px){
  .enter-row,.quick-enter{flex-direction:column}
  .enter-row button,.quick-enter button{width:100%}
}

/* ---------- Accesibilidad: menos movimiento ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ---------- Índice A-Z de salas (/salas/todas) ---------- */
/* top alineado a la altura real del header sticky (~62px); scroll-margin deja el
   título por debajo del header + la propia barra A-Z sticky al saltar a una letra. */
.az-nav{display:flex;flex-wrap:wrap;gap:6px;margin:14px 0 24px;position:sticky;top:62px;
  background:var(--fondo);padding:8px 0;z-index:5}
.az-nav a{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;
  padding:0 8px;background:#fff;border:1px solid var(--linea);border-radius:9px;font-weight:700;
  color:var(--azul);text-decoration:none}
.az-nav a:hover{background:var(--azul);color:#fff;border-color:var(--azul)}
.block[id^="letra-"]{scroll-margin-top:114px}
/* En móvil el header NO es de una fila: apila marca+buscador+nav (~150px). El
   top:62px de escritorio dejaría la barra A-Z tapada bajo el header sticky. */
@media(max-width:759px){
  /* el header apilado (marca+buscador+nav ≈150px) robaba ~25% del viewport en
     móviles cortos; en pantallas pequeñas deja de ser sticky para dar aire al
     contenido. La barra A-Z sí sigue sticky y ahora se ancla al borde superior. */
  .site-header{position:static}
  .tarot-text,.tarot-face{min-width:0}
  .az-nav{top:0}
  .block[id^="letra-"]{scroll-margin-top:280px}
}

/* TheMonetizer — unidades de anuncio */
.tm-ad-unit{width:100%;max-width:100%;overflow:hidden;margin:24px 0}
.tm-ad-unit:not(:empty){min-height:250px}
.outbrain-tm{width:100%;max-width:100%;overflow:hidden;margin:24px 0;min-height:320px}
