/* S News Theme v1.3 - Extracted from prototype */

/* ════════════════════════════════════════
   DESIGN TOKENS
════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --W:#FFFFFF; --K:#0A0A0A;
  --G1:#F7F7F5; --G2:#E8E8E6; --G3:#CFCFCF;
  --G4:#9A9A9A; --G5:#5A5A5A; --G6:#2A2A2A;
  /* Brand accent — Cinnabar Red (El Salvador flag-inspired) */
    
  /* Shadows */
  --sh-xs:0 1px 4px rgba(0,0,0,.06);
  --sh-sm:0 3px 12px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.04);
  --sh-md:0 8px 28px rgba(0,0,0,.1),0 2px 6px rgba(0,0,0,.05);
  --sh-lg:0 20px 60px rgba(0,0,0,.14),0 6px 16px rgba(0,0,0,.06);
  --BG:'Bricolage Grotesque',sans-serif;
  --DM:'DM Sans',sans-serif;
  --NAV:56px; --MOB:50px; --BOTNAV:64px;
  --MAX:1480px;
  --R4:4px; --R8:8px; --R12:12px;
  --ease:cubic-bezier(.4,0,.2,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
}
html{scroll-behavior:smooth}
body{font-family:var(--DM);background:var(--W);color:var(--K);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a,button{text-decoration:none;color:inherit;cursor:pointer;border:none;background:none;font-family:inherit;outline:none}
img,svg{display:block;max-width:100%;flex-shrink:0}

/* ════════════════════════════════════════
   NAV — precision with brand stripe
════════════════════════════════════════ */
.nav{
  position:sticky;top:0;z-index:600;
  height:var(--NAV);
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(32px) saturate(200%);
  -webkit-backdrop-filter:blur(32px) saturate(200%);
  border-bottom:1px solid var(--G2);
}
/* 3px brand stripe at very top */
.nav::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:3px;background:var(--K);z-index:1;
}
.nav-in{
  max-width:var(--MAX);margin:0 auto;
  height:100%;padding:3px 28px 0;
  display:flex;align-items:center;gap:0;
}
.wordmark{
  font-family:var(--BG);font-size:22px;font-weight:800;
  letter-spacing:-.06em;color:var(--K);line-height:1;
  cursor:pointer;flex-shrink:0;margin-right:32px;
  display:flex;align-items:center;gap:2px;
  user-select:none;transition:opacity .15s;
}
.wordmark:hover{opacity:.7}
.wordmark-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--K);margin-bottom:1px;flex-shrink:0;
}
.nav-links{
  display:flex;align-items:center;flex:1;
  overflow-x:auto;scrollbar-width:none;
}
.nav-links::-webkit-scrollbar{display:none}
.nl{
  font-family:var(--DM);font-size:12.5px;font-weight:400;
  color:var(--G4);padding:0 12px;height:calc(var(--NAV) - 3px);
  display:flex;align-items:center;white-space:nowrap;
  position:relative;transition:color .15s;flex-shrink:0;
  letter-spacing:.01em;
}
.nl:hover{color:var(--K)}
.nl.on{color:var(--K);font-weight:500}
.nl.on::after{
  content:'';position:absolute;bottom:0;
  left:12px;right:12px;height:2px;
  background:var(--K);border-radius:2px 2px 0 0;
}
.nav-cta{
  font-family:var(--DM);font-size:12px;font-weight:600;
  background:var(--K);color:var(--W);
  padding:7px 16px;border-radius:var(--R4);
  margin:0 4px;transition:all .15s;
  white-space:nowrap;flex-shrink:0;letter-spacing:.01em;
}
.nav-cta:hover{background:var(--K);transform:translateY(-1px);box-shadow:var(--sh-sm)}
.nav-cta:last-of-type{background:transparent;color:var(--K);border:1.5px solid var(--G2)}
.nav-cta:last-of-type:hover{background:var(--G1);transform:translateY(-1px)}
.nav-tools{display:flex;align-items:center;gap:0;border-left:1px solid var(--G2);padding-left:12px;margin-left:8px;flex-shrink:0}
.ni{
  width:34px;height:34px;border-radius:var(--R8);
  display:flex;align-items:center;justify-content:center;
  color:var(--G4);transition:all .15s;
}
.ni:hover{background:var(--G1);color:var(--K)}
.ni svg{width:17px;height:17px;stroke-width:1.75}

/* ════════════════════════════════════════
   TICKER — live breaking strip
════════════════════════════════════════ */
.ticker{
  background:var(--K);height:30px;
  display:flex;align-items:center;overflow:hidden;
}
.t-tag{
  background:var(--K);color:var(--W);
  font-family:var(--DM);font-size:8px;
  font-weight:800;letter-spacing:.22em;text-transform:uppercase;
  padding:0 16px;flex-shrink:0;height:30px;
  display:flex;align-items:center;gap:6px;
  position:relative;
}
.t-tag::after{
  content:'';position:absolute;right:-8px;top:0;bottom:0;
  width:0;border-top:15px solid transparent;border-bottom:15px solid transparent;
  border-left:8px solid var(--K);
}
.t-live-dot{width:5px;height:5px;border-radius:50%;background:var(--W);animation:pulse 1.4s ease-in-out infinite}
.t-mask{overflow:hidden;flex:1;padding-left:16px}
.t-roll{display:flex;animation:scrollX 55s linear infinite;white-space:nowrap}
.t-item{font-family:var(--DM);font-size:11.5px;color:rgba(255,255,255,.55);padding:0 56px 0 0;font-weight:300;letter-spacing:.01em}
.t-item::before{content:'◆';margin-right:16px;color:rgba(255,255,255,.15);font-size:7px;vertical-align:middle}
@keyframes scrollX{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ════════════════════════════════════════
   MOBILE HEADER
════════════════════════════════════════ */
.mob-hd{
  display:none;position:sticky;top:0;z-index:600;
  height:var(--MOB);
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(28px) saturate(200%);
  -webkit-backdrop-filter:blur(28px) saturate(200%);
  border-bottom:1px solid var(--G2);
  padding:0 16px;align-items:center;justify-content:space-between;
}
.mob-hd::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:3px;background:var(--K);
}
.mob-mark{font-family:var(--BG);font-size:22px;font-weight:800;letter-spacing:-.06em;display:flex;align-items:center;gap:2px}
.mob-mark-dot{width:6px;height:6px;border-radius:50%;background:var(--K);margin-bottom:1px}
.mob-right{display:flex;gap:2px}

/* ════════════════════════════════════════
   APP SHELL
════════════════════════════════════════ */
.app{min-height:100vh;padding-top:calc(var(--NAV) + 30px)} /* nav 56 + ticker 30 */
.pg{display:none}
.pg.on{display:block;animation:pageIn .28s var(--ease) both}
@keyframes pageIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ════════════════════════════════════════
   HOME — HERO
════════════════════════════════════════ */
.home-wrap{max-width:var(--MAX);margin:0 auto;padding:0 28px 80px}

/* TOP STORY */
.top-story{
  display:grid;
  grid-template-columns:1fr 440px;
  border-bottom:1px solid var(--G2);
  padding:44px 0 44px;
  gap:52px;
  align-items:center;
  cursor:pointer;
}
.top-story:hover .ts-hl{opacity:.72}
.ts-eyebrow{
  display:flex;align-items:center;gap:12px;
  margin-bottom:22px;
}
.ts-live{
  display:flex;align-items:center;gap:6px;
  font-family:var(--DM);font-size:9.5px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--W);background:var(--K);
  padding:4px 10px 4px 8px;border-radius:3px;
}
.ts-live-dot{
  width:6px;height:6px;border-radius:50%;background:var(--W);
  animation:pulse 1.4s ease-in-out infinite;flex-shrink:0;
}
.ts-cat{
  font-family:var(--DM);font-size:10px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--G4);
}
.ts-hl{
  font-family:var(--BG);
  font-size:clamp(34px,5vw,70px);
  font-weight:700;line-height:1.03;
  letter-spacing:-.035em;color:var(--K);
  margin-bottom:22px;
  transition:opacity .25s;
}
.ts-desc{
  font-family:var(--DM);font-size:16px;font-weight:300;
  color:var(--G5);line-height:1.7;
  max-width:560px;margin-bottom:24px;
}
.ts-meta{
  display:flex;align-items:center;gap:16px;
  font-family:var(--DM);font-size:12px;color:var(--G4);
}
.ts-meta-dot{color:var(--G3)}
.ts-read-more{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--DM);font-size:12.5px;font-weight:600;
  color:var(--K);transition:gap .2s;
}
.top-story:hover .ts-read-more{gap:10px}
.ts-read-more svg{width:13px;height:13px;stroke-width:2.5}
.ts-img{
  width:100%;aspect-ratio:4/3;
  overflow:hidden;position:relative;
  flex-shrink:0;border-radius:16px;
  box-shadow:var(--sh-md);
}
.ts-img-inner{width:100%;height:100%;transition:transform .6s var(--ease)}
.top-story:hover .ts-img-inner{transform:scale(1.03)}
.ts-img-grad{
  position:absolute;inset:0;
  background:linear-gradient(140deg,rgba(0,0,0,.06) 0%,transparent 50%);
  border-radius:16px;pointer-events:none;
}

/* SUB-HERO ROW */
.sub-hero{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border-bottom:1px solid var(--G2);
}
.sh-item{
  padding:26px 22px;
  border-right:1px solid var(--G2);
  cursor:pointer;transition:background .2s;
}
.sh-item:last-child{border-right:none}
.sh-item:hover{background:var(--G1)}
.sh-item:hover .sh-hl{opacity:.65}
.sh-img{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#d4d4d4 0%,#9a9a9a 100%);margin-bottom:14px;border-radius:var(--R8);overflow:hidden;transition:transform .4s var(--ease)}
.sh-item:hover .sh-img{transform:scale(1.01)}
.sh-cat{font-family:var(--DM);font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--K);margin-bottom:8px}
.sh-hl{font-family:var(--BG);font-size:18px;font-weight:600;line-height:1.25;letter-spacing:-.025em;color:var(--K);margin-bottom:8px;transition:opacity .2s}
.sh-meta{font-family:var(--DM);font-size:11.5px;color:var(--G4)}

/* ════════════════════════════════════════
   SECTION LABEL — accent left border
════════════════════════════════════════ */
.sec-label{
  display:flex;align-items:center;gap:0;
  padding:34px 0 20px;
  border-bottom:1px solid var(--K);
  margin-bottom:28px;
  justify-content:space-between;
}
.sec-label-left{
  display:flex;align-items:center;gap:14px;
}
.sec-label-accent{
  width:3px;height:36px;background:var(--K);border-radius:2px;flex-shrink:0;
}
.sec-label-name{
  font-family:var(--BG);font-size:13px;font-weight:800;
  letter-spacing:.05em;text-transform:uppercase;color:var(--K);
}
.sec-label-sub{font-family:var(--DM);font-size:11px;color:var(--G4);letter-spacing:.02em;margin-top:2px}
.sec-label-more{
  font-family:var(--DM);font-size:11.5px;font-weight:500;
  color:var(--G4);display:flex;align-items:center;gap:4px;
  transition:color .15s;letter-spacing:.01em;
}
.sec-label-more:hover{color:var(--K)}
.sec-label-more svg{width:12px;height:12px;stroke-width:2}
.sec{margin-bottom:60px}

/* ════════════════════════════════════════
   NEWS GRIDS
════════════════════════════════════════ */
.g4{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--G2)}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--G2)}
.g-asym{display:grid;grid-template-columns:2fr 1fr;gap:0;border-top:1px solid var(--G2)}
.g-list{border-top:1px solid var(--G2)}

/* STANDARD CARD */
.card{
  padding:20px 20px 20px 0;
  border-right:1px solid var(--G2);
  cursor:pointer;
  transition:background .2s,transform .25s var(--ease),box-shadow .25s var(--ease);
  position:relative;z-index:0;
}
.card:last-child{border-right:none}
.card:hover{background:var(--G1);transform:translateY(-2px);box-shadow:var(--sh-sm);z-index:2}
.card:hover .card-hl{opacity:.65}
.card-img{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#ebebeb 0%,#d4d4d4 100%);margin-bottom:14px;overflow:hidden;position:relative;border-radius:var(--R8)}
.card-img-inner{width:100%;height:100%;transition:transform .55s var(--ease)}
.card:hover .card-img-inner{transform:scale(1.04)}
/* img color variants */
.c0{background:linear-gradient(135deg,#e4e4e4 0%,#c0c0c0 100%)}
.c1{background:linear-gradient(135deg,#eaeaea 0%,#c8c8c8 100%)}
.c2{background:linear-gradient(135deg,#dcdcdc 0%,#b8b8b8 100%)}
.c3{background:linear-gradient(135deg,#f0f0ee 0%,#cacac8 100%)}
.c4{background:linear-gradient(135deg,#e0e0e0 0%,#b0b0b0 100%)}
.c5{background:linear-gradient(135deg,#e8e8e6 0%,#c4c4c4 100%)}
.dk0{background:linear-gradient(160deg,#3c3c3c 0%,#1a1a1a 100%)}
.dk1{background:linear-gradient(160deg,#2e2e2e 0%,#0f0f0f 100%)}
.dk2{background:linear-gradient(160deg,#444 0%,#222 100%)}
.card-cat{font-family:var(--DM);font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--K);margin-bottom:7px}
.card-hl{font-family:var(--BG);font-size:16px;font-weight:600;line-height:1.28;letter-spacing:-.02em;color:var(--K);margin-bottom:8px;transition:opacity .2s}
.card-desc{font-family:var(--DM);font-size:12.5px;color:var(--G5);line-height:1.58;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:10px;font-weight:300}
.card-foot{display:flex;justify-content:space-between;font-family:var(--DM);font-size:11px;color:var(--G4)}

.card.lg .card-hl{font-size:22px}
.card.lg .card-img{aspect-ratio:4/3}
.card.compact{padding:16px 20px 16px 0}
.card.compact .card-hl{font-size:14.5px;margin-bottom:5px}

/* LIST ITEM */
.list-item{
  display:grid;grid-template-columns:1fr auto;
  align-items:start;gap:20px;
  padding:18px 0;border-bottom:1px solid var(--G2);
  cursor:pointer;transition:background .2s;
}
.list-item:last-child{border-bottom:none}
.list-item:hover{background:var(--G1);padding-left:6px}
.list-item:hover .li-hl{opacity:.65}
.li-cat{font-family:var(--DM);font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--K);margin-bottom:5px}
.li-hl{font-family:var(--BG);font-size:16.5px;font-weight:600;line-height:1.28;letter-spacing:-.02em;transition:opacity .2s;margin-bottom:6px}
.li-meta{font-family:var(--DM);font-size:11px;color:var(--G4)}
.li-img{width:96px;height:68px;flex-shrink:0;border-radius:var(--R8)}

/* ════════════════════════════════════════
   OPINION — italic pull-quote
════════════════════════════════════════ */
.op-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--G2)}
.op-card{
  padding:28px 28px 28px 0;
  border-right:1px solid var(--G2);
  cursor:pointer;transition:background .2s;
}
.op-card:nth-child(even){border-right:none;padding-left:28px;padding-right:0}
.op-card:hover{background:var(--G1)}
.op-rule{width:28px;height:2px;background:var(--K);margin-bottom:18px;border-radius:2px}
.op-q{
  font-family:var(--BG);font-size:18px;font-weight:500;
  font-style:italic;line-height:1.5;letter-spacing:-.015em;
  color:var(--K);margin-bottom:18px;
}
.op-author{display:flex;align-items:center;gap:10px;padding-top:16px;border-top:1px solid var(--G2)}
.op-av{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0}
.op-av-img{width:100%;height:100%}
.op-nm{font-family:var(--DM);font-size:13px;font-weight:600;color:var(--K)}
.op-role{font-family:var(--DM);font-size:11px;color:var(--G4);margin-top:2px}

/* ════════════════════════════════════════
   FINANZAS
════════════════════════════════════════ */
.fin-feat{
  display:grid;grid-template-columns:1fr 360px;
  border-top:1px solid var(--G2);border-bottom:1px solid var(--G2);
  cursor:pointer;transition:background .2s;min-height:200px;
}
.fin-feat:hover{background:var(--G1)}
.fin-feat:hover .fin-feat-hl{opacity:.7}
.fin-feat-body{padding:28px 24px 28px 0;display:flex;flex-direction:column;justify-content:center}
.fin-feat-cat{font-family:var(--DM);font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--K);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.fin-feat-cat-dot{width:5px;height:5px;border-radius:50%;background:var(--K)}
.fin-feat-hl{font-family:var(--BG);font-size:clamp(20px,2.4vw,32px);font-weight:700;line-height:1.15;letter-spacing:-.03em;color:var(--K);margin-bottom:12px;transition:opacity .2s}
.fin-feat-desc{font-family:var(--DM);font-size:13.5px;color:var(--G5);line-height:1.6;font-weight:300;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.fin-feat-meta{font-family:var(--DM);font-size:11px;color:var(--G4)}
.fin-feat-img{background:linear-gradient(140deg,#2a2a2a 0%,#0a0a0a 100%)}
.fin-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--G2)}
.fin-card{padding:20px 18px 20px 0;border-right:1px solid var(--G2);cursor:pointer;transition:background .2s}
.fin-card:last-child{border-right:none}
.fin-card:hover{background:var(--G1)}
.fin-card:hover .fin-card-hl{opacity:.65}
.fin-card-img{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#ebebeb,#d4d4d4);margin-bottom:14px;border-radius:var(--R8);overflow:hidden}
.fin-card-cat{font-family:var(--DM);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--K);margin-bottom:6px}
.fin-card-hl{font-family:var(--BG);font-size:16px;font-weight:600;line-height:1.28;letter-spacing:-.02em;color:var(--K);margin-bottom:8px;transition:opacity .2s}
.fin-card-meta{font-family:var(--DM);font-size:11px;color:var(--G4)}

/* ════════════════════════════════════════
   TENDENCIA — ranked viral list
════════════════════════════════════════ */
.tend-grid{display:grid;grid-template-columns:repeat(2,1fr);border-top:1px solid var(--G2)}
.tend-item{
  display:flex;gap:14px;align-items:flex-start;
  padding:20px 20px 20px 0;
  border-right:1px solid var(--G2);border-bottom:1px solid var(--G2);
  cursor:pointer;transition:background .2s;position:relative;
}
.tend-item:nth-child(even){border-right:none;padding-left:20px;padding-right:0}
.tend-item:nth-last-child(-n+2){border-bottom:none}
.tend-item:hover{background:var(--G1)}
.tend-item:hover .tend-hl{opacity:.65}
.tend-num{
  font-family:var(--BG);font-size:52px;font-weight:800;
  letter-spacing:-.06em;line-height:1;color:var(--G2);
  flex-shrink:0;width:52px;text-align:right;
  transition:color .2s;user-select:none;
}
/* First item gets accent number */
.tend-item:first-child .tend-num{color:var(--G1);color:var(--G2)}
.tend-item:hover .tend-num{color:var(--G3)}
.tend-body{flex:1;min-width:0;padding-top:8px}
.tend-cat{font-family:var(--DM);font-size:8.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--K);margin-bottom:6px;display:flex;align-items:center;gap:6px}

.tend-hl{font-family:var(--BG);font-size:16px;font-weight:600;line-height:1.3;letter-spacing:-.02em;color:var(--K);margin-bottom:8px;transition:opacity .2s}
.tend-stats{display:flex;gap:12px;font-family:var(--DM);font-size:10.5px;color:var(--G4)}
.tend-stat{display:flex;align-items:center;gap:3px}
.tend-stat svg{width:11px;height:11px;stroke-width:1.75}
@media(max-width:768px){
  /* ══ NAV ══ */
  .nav,.ticker{display:none}
  .mob-hd{display:flex;height:52px;padding:0 16px}
  .mob-nav{display:block}
  .mob-mark{font-size:20px}

  /* ══ QUICK CATS ══ */
  .mob-quick-cats{display:flex;position:sticky;top:52px;z-index:599}

  /* ══ APP OFFSET ══ */
  .app{padding-top:calc(var(--MOB) + 42px)}
  #pg-article.on{padding-top:calc(var(--MOB) + 8px)}
  .home-wrap{padding:0 0 100px;overflow-x:hidden}

  /* ══ HERO / TOP STORY ══ */
  .hero-carousel{min-height:auto}
  .top-story{
    grid-template-columns:1fr;gap:0;
    padding:16px 16px 20px;
    border-bottom:1px solid var(--G2);
  }
  .ts-img{order:-1;width:100%;aspect-ratio:16/9;border-radius:10px;margin-bottom:14px;overflow:hidden;flex-shrink:0}
  .ts-hl{font-size:22px;line-height:1.1;margin-bottom:10px}
  .ts-desc{font-size:13.5px;margin-bottom:14px;-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
  .ts-meta{font-size:11px;gap:8px}
  .ts-live{font-size:8px;padding:3px 7px}
  .ts-eyebrow{margin-bottom:10px}
  .ts-cta{font-size:11px;padding:8px 14px}

  /* ══ SUB-HERO ══ */
  .sub-hero{
    display:flex;overflow-x:auto;gap:0;
    scrollbar-width:none;border-bottom:1px solid var(--G2);
    -webkit-overflow-scrolling:touch;
  }
  .sub-hero::-webkit-scrollbar{display:none}
  .sh-item{
    flex-shrink:0;width:170px;
    padding:12px 13px;
    border-right:1px solid var(--G2);
    border-bottom:none !important;
    overflow:hidden;
  }
  .sh-item:last-child{display:flex}
  .sh-img{width:100%;height:90px;aspect-ratio:unset;border-radius:8px;margin-bottom:8px;overflow:hidden}
  .sh-hl{
    font-size:12.5px;line-height:1.35;
    overflow:hidden;
    display:-webkit-box;
    -webkit-line-clamp:3;
    -webkit-box-orient:vertical;
    word-break:break-word;
  }
  .sh-cat{font-size:8px;letter-spacing:.1em}
  .sh-time{display:none}

  /* ══ SECTION LABELS ══ */
  .sec-label{padding:20px 16px 12px;margin-bottom:0}
  .sec{margin-bottom:0}
  .sec-label-name{font-size:12px}
  .sec-label-sub{font-size:10px}
  .sec-label-more{font-size:11px;padding:5px 10px}

  /* ══ CARDS ══ */
  .g3,.g4{grid-template-columns:1fr;border-top:none;display:flex;flex-direction:column}
  .card{
    display:flex;flex-direction:row;gap:12px;
    align-items:flex-start;
    padding:12px 16px;
    border-right:none;
    border-bottom:1px solid var(--G2);
    transform:none !important;box-shadow:none !important;
    cursor:pointer;
  }
  .card:last-child{border-bottom:none}
  .card-img{width:84px;height:62px;aspect-ratio:unset;margin-bottom:0;flex-shrink:0;border-radius:8px;overflow:hidden}
  .card-body-col{flex:1;min-width:0}
  .card-cat{margin-bottom:3px;font-size:8px;letter-spacing:.12em}
  .card-hl{
    font-size:13px;margin-bottom:0;line-height:1.35;
    overflow:hidden;display:-webkit-box;
    -webkit-line-clamp:3;-webkit-box-orient:vertical;
  }
  .card-desc{display:none}
  .card-foot{padding-top:4px;font-size:10px;color:var(--G4)}

  /* ══ TENDENCIA 2-col ══ */
  .g4.tendencia-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;flex-direction:unset}
  .g4.tendencia-grid .card{flex-direction:column;padding:12px;border-right:1px solid var(--G2);border-bottom:1px solid var(--G2);transform:none !important;box-shadow:none !important}
  .g4.tendencia-grid .card:nth-child(even){border-right:none}
  .g4.tendencia-grid .card:nth-last-child(-n+2){border-bottom:none}
  .g4.tendencia-grid .card-img{width:100%;height:auto;aspect-ratio:1/1;margin-bottom:8px;border-radius:8px}
  .g4.tendencia-grid .card-hl{font-size:12px}
  .g4.tendencia-grid .card-body-col{display:contents}

  /* ══ ASYM GRID ══ */
  .g-asym{grid-template-columns:1fr;border-top:none}
  .g-asym > div:last-child{border-left:none;border-top:1px solid var(--G2)}
  .card.lg{flex-direction:column;padding:14px 16px}
  .card.lg .card-img{width:100%;height:auto;aspect-ratio:16/9;margin-bottom:12px;border-radius:10px}
  .card.compact{flex-direction:row;padding:12px 16px;border-bottom:1px solid var(--G2) !important;border-right:none !important}
  .card.compact .card-img{display:none}

  /* ══ OPINION ══ */
  .op-grid{grid-template-columns:1fr;border-top:none}
  .op-card{padding:16px;border-right:none;border-top:1px solid var(--G2)}
  .op-card:first-child{border-top:none}
  .op-card:nth-child(even){padding-left:16px;border-left:none}
  .op-q{font-size:15px}

  /* ══ LIST ITEMS ══ */
  .g-list{border-top:none}
  .list-item{padding:12px 16px}
  .li-img{width:72px;height:54px;border-radius:8px}

  /* ══ FINANZAS ══ */
  .fin-feat{grid-template-columns:1fr;border-top:none}
  .fin-feat-body{padding:16px}
  .fin-feat-img{height:150px}
  .fin-grid{grid-template-columns:1fr;border-top:none}
  .fin-card{padding:12px 16px;border-right:none;border-bottom:1px solid var(--G2)}
  .fin-card:last-child{border-bottom:none}
  .fin-card-img{display:none}

  /* ══ PEOPLE ══ */
  .pv-grid{margin:0 -16px}

  /* ══ HOME SECTION DIVIDERS ══ */
  .home-section-divider{padding:22px 16px 0}
  .hsd-title{font-size:18px}
  .hsd-more{padding:6px 12px;font-size:11px}

  /* ══ HOME PREDICCIONES ══ */
  .home-preds-gauge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:16px 0}
  .hp-card{padding:12px}

  /* ══ HOME XPRESS FEED ══ */
  .hx-feed{padding:0 16px}

  /* ══ VIDEOS ══ */
  .vf-feed{height:calc(100vh - var(--MOB) - 62px)}
  .vf-item{height:calc(100vh - var(--MOB) - 62px)}
  .vf-content{padding:0 70px 28px 20px}
  .vf-hl{font-size:22px}

  /* ══ ASK LUNA ══ */
  .ask-shell{height:calc(100vh - var(--MOB) - 62px);border:none}
  .ask-msgs{padding:12px 16px}
  .ask-top{padding:12px 16px}
  .ask-chips-row{padding:0 16px 10px}
  .ask-input-bar{padding:10px 14px 14px}
  .ask-welcome-mark{font-size:36px}
  .ask-welcome-title{font-size:17px}
  .ask-welcome-sub{font-size:13px}
  #ask-suggest-list{padding:0 16px 16px}
  .ask-suggest-item{padding:10px 14px;gap:10px}

  /* ══ XPRESS ══ */
  .xp-wrap{border:none}
  .xp-hdr{top:var(--MOB)}
  .xp-compose,.xp-post{padding:12px 16px}
  .xp-title{font-size:20px}
  .xp-compose-in{padding:10px 14px}

  /* ══ PREDICCIONES ══ */
  .pred-outer{padding:12px 16px 100px}
  .pred-pg-top{flex-direction:column;align-items:flex-start;gap:12px;padding-bottom:14px}
  .pred-pg-title{font-size:24px}
  .pred-new-btn{width:100%;justify-content:center}
  .pred-featured-inner{grid-template-columns:1fr}
  .pred-featured-chart{display:none}
  .pred-featured-left{border-right:none;border-bottom:1px solid var(--G2)}
  .pred-grid{grid-template-columns:1fr 1fr;gap:10px}
  .pred-card{padding:12px 12px 10px}
  .pred-q{font-size:12px;-webkit-line-clamp:3}
  .pred-gauge-si-pct{font-size:17px}
  .pred-vote-si,.pred-vote-no{font-size:11px;padding:7px 4px}
  .pred-filters{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;-webkit-overflow-scrolling:touch}
  .pred-filters::-webkit-scrollbar{display:none}
  .pred-f{white-space:nowrap;flex-shrink:0;font-size:12px;padding:6px 12px}

  /* ══ MAS NOTICIAS ══ */
  .mas-grid{grid-template-columns:1fr 1fr !important;gap:0 !important}
  .mas-card{padding:10px 12px;border-bottom:1px solid var(--G2)}
  .mas-img{aspect-ratio:16/9;border-radius:6px;margin-bottom:8px}
  .mas-hl{font-size:12.5px}
  .mas-meta{font-size:10px}

  /* ══ MODALS ══ */
  .modal-box{border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;max-width:100%;max-height:88vh;display:flex;flex-direction:column}
  .modal-layer{align-items:flex-end;padding:0}
  .modal-body{padding:16px 18px}
  .modal-head{padding:16px 18px}
  .pred-detail-box{border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;max-width:100%;max-height:90vh}
  .pred-detail-layer{align-items:flex-end;padding:0}

  /* ══ MOBILE NAV BOTTOM ══ */
  .mob-nav{height:62px;padding-bottom:env(safe-area-inset-bottom,0px)}
  .mob-nav-in{height:62px}
  a.mob-tab,button.mob-tab{gap:3px;font-size:8.5px;letter-spacing:.02em}
  a.mob-tab svg,button.mob-tab svg{width:22px;height:22px;stroke-width:1.75}
  a.mob-tab-xp,button.mob-tab-xp{font-size:8.5px}
  .mob-tab-xp-ico{width:44px;height:44px;border-radius:14px;margin-top:-14px}
  .mob-tab-xp-ico svg{width:22px;height:22px}
  a.mob-tab,a.mob-tab:visited{text-decoration:none;color:#BEBEBE}
  a.mob-tab.on,a.mob-tab:hover{color:var(--K)}
  a.mob-tab-xp,a.mob-tab-xp:visited{text-decoration:none}

  /* ══ ARTICLE TEMPLATES MOBILE ══ */
  .tA-cover{height:220px}
  .tA-article{grid-template-columns:1fr;gap:0;padding:0 16px 40px}
  .tA-hl{font-size:26px}
  .tA-right{border-left:none;padding-left:0;border-top:1px solid var(--G2);margin-top:20px;padding-top:20px}
  .tB-heading{padding:24px 16px 20px}
  .tB-hl{font-size:26px}
  .tB-photo{height:220px}
  .tB-body{padding:0 16px 40px}
  .tC-hl{font-size:36px}
  .tC-cover{height:100svh}

  /* ══ FOOTER on mobile ══ */
  .site-footer{margin-top:40px;padding-bottom:62px}
  .sf-inner{padding:40px 20px 32px}
  .sf-top{flex-direction:column;gap:24px}
  .sf-links{grid-template-columns:1fr 1fr;gap:20px 16px}
  .sf-col-title{font-size:9px}
  .sf-link{font-size:12px}
  .sf-wordmark{font-size:36px}
}

@media(max-width:480px){.mas-feed{grid-template-columns:1fr}.mas-card.wide,.mas-card.tall{grid-column:span 1;grid-row:span 1}}

@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.7)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */
@media(max-width:1280px){
  .pred-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:1100px){
  .g4{grid-template-columns:repeat(2,1fr)}
  .top-story{grid-template-columns:1fr 360px;gap:36px}
  .pred-grid{grid-template-columns:repeat(3,1fr)}
  .pred-featured-inner{grid-template-columns:320px 1fr}
}
@media(max-width:860px){
  .top-story{grid-template-columns:1fr;gap:24px}
  .ts-img{aspect-ratio:16/9;width:100%}
  .sub-hero{grid-template-columns:1fr 1fr}
  .sh-item:last-child{display:none}
  .g-asym{grid-template-columns:1fr}
  .pred-grid{grid-template-columns:repeat(2,1fr)}
  .pred-card{padding:14px 14px 11px}
  .pred-featured-inner{grid-template-columns:1fr}
  .pred-featured-chart{border-top:1px solid var(--G2);min-height:220px}
  .op-grid{grid-template-columns:1fr}
  .op-card:nth-child(even){border-right:none;padding-left:0;border-top:1px solid var(--G2)}
}
@media(max-width:768px){
  /* ── Kill desktop nav, show mobile ── */
  .nav,.ticker,.mob-cats{display:none}
  .mob-hd{display:flex}
  .mob-nav{display:block}
  .home-wrap{padding:0 0 80px;overflow-x:hidden}
  .home-wrap > *:first-child{scroll-margin-top:calc(var(--MOB) + 42px)}
  .app{padding-top:var(--MOB)} /* just mob-hd height on mobile */

  /* ── Mobile header — taller, better layout ── */
  .mob-hd{
    height:52px;
    padding:0 16px;
  }
  .mob-mark{font-size:20px}

  /* ── TOP STORY mobile ── */
  .top-story{
    grid-template-columns:1fr;gap:0;
    padding:20px 16px 24px;
    border-bottom:1px solid var(--G2);
  }
  .hero-carousel{min-height:auto}
  .ts-img{order:-1;width:100%;aspect-ratio:16/9;border-radius:12px;margin-bottom:18px;overflow:hidden}
  .ts-hl{font-size:24px;line-height:1.08;margin-bottom:12px}
  .ts-desc{font-size:14px;margin-bottom:16px}
  .ts-live{font-size:8.5px;padding:3px 8px}

  /* ── Sub-hero horizontal scroll ── */
  .sub-hero{
    display:flex;overflow-x:auto;gap:0;
    scrollbar-width:none;border-bottom:1px solid var(--G2);
  }
  .sub-hero::-webkit-scrollbar{display:none}
  .sh-item{flex-shrink:0;width:200px;padding:14px 13px;border-right:1px solid var(--G2);border-bottom:none !important}
  .sh-item:last-child{display:flex}
  .sh-img{width:100%;height:100px;aspect-ratio:unset;border-radius:var(--R8);margin-bottom:10px}
  .sh-hl{font-size:13px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
  .sh-cat{font-size:8.5px}

  /* ── Section labels ── */
  .sec-label{padding:22px 16px 13px;margin-bottom:0}
  .sec{margin-bottom:0}
  .sec-label-name{font-size:12px}
  .sec-label-sub{font-size:10px}

  /* ── Cards → horizontal list ── */
  .g3,.g4{
    grid-template-columns:1fr;border-top:none;
    display:flex;flex-direction:column;
  }
  .card{
    display:flex;flex-direction:row;gap:12px;
    align-items:flex-start;
    padding:13px 16px;border-right:none;
    border-bottom:1px solid var(--G2);
    transform:none !important;box-shadow:none !important;
  }
  .card:last-child{border-bottom:none}
  .card-img{width:88px;height:66px;aspect-ratio:unset;margin-bottom:0;flex-shrink:0;border-radius:var(--R8)}
  .card-body-col{flex:1;min-width:0}
  .card-cat{margin-bottom:4px;font-size:8.5px}
  .card-hl{font-size:13.5px;margin-bottom:4px}
  .card-desc{display:none}
  .card-foot{padding-top:5px;font-size:10px}

  /* ── Tendencia 2-col on mobile ── */
  .g4.tendencia-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:0;flex-direction:unset;
  }
  .g4.tendencia-grid .card{
    flex-direction:column;padding:12px;
    border-right:1px solid var(--G2);border-bottom:1px solid var(--G2);
    transform:none !important;box-shadow:none !important;
  }
  .g4.tendencia-grid .card:nth-child(even){border-right:none}
  .g4.tendencia-grid .card:nth-last-child(-n+2){border-bottom:none}
  .g4.tendencia-grid .card-img{width:100%;height:auto;aspect-ratio:1/1;margin-bottom:8px}
  .g4.tendencia-grid .card-hl{font-size:12px}
  .g4.tendencia-grid .card-body-col{display:contents}

  /* ── Asym grid ── */
  .g-asym{grid-template-columns:1fr;border-top:none}
  .g-asym > div:last-child{border-left:none;border-top:1px solid var(--G2)}
  .card.lg{flex-direction:column;padding:14px 16px}
  .card.lg .card-img{width:100%;height:auto;aspect-ratio:16/9;margin-bottom:12px;border-radius:10px}
  .card.compact{flex-direction:row;padding:13px 16px;border-bottom:1px solid var(--G2) !important;border-right:none !important}
  .card.compact .card-img{display:none}

  /* ── Opinion ── */
  .op-grid{grid-template-columns:1fr;border-top:none}
  .op-card{padding:16px 16px;border-right:none;border-top:1px solid var(--G2)}
  .op-card:first-child{border-top:none}
  .op-card:nth-child(even){padding-left:16px;border-left:none;border-top:1px solid var(--G2)}
  .op-q{font-size:15px}

  /* ── List items ── */
  .g-list{border-top:none}
  .list-item{padding:13px 16px}
  .li-img{width:75px;height:55px;border-radius:var(--R8)}

  /* ── Finanzas ── */
  .fin-feat{grid-template-columns:1fr;border-top:none}
  .fin-feat-body{padding:16px 16px}
  .fin-feat-img{height:150px}
  .fin-grid{grid-template-columns:1fr;border-top:none}
  .fin-card{padding:13px 16px;border-right:none;border-bottom:1px solid var(--G2)}
  .fin-card:last-child{border-bottom:none}
  .fin-card-img{display:none}

  /* ── People ── */
  .pv-grid{margin:0 -16px}

  /* ── Home sections ── */
  .home-section-divider{padding:24px 16px 0}
  .hsd-title{font-size:18px}
  .hsd-more{padding:7px 12px;font-size:11px}

  /* ── Videos ── */
  .vf-feed{height:calc(100vh - var(--MOB) - var(--BOTNAV))}
  .vf-item{height:calc(100vh - var(--MOB) - var(--BOTNAV))}
  .vf-content{padding:0 70px 28px 20px}
  .vf-hl{font-size:22px}

  /* ── Ask Luna ── */
  .ask-shell{height:calc(100vh - var(--MOB) - var(--BOTNAV));border:none}
  .ask-msgs{padding:14px 16px}
  .ask-top{padding:13px 16px}
  .ask-chips-row{padding:0 16px 10px}
  .ask-input-bar{padding:10px 14px 14px}
  .ask-welcome-mark{font-size:40px}
  .ask-welcome-title{font-size:18px}

  /* ── Xpress ── */
  .xp-wrap{border:none}
  .xp-hdr{top:var(--MOB)}
  .xp-compose,.xp-post{padding:13px 16px}
  .xp-title{font-size:22px}

  /* ── Predicciones mobile ── */
  .pred-outer{padding:16px 16px 80px}
  .pred-pg-top{flex-direction:column;align-items:flex-start;gap:12px;padding-bottom:16px}
  .pred-pg-title{font-size:26px}
  .pred-new-btn{width:100%;justify-content:center}
  .pred-featured-inner{grid-template-columns:1fr}
  .pred-featured-chart{display:none} /* hide chart on mobile in featured card */
  .pred-featured-left{border-right:none;border-bottom:1px solid var(--G2)}
  .pred-grid{grid-template-columns:1fr 1fr;gap:10px}
  .pred-card{padding:13px 13px 11px}
  .pred-q{font-size:12.5px;-webkit-line-clamp:3}
  .pred-gauge-num{font-size:13px}
  .pred-gauge-si-pct{font-size:18px}
  .pred-vote-si,.pred-vote-no{font-size:11px;padding:8px 4px}
  .pred-filters{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
  .pred-filters::-webkit-scrollbar{display:none}
  .pred-f{white-space:nowrap;flex-shrink:0;font-size:12px;padding:6px 13px}

  /* ── Modals ── */
  .modal-box{border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;max-width:100%;max-height:88vh;display:flex;flex-direction:column}
  .modal-layer{align-items:flex-end;padding:0}
  .pred-detail-box{border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;max-width:100%;max-height:90vh}
  .pred-detail-layer{align-items:flex-end;padding:0}

  /* ── Mobile nav bottom ── */
  .mob-nav{height:62px}
  .mob-nav-in{height:62px}
  .mob-tab{gap:3px;font-size:8.5px;letter-spacing:.02em}
  .mob-tab svg{width:22px;height:22px}
  .mob-tab-xp{font-size:8.5px}
  .mob-tab-xp-ico{width:42px;height:42px;border-radius:14px;margin-top:-10px}
  .mob-tab-xp-ico svg{width:21px;height:21px}
}
@media(max-width:480px){
  .ts-hl{font-size:20px}
  .sh-item{width:155px}
  .sh-hl{font-size:12px}
  .pred-grid{grid-template-columns:1fr}
  .card-hl{font-size:12.5px}
  .home-preds-gauge-grid{grid-template-columns:1fr}
  .mas-grid{grid-template-columns:1fr !important}
}
/* ════════════════════════════════════════
   FOOTER
════════════════════════════════════════ */
.site-footer{
  background:var(--K);color:var(--W);
  margin-top:80px;
  /* hide on non-home pages */
}
.sf-inner{
  max-width:var(--MAX);margin:0 auto;
  padding:64px 28px 32px;
}

/* Top row */
.sf-top{
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;margin-bottom:52px;
  align-items:start;
}
.sf-wordmark{
  font-family:var(--BG);font-size:36px;font-weight:800;
  letter-spacing:-.06em;line-height:1;
  display:flex;align-items:center;gap:4px;
  margin-bottom:16px;
}
.sf-dot{
  display:inline-block;width:8px;height:8px;
  border-radius:50%;background:var(--W);
  margin-bottom:2px;flex-shrink:0;
}
.sf-tagline{
  font-family:var(--DM);font-size:14px;font-weight:300;
  color:rgba(255,255,255,.45);line-height:1.65;
  margin-bottom:24px;
}
.sf-social{display:flex;gap:4px;flex-wrap:wrap}
.sf-soc{
  width:38px;height:38px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.45);
  transition:all .2s;border-radius:var(--R4);
}
.sf-soc:hover{background:rgba(255,255,255,.08);color:var(--W);border-color:rgba(255,255,255,.25)}
.sf-soc svg{width:15px;height:15px}

/* Newsletter */
.sf-nl-label{
  font-family:var(--DM);font-size:9.5px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.3);margin-bottom:10px;
}
.sf-nl-title{
  font-family:var(--BG);font-size:22px;font-weight:700;
  letter-spacing:-.03em;line-height:1.25;
  color:var(--W);margin-bottom:20px;
}
.sf-nl-form{
  display:flex;gap:0;
  border:1px solid rgba(255,255,255,.15);
  overflow:hidden;
  margin-bottom:10px;
}
.sf-nl-inp{
  flex:1;padding:12px 16px;
  border:none;outline:none;background:rgba(255,255,255,.06);
  font-family:var(--DM);font-size:13px;
  color:var(--W);
}
.sf-nl-inp::placeholder{color:rgba(255,255,255,.25)}
.sf-nl-inp:focus{background:rgba(255,255,255,.1)}
.sf-nl-btn{
  padding:12px 22px;background:var(--W);color:var(--K);
  font-family:var(--DM);font-size:13px;font-weight:700;
  letter-spacing:.01em;cursor:pointer;
  transition:opacity .15s;white-space:nowrap;
  border:none;
}
.sf-nl-btn:hover{opacity:.85}
.sf-nl-sub{
  font-family:var(--DM);font-size:11px;
  color:rgba(255,255,255,.22);
}

/* Divider */
.sf-divider{
  height:1px;background:rgba(255,255,255,.08);
  margin-bottom:44px;
}

/* Links grid */
.sf-links{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:32px;margin-bottom:52px;
}
.sf-col-title{
  font-family:var(--DM);font-size:9px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.28);margin-bottom:16px;
}
.sf-link{
  display:block;font-family:var(--DM);font-size:13px;
  font-weight:300;color:rgba(255,255,255,.5);
  margin-bottom:10px;transition:color .15s;
  line-height:1;
}
.sf-link:hover{color:var(--W)}

/* Bottom bar */
.sf-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.08);
  flex-wrap:wrap;gap:12px;
}
.sf-copy{
  font-family:var(--DM);font-size:12px;
  color:rgba(255,255,255,.22);font-weight:300;
}

/* Footer responsive */
@media(max-width:900px){
  .sf-top{grid-template-columns:1fr;gap:40px}
  .sf-links{grid-template-columns:repeat(2,1fr);gap:24px}
}
@media(max-width:600px){
  .sf-inner{padding:48px 20px 32px}
  .sf-links{grid-template-columns:1fr 1fr;gap:20px}
  .sf-bottom{flex-direction:column;align-items:flex-start}
}
@media(max-width:768px){
  .site-footer{margin-top:0;margin-bottom:58px}
}

/* ── MOBILE QUICK CATEGORIES ── */
.mob-quick-cats{
  display:none;
  background:var(--W);
  border-bottom:1px solid var(--G2);
  padding:8px 14px;
  gap:8px;
  overflow-x:auto;
  scrollbar-width:none;
  position:sticky;
  top:var(--MOB);
  z-index:599;
}
.mob-quick-cats::-webkit-scrollbar{display:none}
.mqc-btn{
  white-space:nowrap;flex-shrink:0;
  font-family:var(--DM);font-size:12.5px;font-weight:500;
  color:var(--G5);padding:5px 14px;
  border:1.5px solid var(--G2);border-radius:980px;
  background:var(--W);cursor:pointer;transition:all .15s;
}
.mqc-btn.on,.mqc-btn:hover{background:var(--K);color:var(--W);border-color:var(--K)}
@media(max-width:768px){
  .mob-quick-cats{display:flex}
}

/* ═══════════════════════════════════════════════════
   ARTICLE READER — 3 templates
   All use: BG for headlines, DM Sans for body
═══════════════════════════════════════════════════ */
#pg-article.on{display:block;background:var(--W);min-height:100vh;padding-top:calc(var(--NAV) + 30px)}

/* Article nav override */
.art-nav-back{
  display:flex;align-items:center;gap:6px;
  font-family:var(--DM);font-size:13px;font-weight:500;color:var(--G4);cursor:pointer;transition:color .15s;
}
.art-nav-back:hover{color:var(--K)}
.art-nav-back svg{width:16px;height:16px;stroke-width:2;stroke:currentColor;fill:none}
.art-nav-cat{font-family:var(--DM);font-size:13px;font-weight:600;color:var(--G5)}
.art-nav-tools{margin-left:auto;display:flex;gap:6px}
.art-nav-tool{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s;color:var(--G5)}
.art-nav-tool:hover{background:var(--G2);color:var(--K)}
.art-nav-tool svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.75}
.art-nav-sep{color:var(--G3);font-size:11px}

/* Template switcher (only visible in dev) */
.art-tpl-bar{
  background:var(--K);display:none;justify-content:center;
}
.art-tpl-btn{
  font-family:var(--DM);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.3);padding:10px 28px;cursor:pointer;
  border-bottom:2px solid transparent;transition:all .18s;
}
.art-tpl-btn.on{color:var(--W);border-bottom-color:var(--W)}
.art-tpl-btn:hover:not(.on){color:rgba(255,255,255,.6)}

/* Template wrapper */
.art-tpl{display:none}
.art-tpl.on{display:block;animation:fadeUp .3s var(--ease)}

/* ── TEMPLATE A — BROADSHEET (foto portada, 2 cols) ── */
.tA{background:var(--W)}
.tA-cover{width:100%;height:420px;position:relative;overflow:hidden;background:#1a1a1a}
.tA-cover-img{width:100%;height:100%;background:linear-gradient(160deg,#2c2c2c,#0a0a0a);transition:transform 7s linear}
.tA-cover:hover .tA-cover-img{transform:scale(1.02)}
.tA-cover-badge{
  position:absolute;bottom:20px;left:40px;
  font-family:var(--DM);font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.65);
}
.tA-masthead{
  max-width:1080px;margin:0 auto;padding:28px 40px 0;
  border-bottom:3px double var(--K);padding-bottom:16px;
}
.tA-wordmark{font-family:var(--BG);font-size:48px;font-weight:800;letter-spacing:-.06em;color:var(--K);text-align:center;line-height:1}
.tA-wordmark span{width:7px;height:7px;border-radius:50%;background:var(--K);display:inline-block;vertical-align:super;margin-left:2px}
.tA-tagline{font-family:var(--DM);font-style:italic;font-size:12px;color:var(--G4);text-align:center;margin-top:4px}
.tA-article{max-width:1080px;margin:0 auto;padding:28px 40px 80px;display:grid;grid-template-columns:1fr 1fr;gap:0}
.tA-hl-block{grid-column:1/-1;border-bottom:2px solid var(--K);padding-bottom:18px;margin-bottom:22px}
.tA-eyebrow{font-family:var(--DM);font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--G4);margin-bottom:10px}
.tA-hl{font-family:var(--BG);font-size:clamp(28px,3.8vw,50px);font-weight:800;letter-spacing:-.04em;line-height:1.04;color:var(--K);margin-bottom:12px}
.tA-deck{font-family:var(--DM);font-style:italic;font-size:18px;line-height:1.5;color:var(--G5);max-width:800px}
.tA-left{padding-right:40px;border-right:1px solid var(--G3)}
.tA-right{padding-left:40px}
.tA-byline{display:flex;align-items:center;gap:8px;margin-bottom:22px;padding-bottom:12px;border-bottom:1px solid var(--G2)}
.tA-author{font-family:var(--DM);font-size:12px;font-weight:700;color:var(--K)}
.tA-dot{width:3px;height:3px;border-radius:50%;background:var(--G3);flex-shrink:0}
.tA-meta{font-family:var(--DM);font-size:11px;color:var(--G4)}
.tA-p{font-family:var(--DM);font-size:17px;line-height:1.78;color:var(--G6);margin-bottom:22px;font-weight:300}
.tA-p:first-of-type::first-letter{font-family:var(--BG);font-size:66px;font-weight:800;letter-spacing:-.04em;float:left;line-height:.82;margin:4px 8px 0 0;color:var(--K)}
.tA-subhead{font-family:var(--BG);font-size:21px;font-weight:700;letter-spacing:-.03em;color:var(--K);margin:28px 0 12px;border-top:1px solid var(--G2);padding-top:18px}
.tA-pullquote{margin:26px 0;padding:18px 0;border-top:3px solid var(--K);border-bottom:3px solid var(--K)}
.tA-pullquote-text{font-family:var(--DM);font-style:italic;font-size:20px;line-height:1.4;color:var(--K);font-weight:300}
.tA-pullquote-cite{font-family:var(--DM);font-size:10px;font-weight:700;color:var(--G4);letter-spacing:.12em;text-transform:uppercase;margin-top:7px}
.tA-img{width:100%;aspect-ratio:4/3;background:linear-gradient(160deg,#2c2c2c,#0a0a0a);margin-bottom:12px}
.tA-caption{font-family:var(--DM);font-style:italic;font-size:11.5px;color:var(--G4);margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--G2)}
.tA-related-lbl{font-family:var(--DM);font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--G4);margin-bottom:10px}
.tA-related-item{padding:11px 0;border-bottom:1px solid var(--G2);cursor:pointer}
.tA-related-item:last-child{border-bottom:none}
.tA-related-cat{font-family:var(--DM);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--G4);margin-bottom:4px}
.tA-related-hl{font-family:var(--BG);font-size:15px;font-weight:700;line-height:1.25;letter-spacing:-.02em;color:var(--K)}
.tA-related-meta{font-family:var(--DM);font-size:10.5px;color:var(--G4);margin-top:3px}
@media(max-width:768px){
  #pg-article.on{padding-top:calc(var(--MOB) + 4px)}
  .tA-cover{height:240px}.tA-cover-badge{left:20px}
  .tA-masthead{padding:20px 20px 0}.tA-wordmark{font-size:34px}
  .tA-article{grid-template-columns:1fr;padding:20px 20px 60px}
  .tA-left{padding-right:0;border-right:none;border-bottom:1px solid var(--G2);padding-bottom:28px;margin-bottom:28px}
  .tA-right{padding-left:0}.tA-hl-block{grid-column:1}
}

/* ── TEMPLATE B — REVISTA EDITORIAL BLANCA ── */
.tB{background:var(--W)}
.tB-topbar{background:var(--W);border-bottom:1px solid var(--G2);padding:9px 40px;display:flex;align-items:center;gap:10px}
.tB-topbar-cat{font-family:var(--DM);font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--G4)}
.tB-topbar-sep{color:var(--G3);font-size:10px}
.tB-topbar-read{margin-left:auto;display:flex;align-items:center;gap:5px;font-family:var(--DM);font-size:11px;color:var(--G4)}
.tB-topbar-read svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.75}
.tB-heading{max-width:780px;margin:0 auto;padding:52px 24px 40px;text-align:center;border-bottom:1px solid var(--G2)}
.tB-eyebrow{font-family:var(--DM);font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--G4);margin-bottom:18px}
.tB-hl{font-family:var(--BG);font-size:clamp(32px,5vw,58px);font-weight:800;letter-spacing:-.05em;line-height:.98;color:var(--K);margin-bottom:18px}
.tB-deck{font-family:var(--DM);font-size:19px;font-weight:300;line-height:1.6;color:var(--G5);max-width:580px;margin:0 auto 26px}
.tB-byline-center{display:flex;align-items:center;justify-content:center;gap:9px}
.tB-av{width:32px;height:32px;border-radius:50%;background:var(--G2);display:flex;align-items:center;justify-content:center;font-family:var(--DM);font-size:10px;font-weight:700;color:var(--G5);flex-shrink:0}
.tB-author{font-family:var(--DM);font-size:12.5px;font-weight:600;color:var(--G5)}
.tB-sep{color:var(--G3)}
.tB-date{font-family:var(--DM);font-size:12px;color:var(--G4)}
.tB-photo{width:100%;height:520px;background:linear-gradient(160deg,#2c2c2c,#0a0a0a);position:relative;overflow:hidden}
.tB-photo:hover .tB-photo-inner{transform:scale(1.02)}
.tB-photo-inner{width:100%;height:100%;transition:transform 7s linear}
.tB-photo-cap{position:absolute;bottom:0;left:0;right:0;padding:14px 40px;font-family:var(--DM);font-style:italic;font-size:11.5px;color:rgba(255,255,255,.45);background:linear-gradient(to top,rgba(0,0,0,.45),transparent)}
.tB-body{max-width:660px;margin:0 auto;padding:52px 24px 80px}
.tB-p{font-family:var(--DM);font-size:17.5px;font-weight:300;line-height:1.82;color:var(--G6);margin-bottom:24px}
.tB-p:first-of-type::first-letter{font-family:var(--BG);font-size:70px;font-weight:800;letter-spacing:-.04em;float:left;line-height:.82;margin:4px 9px 0 0;color:var(--K)}
.tB-subhead{font-family:var(--BG);font-size:24px;font-weight:800;letter-spacing:-.04em;color:var(--K);margin:44px 0 16px;text-align:center}
.tB-quote{text-align:center;margin:40px 0;padding:32px 12px;border-top:1px solid var(--G2);border-bottom:1px solid var(--G2)}
.tB-quote-mark{font-family:var(--BG);font-size:64px;font-weight:800;line-height:.6;color:var(--G2);display:block;margin-bottom:8px}
.tB-quote-text{font-family:var(--DM);font-style:italic;font-size:22px;line-height:1.45;color:var(--K);margin-bottom:12px;font-weight:300}
.tB-quote-cite{font-family:var(--DM);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--G4)}
.tB-inline-img{margin:36px -80px;height:300px;background:linear-gradient(135deg,#2c2c2c,#0a0a0a);position:relative;overflow:hidden}
.tB-inline-cap{margin-top:9px;font-family:var(--DM);font-style:italic;font-size:11.5px;color:var(--G4);text-align:center;margin-bottom:28px}
.tB-footer{margin-top:52px;padding-top:22px;border-top:1px solid var(--G2);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.tB-tags{display:flex;gap:6px;flex-wrap:wrap}
.tB-tag{font-family:var(--DM);font-size:10.5px;font-weight:600;color:var(--G5);padding:4px 12px;border:1.5px solid var(--G2);cursor:pointer;transition:all .15s;border-radius:4px}
.tB-tag:hover{border-color:var(--K);color:var(--K)}
.tB-next{display:flex;align-items:center;gap:6px;font-family:var(--DM);font-size:12px;font-weight:600;color:var(--G4);cursor:pointer;transition:color .15s}
.tB-next:hover{color:var(--K)}
.tB-next svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2}
@media(max-width:768px){
  .tB-topbar{padding:9px 16px}.tB-heading{padding:36px 20px 28px}.tB-photo{height:260px}
  .tB-body{padding:36px 20px 60px}.tB-inline-img{margin:28px -20px;height:220px}
}

/* ── TEMPLATE C — INMERSIVO LONGFORM ── */
.tC{background:#050505}
.tC-cover{height:100vh;min-height:580px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;background:#000}
.tC-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 30%,rgba(40,80,180,.5) 0%,transparent 60%),radial-gradient(ellipse 60% 80% at 20% 70%,rgba(120,40,180,.4) 0%,transparent 55%),linear-gradient(180deg,#050510 0%,#0a0518 100%)}
.tC-grain{position:absolute;inset:0;opacity:.35;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");background-size:200px}
.tC-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.98) 0%,rgba(0,0,0,.45) 55%,transparent 100%)}
.tC-content{position:relative;padding:0 60px 64px;max-width:880px}
.tC-label{display:inline-flex;align-items:center;gap:8px;font-family:var(--DM);font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:20px}
.tC-label-bar{width:20px;height:1.5px;background:rgba(255,255,255,.25)}
.tC-hl{font-family:var(--BG);font-size:clamp(36px,7vw,84px);font-weight:800;line-height:.93;letter-spacing:-.06em;color:var(--W);margin-bottom:22px}
.tC-hl em{font-style:normal;-webkit-text-stroke:1.5px rgba(255,255,255,.28);color:transparent}
.tC-deck{font-family:var(--DM);font-size:17px;font-weight:300;color:rgba(255,255,255,.5);line-height:1.65;max-width:540px;margin-bottom:32px}
.tC-meta{display:flex;align-items:center;gap:10px}
.tC-av{width:36px;height:36px;border-radius:50%;border:1.5px solid rgba(255,255,255,.18);background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;font-family:var(--DM);font-size:10px;font-weight:700;color:var(--W);flex-shrink:0}
.tC-by{font-family:var(--DM);font-size:12px;color:rgba(255,255,255,.4)}
.tC-dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.18)}
.tC-date{font-family:var(--DM);font-size:12px;color:rgba(255,255,255,.2)}
.tC-scroll{position:absolute;bottom:24px;right:52px;display:flex;align-items:center;gap:7px;font-family:var(--DM);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.15)}
.tC-scroll svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;animation:blink 1.6s ease-in-out infinite}
@keyframes blink{0%,100%{transform:translateY(0);opacity:.15}50%{transform:translateY(5px);opacity:.4}}
.tC-body{background:#050505;max-width:740px;margin:0 auto;padding:68px 24px 96px}
.tC-intro{font-family:var(--DM);font-style:italic;font-size:20px;line-height:1.65;color:rgba(255,255,255,.4);margin-bottom:48px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.07);font-weight:300}
.tC-p{font-family:var(--DM);font-size:17px;font-weight:300;line-height:1.88;color:rgba(255,255,255,.65);margin-bottom:24px}
.tC-p strong{color:rgba(255,255,255,.9);font-weight:600}
.tC-subhead{font-family:var(--BG);font-size:28px;font-weight:800;letter-spacing:-.05em;color:var(--W);margin:56px 0 20px}
.tC-spread{margin:52px -80px;height:440px;background:linear-gradient(135deg,#0d1117,#050505);display:flex;align-items:flex-end;padding:22px 36px;border-radius:5px;overflow:hidden;position:relative}
.tC-spread::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(5,5,5,.9) 100%)}
.tC-spread-cap{position:relative;font-family:var(--DM);font-size:10px;color:rgba(255,255,255,.22)}
.tC-pull{margin:44px 0;padding:32px 36px;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.02);display:flex;gap:22px;align-items:flex-start}
.tC-pull-n{font-family:var(--BG);font-size:80px;font-weight:800;letter-spacing:-.06em;line-height:.85;color:rgba(255,255,255,.05);flex-shrink:0;width:80px}
.tC-pull-text{font-family:var(--BG);font-size:20px;font-weight:700;letter-spacing:-.025em;line-height:1.28;color:var(--W);margin-bottom:9px}
.tC-pull-source{font-family:var(--DM);font-size:10px;color:rgba(255,255,255,.22);font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.tC-end{margin-top:56px;padding-top:26px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.tC-tags{display:flex;gap:7px;flex-wrap:wrap}
.tC-tag{font-family:var(--DM);font-size:10px;font-weight:600;color:rgba(255,255,255,.25);padding:5px 11px;border:1px solid rgba(255,255,255,.08);cursor:pointer;transition:all .15s;border-radius:3px}
.tC-tag:hover{color:var(--W);border-color:rgba(255,255,255,.28)}
.tC-next{display:flex;align-items:center;gap:7px;font-family:var(--DM);font-size:12px;font-weight:600;color:rgba(255,255,255,.28);cursor:pointer;transition:color .15s}
.tC-next:hover{color:var(--W)}
.tC-next svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2}
@media(max-width:768px){
  .tC-content{padding:0 22px 48px}.tC-spread{margin:36px -20px;height:260px;border-radius:0}
  .tC-body{padding:40px 20px 64px}.tC-pull{padding:20px;gap:14px}.tC-pull-n{font-size:56px;width:56px}
}

/* Nav anchor links — match button styling */
.nl, .nl:visited, .nl:link { text-decoration:none; }
.nav-cta, .nav-cta:visited, .nav-cta:link { text-decoration:none; }
.wordmark, .wordmark:visited { text-decoration:none; color:var(--K); }
.mqc-btn, .mqc-btn:visited { text-decoration:none; }

/* Mobile nav — anchor tags render same as buttons */
a.mob-tab, a.mob-tab:visited, a.mob-tab:link {
  text-decoration:none;
  color:#BEBEBE;
}
a.mob-tab.on, a.mob-tab:hover {
  color:var(--K);
}
a.mob-tab-xp, a.mob-tab-xp:visited, a.mob-tab-xp:link {
  text-decoration:none;
  color:var(--K);
}

/* ════════════════════════════════════════
   ASK LUNA — Fullscreen chat experience
   No footer, locked viewport, offset from nav
════════════════════════════════════════ */
#pg-ask.on {
  background: var(--W);
  position: fixed;
  inset: 0;
  z-index: 100;
  overflow: hidden;
}
#pg-ask .site-footer,
#pg-ask ~ .site-footer {
  display: none !important;
}

.ask-shell {
  display: flex;
  flex-direction: column;
  height: 100vh;
  max-width: 700px;
  margin: 0 auto;
  border: none;
  background: var(--W);
  position: relative;
}

/* Push shell content below the fixed desktop nav + ticker */
.ask-shell::before {
  content: '';
  display: block;
  height: calc(var(--NAV) + 30px);
  flex-shrink: 0;
}

/* Brand header */
.ask-top {
  padding: 12px 24px 10px;
  border-bottom: 1px solid var(--G2);
  flex-shrink: 0;
}
.ask-top-brand {
  display: flex;
  align-items: center;
  gap: 4px;
}
.ask-top-brand-part {
  font-family: var(--DM);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: 4px 8px;
  border: 1.5px solid var(--K);
  border-radius: 4px;
}

/* Tab strip */
.ask-tabs {
  display: flex;
  border-bottom: 1px solid var(--G2);
  flex-shrink: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.ask-tabs::-webkit-scrollbar { display: none; }
.ask-tab {
  font-family: var(--DM);
  font-size: 12px;
  font-weight: 600;
  color: var(--G4);
  padding: 11px 18px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: all .15s;
  flex-shrink: 0;
}
.ask-tab.on { color: var(--K); border-bottom-color: var(--K); }
.ask-tab:hover:not(.on) { color: var(--G5); }

/* Messages — scrollable area fills remaining space */
.ask-msgs {
  flex: 1;
  overflow-y: auto;
  padding: 16px 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  /* Never show footer content below messages */
  overscroll-behavior: contain;
}

/* Welcome state */
.ask-welcome {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 48px 24px 24px;
  gap: 10px;
}
.ask-welcome-greeting {
  font-family: var(--BG);
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -.04em;
  color: var(--K);
  line-height: 1.1;
}
.ask-welcome-sub {
  font-family: var(--DM);
  font-size: 14px;
  color: var(--G4);
  font-weight: 300;
  max-width: 320px;
}
.ask-suggest-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
  max-width: 500px;
  margin-top: 12px;
}
.ask-suggest-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--G1);
  border: 1px solid var(--G2);
  border-radius: 10px;
  cursor: pointer;
  text-align: left;
  transition: background .15s, border-color .15s;
}
.ask-suggest-item:hover { background: var(--G2); border-color: var(--G3); }
.ask-suggest-icon { font-size: 18px; flex-shrink: 0; }
.ask-suggest-text {
  font-family: var(--DM);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--K);
  line-height: 1.35;
}

/* Message bubbles */
.ask-row { display: flex; gap: 10px; align-items: flex-end; max-width: 85%; }
.ask-row.user { align-self: flex-end; flex-direction: row-reverse; }
.ask-row.ai   { align-self: flex-start; }
.ask-bub {
  font-family: var(--DM);
  font-size: 14px;
  line-height: 1.6;
  padding: 11px 15px;
  border-radius: 16px;
  max-width: 100%;
  white-space: pre-wrap;
  word-break: break-word;
}
.ask-row.user .ask-bub {
  background: var(--K);
  color: var(--W);
  border-bottom-right-radius: 4px;
}
.ask-row.ai .ask-bub {
  background: var(--G1);
  color: var(--K);
  border: 1px solid var(--G2);
  border-bottom-left-radius: 4px;
}
.ask-typing-bub {
  display: flex;
  align-items: center;
  gap: 4px;
  background: var(--G1);
  border: 1px solid var(--G2);
  padding: 11px 15px;
  border-radius: 16px;
  border-bottom-left-radius: 4px;
}
.ask-typing-bub span span,
.ask-typing-bub > span:not(#luna-status-txt) span {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--G4);
  animation: askPulse 1.2s ease-in-out infinite;
  display: inline-block;
}
.ask-typing-bub > span:not(#luna-status-txt) span:nth-child(2) { animation-delay: .2s; }
.ask-typing-bub > span:not(#luna-status-txt) span:nth-child(3) { animation-delay: .4s; }
@keyframes askPulse { 0%,80%,100%{transform:scale(.6);opacity:.4} 40%{transform:scale(1);opacity:1} }

/* Input area — always visible at bottom */
.ask-input-bar {
  flex-shrink: 0;
  padding: 12px 16px 16px;
  border-top: 1px solid var(--G2);
  background: var(--W);
}
.ask-input-in {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  background: var(--G1);
  border: 1.5px solid var(--G2);
  border-radius: 14px;
  padding: 10px 10px 10px 16px;
  transition: border-color .2s;
}
.ask-input-in:focus-within { border-color: var(--K); }
.ask-textarea {
  flex: 1;
  border: none;
  outline: none;
  font-family: var(--DM);
  font-size: 14px;
  color: var(--K);
  background: transparent;
  resize: none;
  max-height: 120px;
  line-height: 1.5;
  font-weight: 300;
}
.ask-textarea::placeholder { color: var(--G3); }
.ask-send-btn {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--K);
  border: none;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: opacity .15s, transform .1s;
}
.ask-send-btn:disabled { opacity: .35; cursor: default; }
.ask-send-btn:not(:disabled):hover { opacity: .85; }
.ask-send-btn:not(:disabled):active { transform: scale(.95); }
.ask-send-btn svg { width: 20px; height: 20px; }
.ask-footer-note {
  text-align: center;
  padding: 6px 0 0;
  font-family: var(--DM);
  font-size: 10px;
  color: var(--G3);
}

/* ── MOBILE: proper fullscreen ── */
@media(max-width:768px) {
  #pg-ask.on {
    position: fixed;
    inset: 0;
    overflow: hidden;
  }
  .ask-shell {
    max-width: 100%;
    height: 100%;
  }
  .ask-shell::before {
    /* On mobile nav is sticky at top */
    height: var(--MOB);
  }
  .ask-msgs { padding: 12px 16px; }
  .ask-top  { padding: 10px 16px 8px; }
  .ask-input-bar { padding: 8px 12px calc(12px + env(safe-area-inset-bottom, 0px)); }
  .ask-welcome { padding: 32px 16px 16px; }
  .ask-welcome-greeting { font-size: 22px; }
  .ask-suggest-item { padding: 10px 14px; }
  .ask-suggest-text { font-size: 13px; }
  /* Hide mob bottom nav while in ask */
  #pg-ask.on ~ #mob-nav,
  body:has(#pg-ask.on) #mob-nav { display: none !important; }
}

/* ── Also hide site footer when ask is active ── */
body:has(#pg-ask.on) .site-footer { display: none !important; }
body:has(#pg-ask.on) #mob-nav     { display: none !important; }


/* ── Predicciones modal — above nav, button always visible ── */
.modal-layer { z-index: 1200 !important; }
.pred-detail-layer { z-index: 1200 !important; }
.modal-box {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  max-height: min(90vh, 700px);
}
.modal-body {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.modal-foot {
  flex-shrink: 0;
  padding: 14px 22px 18px;
  border-top: 1px solid var(--G2);
  background: var(--W);
  display: flex;
  gap: 10px;
}
.modal-submit {
  flex: 1;
  background: var(--K);
  color: var(--W);
  border: none;
  border-radius: 8px;
  font-family: var(--DM);
  font-size: 13px;
  font-weight: 700;
  padding: 12px;
  cursor: pointer;
  transition: opacity .15s;
}
.modal-submit:hover { opacity: .85; }
.modal-submit:disabled { opacity: .4; cursor: default; }
.modal-cancel {
  background: none;
  border: 1.5px solid var(--G2);
  border-radius: 8px;
  font-family: var(--DM);
  font-size: 13px;
  font-weight: 600;
  padding: 12px 18px;
  color: var(--G4);
  cursor: pointer;
}
@media(max-width:768px){
  .modal-box { max-height: 85vh; border-radius: 20px 20px 0 0; }
  .modal-foot { padding: 12px 16px calc(14px + env(safe-area-inset-bottom, 0px)); }
}

/* ── Xpress compose — anonymous name input ── */
.xp-name-row {
  padding: 10px 16px 0;
  display: flex;
  align-items: center;
}
.xp-name-inp {
  width: 100%;
  border: 1.5px solid var(--G2);
  border-radius: 8px;
  padding: 8px 12px;
  font-family: var(--DM);
  font-size: 13px;
  font-weight: 500;
  color: var(--K);
  background: var(--G1);
  outline: none;
  transition: border-color .18s;
}
.xp-name-inp:focus { border-color: var(--K); background: var(--W); }
.xp-name-inp::placeholder { color: var(--G3); font-weight: 400; }
.xp-compose-body-row {
  display: flex;
  gap: 10px;
  padding: 10px 16px 12px;
  align-items: flex-start;
}
/* Xpress ad slot */
.xp-ad-slot {
  border-bottom: 1px solid var(--G2);
  background: #fafaf8;
}

/* ── Hero: real background images from WP ── */
.hero-slide[style*="background-image"] .ts-img,
.top-story .ts-img[style*="background-image"] {
  background-size: cover;
  background-position: center;
}
.card-img-inner[style*="background-image"] {
  background-size: cover;
  background-position: center;
  width: 100%;
  height: 100%;
}
.sh-img[style*="background-image"] {
  background-size: cover;
  background-position: center;
}
/* Article related block responsive */
.art-related-block { padding: 0 0 40px; }
@media(max-width:768px){
  .art-related-block > div > div[style*="grid-template-columns"] {
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
  }
}
@media(max-width:480px){
  .art-related-block > div > div[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }
}

/* ── Pred cards on home — full display ── */
.home-preds-gauge-grid .pred-card {
  border: 1px solid var(--G2);
  border-radius: 14px;
  padding: 18px 16px 14px;
  cursor: pointer;
  transition: border-color .18s, transform .18s;
  display: flex;
  flex-direction: column;
  background: var(--W);
  min-height: 180px;
}
.home-preds-gauge-grid .pred-card:hover {
  border-color: var(--K);
  transform: translateY(-2px);
}
.home-preds-gauge-grid .pred-card-top-row {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  margin-bottom: 12px;
}
.home-preds-gauge-grid .pred-card-spacer { flex: 1; }
@media(max-width:768px){
  .home-preds-gauge-grid{grid-template-columns:1fr 1fr !important;gap:10px}
}
@media(max-width:480px){
  .home-preds-gauge-grid{grid-template-columns:1fr !important}
}

/* ── Luna AI — Mobile fullscreen ── */
@media(max-width:768px){
  #pg-ask.on {
    position: fixed !important;
    top: 0; left: 0; right: 0; bottom: 0;
    z-index: 200 !important;
    background: var(--W);
    overflow: hidden;
  }
  .ask-shell {
    height: 100% !important;
    max-width: 100% !important;
    display: flex;
    flex-direction: column;
  }
  .ask-shell::before {
    height: var(--MOB, 52px) !important;
    flex-shrink: 0;
  }
  .ask-msgs {
    flex: 1 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding: 12px 16px !important;
    overscroll-behavior: contain;
  }
  .ask-top {
    flex-shrink: 0;
    padding: 10px 16px 8px !important;
  }
  .ask-tabs {
    flex-shrink: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .ask-tab {
    padding: 9px 14px !important;
    font-size: 11px !important;
  }
  .ask-input-bar {
    flex-shrink: 0 !important;
    padding: 10px 14px calc(12px + env(safe-area-inset-bottom, 0px)) !important;
    background: var(--W);
    border-top: 1px solid var(--G2);
  }
  .ask-welcome {
    padding: 28px 16px 16px !important;
  }
  .ask-welcome-greeting {
    font-size: 20px !important;
  }
  .ask-suggest-list {
    gap: 7px !important;
  }
  .ask-suggest-item {
    padding: 10px 13px !important;
  }
  .ask-suggest-text {
    font-size: 12.5px !important;
  }
  .ask-bub {
    font-size: 13.5px !important;
    padding: 10px 13px !important;
  }
  .ask-row { max-width: 90% !important; }
  /* Hide mob-nav and footer when chat is open */
  body:has(#pg-ask.on) #mob-nav { display: none !important; }
  body:has(#pg-ask.on) .site-footer { display: none !important; }
}

/* ── Xpress compose — fixed layout ── */
.xp-compose { padding: 0; }
.xp-name-row { padding: 12px 16px 0; }
.xp-name-inp {
  width: 100%;
  box-sizing: border-box;
  border: 1.5px solid var(--G2);
  border-radius: 8px;
  padding: 9px 13px;
  font-family: var(--DM);
  font-size: 13px;
  font-weight: 500;
  color: var(--K);
  background: var(--G1);
  outline: none;
  transition: border-color .18s;
}
.xp-name-inp:focus { border-color: var(--K); background: var(--W); }
.xp-name-inp::placeholder { color: var(--G3); }
.xp-compose-body-row {
  display: flex;
  gap: 12px;
  padding: 10px 16px 14px;
  align-items: flex-start;
}
.xp-av-box {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--K);
  color: var(--W);
  font-family: var(--BG);
  font-size: 14px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.xp-compose-in {
  flex: 1;
  min-width: 0;
}
.xp-compose-textarea {
  width: 100%;
  box-sizing: border-box;
  border: none;
  outline: none;
  font-family: var(--DM);
  font-size: 14px;
  color: var(--K);
  background: transparent;
  resize: none;
  line-height: 1.5;
  min-height: 40px;
  max-height: 150px;
  padding: 0;
}
.xp-compose-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
  padding-top: 10px;
  border-top: 1px solid var(--G2);
}
.xp-pub-btn {
  background: var(--K);
  color: var(--W);
  border: none;
  border-radius: 8px;
  font-family: var(--DM);
  font-size: 13px;
  font-weight: 700;
  padding: 8px 18px;
  cursor: pointer;
  transition: opacity .15s;
}
.xp-pub-btn:hover { opacity: .85; }
