/* ============================================================
   COMPONENTS — module-specific styles
   ============================================================ */

/* ---------- top bar ---------- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;justify-content:space-between;
  padding:9px var(--gutter);background:color-mix(in oklab,var(--paper) 86%,transparent);
  backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,padding .3s}
.topbar.stuck{border-color:var(--rule)}
.tb-left{display:flex;align-items:center;gap:14px}
.tb-mark{font-family:var(--serif);font-weight:600;font-size:18px;letter-spacing:-.01em}
.tb-mark em{font-style:italic;color:var(--accent)}
.tb-progress{position:absolute;left:0;bottom:-1px;height:2px;background:var(--accent);width:0}
.tb-right{display:flex;align-items:center;gap:10px}
.tb-byline{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
@media (max-width:680px){.tb-byline{display:none}}

/* ---------- hero ---------- */
.hero{padding-top:128px;padding-bottom:60px;min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.hero-grid{position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:linear-gradient(var(--rule) 1px,transparent 1px),linear-gradient(90deg,var(--rule) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(120% 90% at 70% 20%,#000 30%,transparent 75%)}
.hero>*{position:relative;z-index:1}
.hero-kicker{margin-bottom:26px}
.hero h1{font-size:clamp(40px,8.2vw,108px);font-weight:500;line-height:.98;letter-spacing:-.022em;max-width:16ch;text-wrap:balance}
.hero-dek{margin-top:30px;max-width:60ch;font-size:clamp(17px,1.8vw,21px);color:var(--ink-2);line-height:1.55}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:54px;border-top:1px solid var(--rule)}
.hstat{padding:24px 22px 22px 0;border-right:1px solid var(--rule)}
.hstat:last-child{border-right:none;padding-right:0}
.hstat .hv{font-family:var(--serif);font-size:clamp(30px,4vw,52px);font-weight:560;line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.hstat:nth-child(2) .hv,.hstat:nth-child(4) .hv{color:var(--accent)}
.hstat .hl{margin-top:10px;font-size:13px;line-height:1.35;color:var(--ink-3);max-width:22ch}
@media (max-width:760px){.hero-stats{grid-template-columns:1fr 1fr}.hstat{border-bottom:1px solid var(--rule)}.hstat:nth-child(2){border-right:none}}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:42px}
.scrollcue{margin-top:48px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-4);display:flex;align-items:center;gap:10px}
.scrollcue .ln{width:46px;height:1px;background:var(--rule-2);position:relative;overflow:hidden}
.scrollcue .ln::after{content:"";position:absolute;inset:0;background:var(--accent);animation:cue 2.4s infinite}
@keyframes cue{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}

/* ---------- index ---------- */
.index-sec{background:var(--paper-2)}
.index-head{display:grid;grid-template-columns:auto minmax(280px,440px);align-items:end;justify-content:space-between;gap:18px 40px;margin-bottom:30px}
.index-head .dek{margin-bottom:10px}
@media (max-width:820px){.index-head{grid-template-columns:1fr}.index-head .dek{margin-bottom:0}}
.toc{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--rule)}
@media (max-width:760px){.toc{grid-template-columns:1fr}}
.toc-item{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  padding:18px 8px;border-bottom:1px solid var(--rule);text-decoration:none;transition:background .2s,padding .2s;position:relative}
.toc-item:nth-child(odd){border-right:1px solid var(--rule)}
@media (max-width:760px){.toc-item:nth-child(odd){border-right:none}}
.toc-item:hover{background:var(--card);padding-inline:18px}
.toc-n{font-family:var(--mono);font-size:13px;color:var(--accent);font-weight:600;width:2.2em}
.toc-txt h4{font-size:17px;font-weight:600;font-family:var(--sans);letter-spacing:-.01em}
.toc-txt p{margin:3px 0 0;font-size:13px;color:var(--ink-3);line-height:1.35}
.toc-go{font-family:var(--mono);font-size:12px;color:var(--ink-4);transition:transform .2s,color .2s}
.toc-item:hover .toc-go{transform:translateX(4px);color:var(--accent)}

/* ---------- chapter head ---------- */
.chead{margin-bottom:clamp(30px,4vw,52px)}
.viz-wrap{margin-top:clamp(28px,4vw,48px)}

/* ---------- donut + bars ---------- */
.viz-duo{display:grid;grid-template-columns:340px 1fr;gap:clamp(28px,5vw,64px);align-items:center}
@media (max-width:840px){.viz-duo{grid-template-columns:1fr}}
.donut{width:100%;max-width:300px;display:block;margin:0 auto}
.donut-big{font-family:var(--serif);font-size:40px;font-weight:600;fill:var(--ink);font-variant-numeric:tabular-nums}
.donut-sub{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;fill:var(--ink-3)}
.donut-legend{margin-top:18px;display:flex;flex-direction:column;gap:9px}
.dl-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;font-size:14px}
.dl-sw{width:11px;height:11px;border-radius:3px}
.dl-k{color:var(--ink-2)}.dl-v{font-family:var(--mono);color:var(--ink);font-weight:600}
.bars{display:flex;flex-direction:column;gap:14px}
.bar-row{display:grid;grid-template-columns:130px 1fr 74px;gap:14px;align-items:center}
.bar-k{font-size:14px;color:var(--ink-2);text-align:right}
.bar-track{height:26px;background:var(--paper-3);border-radius:5px;overflow:hidden}
.bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--water),var(--water-2));border-radius:5px;transition:width 1.1s cubic-bezier(.2,.7,.2,1)}
.bar-v{font-family:var(--mono);font-size:14px;color:var(--ink);font-weight:600;text-align:right}
.bars-cap{margin-top:14px;text-align:right}
@media (max-width:520px){.bar-row{grid-template-columns:96px 1fr 60px;gap:8px}.bar-k{font-size:12px}}

/* ---------- stepper ---------- */
.stepper{display:grid;grid-template-columns:280px 1fr;gap:clamp(24px,4vw,52px)}
@media (max-width:840px){.stepper{grid-template-columns:1fr}}
.step-rail{position:relative;display:flex;flex-direction:column;gap:4px}
.step-prog{display:none}
.step-dot{display:flex;align-items:baseline;gap:14px;text-align:left;background:none;border:none;cursor:pointer;
  padding:14px 16px;border-radius:10px;border:1px solid transparent;transition:all .2s;color:var(--ink-4)}
.step-dot:hover{background:var(--card)}
.step-dot .sd-n{font-size:12px;font-weight:600}
.step-dot .sd-t{font-size:15px;font-weight:600;font-family:var(--sans);letter-spacing:-.01em}
.step-dot.on{color:var(--ink-3)}
.step-dot.cur{color:var(--ink);background:var(--card);border-color:var(--rule)}
.step-dot.cur .sd-n{color:var(--accent)}
@media (max-width:840px){.step-rail{flex-direction:row;overflow-x:auto;gap:8px}.step-dot{flex:0 0 auto}.step-dot .sd-t{display:none}.step-dot .sd-n{font-size:15px}}
.step-stage{min-height:340px}
.step-card{opacity:0;transform:translateY(14px);transition:opacity .5s,transform .5s;background:var(--card);border:1px solid var(--rule);border-radius:16px;padding:clamp(26px,3.5vw,44px);box-shadow:var(--shadow-1);position:relative;overflow:hidden}
.step-card.show{opacity:1;transform:none}
.step-big{position:absolute;top:-18px;right:6px;font-size:150px;font-weight:700;color:var(--paper-3);line-height:1;z-index:0}
[data-theme="dark"] .step-big{color:var(--paper-2)}
.step-card h3,.step-card p,.step-nav{position:relative;z-index:1}
.step-card h3{font-size:clamp(24px,3vw,34px);margin-bottom:14px}
.step-s{font-size:clamp(17px,1.8vw,20px);color:var(--ink);line-height:1.5;margin:0 0 14px;max-width:48ch}
.step-d{font-size:15px;color:var(--ink-3);line-height:1.55;max-width:54ch;margin:0}
.step-nav{display:flex;align-items:center;gap:16px;margin-top:30px}
.step-nav .btn[disabled]{opacity:.35;pointer-events:none}
.step-count{margin-left:auto;color:var(--ink-4);font-size:12px;letter-spacing:.1em}

/* ---------- cases ---------- */
.case-grid{display:flex;flex-direction:column;gap:14px}
.case-card{overflow:hidden}
.case-head{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:24px clamp(20px,3vw,30px);
  display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"tag . plus" "title title plus" "sum sum plus";gap:6px 16px;align-items:start}
.case-tag{grid-area:tag;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600}
.case-head h3{grid-area:title;font-size:clamp(20px,2.4vw,27px)}
.case-sum{grid-area:sum;font-size:15px;color:var(--ink-3);line-height:1.4;max-width:60ch}
.case-plus{grid-area:plus;font-family:var(--serif);font-size:30px;color:var(--ink-4);align-self:center;transition:color .2s}
.case-card:hover .case-plus{color:var(--accent)}
.case-body{height:0;overflow:hidden;transition:height .45s cubic-bezier(.2,.7,.2,1)}
.case-inner{padding:0 clamp(20px,3vw,30px) 26px}
.case-inner p{font-size:16px;color:var(--ink-2);line-height:1.6;margin:0 0 6px;max-width:64ch}

/* ---------- network ---------- */
.net-wrap{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:stretch}
@media (max-width:900px){.net-wrap{grid-template-columns:1fr}}
.net-canvas-box{position:relative;background:var(--paper-2);border:1px solid var(--rule);border-radius:16px;overflow:hidden;min-height:520px}
.net-canvas-box canvas{width:100%;height:520px;display:block;touch-action:none}
.net-hub-note{position:absolute;left:16px;bottom:14px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);pointer-events:none}
.net-side{display:flex;flex-direction:column;gap:18px}
.net-filters{display:flex;flex-wrap:wrap;gap:8px}
.net-panel{flex:1;background:var(--card);border:1px solid var(--rule);border-radius:16px;padding:24px;box-shadow:var(--shadow-1);min-height:230px}
.np-empty .label{color:var(--ink-4)}.np-empty p{font-size:14px;color:var(--ink-3);line-height:1.5;margin-top:12px}
.np-card .np-tag{display:inline-block;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:#fff;padding:.35em .7em;border-radius:4px;font-weight:600}
.np-card h4{font-family:var(--serif);font-size:26px;margin:14px 0 10px;font-weight:560}
.np-card p{font-size:15px;color:var(--ink-2);line-height:1.55}
.np-deg{margin-top:16px;padding-top:14px;border-top:1px solid var(--rule);font-family:var(--mono);font-size:12px;color:var(--ink-3)}
.np-deg span{color:var(--accent);font-weight:600;font-size:15px}

/* ---------- map ---------- */
.map-controls{margin-bottom:20px}
.map-wrap{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start}
@media (max-width:900px){.map-wrap{grid-template-columns:1fr}}
.map-svg{width:100%;height:auto;display:block}
.tile{cursor:pointer;outline:none}
.tile rect{transition:fill .35s ease}
.tile:hover rect,.tile:focus-visible rect{stroke:var(--ink);stroke-width:2.5}
.tile.sel rect{stroke:var(--accent);stroke-width:3}
.tile-code{font-family:var(--mono);font-size:13px;font-weight:600;fill:var(--ink);pointer-events:none}
.tile-val{font-family:var(--mono);font-size:10px;fill:var(--ink-2);pointer-events:none}
.map-side{position:sticky;top:84px}
.md-empty,.md-card{background:var(--card);border:1px solid var(--rule);border-radius:16px;padding:24px;box-shadow:var(--shadow-1)}
.md-empty p{font-size:14px;color:var(--ink-3);line-height:1.5;margin-top:12px}
.md-card h4{font-family:var(--serif);font-size:26px;margin:8px 0 16px;font-weight:560}
.md-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:baseline;padding:10px 0;border-top:1px solid var(--rule)}
.md-row span{font-size:13px;color:var(--ink-3)}
.md-row b{font-family:var(--mono);font-size:19px;color:var(--ink)}
.md-row i{font-size:11px;color:var(--ink-4);font-style:normal;font-family:var(--mono)}
.md-row.pep b{color:var(--accent)}
.map-scale{margin-top:18px;display:flex;flex-direction:column;gap:6px}
.scale-grad{height:10px;border-radius:5px}
.scale-row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--ink-4)}
.scale-pep{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;color:var(--ink-3);margin-top:6px}
.scale-pep .dot{width:9px;height:9px;border-radius:50%;background:var(--red);border:1.5px solid var(--paper)}

/* ---------- table ---------- */
.pep-table{width:100%;border-collapse:collapse;font-size:15px}
.pep-table th{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);
  font-weight:600;padding:12px 14px;border-bottom:2px solid var(--ink);cursor:pointer;user-select:none;white-space:nowrap}
.pep-table th:hover{color:var(--ink)}
.pep-table th.sorted{color:var(--accent)}
.t-left{text-align:left}.t-right{text-align:right}
.sort-ar{margin-left:4px}
.pep-table td{padding:13px 14px;border-bottom:1px solid var(--rule);vertical-align:middle}
.pep-table tr:hover td{background:var(--card)}
.pep-name{font-weight:600;color:var(--ink)}
.pep-dotrow{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:9px;vertical-align:middle}
.pep-role{color:var(--ink-3);font-size:14px}
.party-pill{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--pc);border:1px solid var(--pc);
  padding:.25em .6em;border-radius:999px;background:color-mix(in oklab,var(--pc) 10%,transparent)}
.pep-table td.t-right{position:relative}
.vbar{position:absolute;left:14px;bottom:8px;height:3px;background:var(--accent);opacity:.5;border-radius:2px}
.vnum{position:relative}
@media (max-width:680px){.pep-role,.pep-table th:nth-child(2){display:none}}

/* ---------- corporates ---------- */
.corp-list{display:flex;flex-direction:column;gap:22px}
.corp-row{display:grid;grid-template-columns:220px 1fr;grid-template-areas:"meta track" "meta note";gap:6px 26px;align-items:center;padding-bottom:22px;border-bottom:1px solid var(--rule)}
@media (max-width:680px){.corp-row{grid-template-columns:1fr;grid-template-areas:"meta" "track" "note"}}
.corp-meta{grid-area:meta}.corp-meta h4{font-family:var(--serif);font-size:23px;font-weight:560}
.corp-track{grid-area:track;position:relative;height:38px;background:var(--paper-3);border-radius:6px;overflow:hidden;display:flex;align-items:center}
.corp-fill{height:100%;width:0;background:linear-gradient(90deg,var(--water),var(--water-2));transition:width 1.1s cubic-bezier(.2,.7,.2,1)}
.corp-v{position:absolute;right:14px;font-family:var(--mono);font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap}
.corp-note{grid-area:note;font-size:14px;color:var(--ink-3);line-height:1.45;margin:0}

/* ---------- directors ---------- */
.dir-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.dir-card{background:var(--card);border:1px solid var(--rule);border-radius:14px;padding:24px;transition:transform .2s,box-shadow .2s}
.dir-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.dir-n{font-size:13px;font-weight:600;color:var(--accent);margin-bottom:14px}
.dir-card h4{font-family:var(--serif);font-size:21px;font-weight:560;margin-bottom:8px;line-height:1.15}
.dir-card p{font-size:14px;color:var(--ink-3);line-height:1.5;margin:0}

/* ---------- expedientes ---------- */
.exp-list{display:flex;flex-direction:column;gap:20px}
.exp-row{display:grid;grid-template-columns:200px 1fr 130px;grid-template-areas:"era bar count" "era note note";gap:6px 22px;align-items:center;padding-bottom:18px;border-bottom:1px solid var(--rule)}
@media (max-width:680px){.exp-row{grid-template-columns:1fr;grid-template-areas:"era" "bar" "count" "note"}}
.exp-era{grid-area:era}.exp-era b{display:block;font-size:16px;color:var(--ink)}
.exp-tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.exp-bar{grid-area:bar;height:14px;background:var(--paper-3);border-radius:7px;overflow:hidden}
.exp-fill{height:100%;width:0;background:var(--accent);transition:width 1s cubic-bezier(.2,.7,.2,1)}
.exp-c{grid-area:count;font-family:var(--serif);font-size:30px;font-weight:560;color:var(--ink)}
.exp-c .label{font-family:var(--mono);font-size:10px}
.exp-note{grid-area:note;font-size:13px;color:var(--ink-3);margin:0;line-height:1.4}

/* ---------- timeline ---------- */
.timeline{position:relative;margin-top:20px;padding-left:0}
.tl-item{display:grid;grid-template-columns:90px 40px 1fr;gap:0;align-items:start;position:relative}
.tl-year{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--accent);padding-top:18px;text-align:right;padding-right:18px;font-variant-numeric:tabular-nums}
.tl-dot{position:relative;justify-self:center}
.tl-dot::before{content:"";position:absolute;top:26px;left:50%;transform:translateX(-50%);width:13px;height:13px;border-radius:50%;background:var(--paper);border:3px solid var(--accent);z-index:1}
.tl-dot::after{content:"";position:absolute;top:26px;left:50%;transform:translateX(-50%);width:2px;height:calc(100% + 26px);background:var(--rule)}
.tl-item:last-child .tl-dot::after{display:none}
.tl-card{padding:20px 24px;margin:8px 0 30px}
.tl-card h4{font-family:var(--serif);font-size:21px;font-weight:560;margin-bottom:6px}
.tl-card p{font-size:15px;color:var(--ink-2);line-height:1.5;margin:0}
@media (max-width:560px){.tl-item{grid-template-columns:64px 28px 1fr}.tl-year{font-size:18px;padding-right:10px}}

/* ---------- fepa / coda / denuncia ---------- */
.fepa-sec{background:var(--paper-2)}
.fepa-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,60px);align-items:center}
@media (max-width:860px){.fepa-grid{grid-template-columns:1fr}}
.fepa-card{background:var(--ink);color:var(--paper);border-radius:18px;padding:clamp(30px,4vw,48px);position:relative;overflow:hidden}
[data-theme="dark"] .fepa-card{background:#000;border:1px solid var(--rule)}
.fepa-card .label{color:var(--red)}
.fepa-card h3{font-family:var(--serif);font-size:clamp(26px,3.4vw,40px);color:var(--paper);margin:14px 0 18px;font-weight:520}
.fepa-card p{color:color-mix(in oklab,var(--paper) 78%,transparent);font-size:16px;line-height:1.6}
.fepa-big{font-family:var(--serif);font-size:clamp(60px,9vw,120px);font-weight:600;line-height:.9;color:var(--red);font-variant-numeric:tabular-nums}
.fepa-big small{font-size:.3em;color:var(--paper);font-weight:500;display:block;letter-spacing:.04em;font-family:var(--mono);text-transform:uppercase;margin-top:14px}

.coda-sec{background:var(--ink);color:var(--paper)}
[data-theme="dark"] .coda-sec{background:#000}
.coda-sec .kicker,.coda-sec .label{color:color-mix(in oklab,var(--paper) 60%,transparent)}
.coda-sec h2.title{color:var(--paper)}
.coda-sec .dek{color:color-mix(in oklab,var(--paper) 78%,transparent)}
.coda-svg{width:100%;height:auto;display:block;margin-top:30px}
.coda-svg .axis-t{font-family:var(--mono);font-size:12px;fill:color-mix(in oklab,var(--paper) 55%,transparent)}
.coda-svg line{stroke:color-mix(in oklab,var(--paper) 14%,transparent)!important}
.coda-lab{font-family:var(--mono);font-size:13px;font-weight:600}
.coda-cross{font-family:var(--mono);font-size:12px;color:var(--red);letter-spacing:.1em;text-transform:uppercase}

.denuncia{text-align:center;max-width:760px;margin-inline:auto}
.denuncia .stamp{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);border-radius:999px;padding:.6em 1.2em;margin-bottom:26px}
.denuncia .stamp .pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in oklab,var(--accent) 60%,transparent)}70%{box-shadow:0 0 0 10px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* footer */
.foot{padding:60px var(--gutter);border-top:1px solid var(--rule);background:var(--paper-2);text-align:center}
.foot .mono{font-size:12px;color:var(--ink-4);letter-spacing:.04em;line-height:1.8}
.foot a{color:var(--accent);text-decoration:none}

/* ---------- atlas ---------- */
.atlas-wrap{display:grid;grid-template-columns:1.5fr 1fr;gap:24px;align-items:start}
@media (max-width:900px){.atlas-wrap{grid-template-columns:1fr}}
.atlas-svg{width:100%;height:auto;display:block}
.atlas-state{fill:var(--paper-2);stroke:var(--rule-2);stroke-width:0.7}
.atlas-pin circle{transition:r .2s, opacity .25s}
.atlas-panel{position:sticky;top:78px;background:var(--card);border:1px solid var(--rule);border-radius:14px;box-shadow:var(--shadow-1);padding:26px;min-height:300px}
.atlas-metric{font-family:var(--mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:600}
.atlas-chips{margin-bottom:18px}

/* ---------- explainer ---------- */
.exp-toggle{display:flex;border:1px solid var(--rule);border-radius:999px;overflow:hidden;width:max-content;margin:0 auto 22px;background:var(--card)}
.exp-toggle button{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;padding:12px 22px;border:none;background:transparent;color:var(--ink-3);cursor:pointer;transition:all .2s}
.exp-toggle button.on{background:var(--ink);color:var(--card)}
.exp-stage{background:var(--card);border:1px solid var(--rule);border-radius:14px;box-shadow:var(--shadow-1);padding:30px 32px;max-width:760px;margin:0 auto;min-height:150px}
.exp-stage .et{font-family:var(--serif);font-size:24px;margin:0 0 8px}
.exp-stage .ed{color:var(--ink-2);font-size:16.5px;line-height:1.65;margin:0}
.flips{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:26px}
@media (max-width:760px){.flips{grid-template-columns:1fr}}
.flip{background:var(--card);border:1px solid var(--rule);border-radius:14px;box-shadow:var(--shadow-1);padding:24px;cursor:pointer;transition:transform .2s, box-shadow .2s}
.flip:hover{transform:translateY(-3px)}
.flip .fq{font-family:var(--serif);font-size:20px;line-height:1.2;margin:8px 0 0}
.flip .fa{display:none;color:var(--ink-2);font-size:15px;line-height:1.6;margin-top:12px}
.flip.open .fa{display:block}
.flip .fhint{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-top:14px}
.flip.open .fhint{display:none}

/* ---------- hero art plate + logo ---------- */
.tb-logo{height:46px;width:auto;display:block}
.tb-left{display:flex;align-items:center}
.hero-art{display:block;width:100%;height:auto;margin:46px 0 8px;border-radius:6px;
  mix-blend-mode:multiply;opacity:0;transform:translateY(18px);
  transition:opacity 1.4s cubic-bezier(.2,.7,.2,1) .25s, transform 1.4s cubic-bezier(.2,.7,.2,1) .25s;
  -webkit-mask-image:linear-gradient(180deg,transparent 0,#000 9%,#000 91%,transparent 100%),linear-gradient(90deg,transparent 0,#000 4%,#000 96%,transparent 100%);
  -webkit-mask-composite:source-in;
  mask-image:linear-gradient(180deg,transparent 0,#000 9%,#000 91%,transparent 100%),linear-gradient(90deg,transparent 0,#000 4%,#000 96%,transparent 100%);
  mask-composite:intersect;}
.hero-art.in{opacity:1;transform:none}
[data-theme="dark"] .hero-art{mix-blend-mode:screen;filter:invert(1) hue-rotate(180deg) saturate(0.85)}
.ft-logo{height:76px;width:auto;display:block;margin:0 auto 16px}

.md-peps{margin-top:14px;border-top:1px solid var(--rule);padding-top:10px;max-height:240px;overflow:auto}
.md-pep{padding:6px 0;border-bottom:1px dashed var(--rule);font-size:13.5px;line-height:1.4}
.md-pep b{display:block}
.md-pep span{color:var(--ink-3);font-size:12px}

/* ---------- conversor ---------- */
.conv{background:var(--card);border:1px solid var(--rule);border-radius:14px;box-shadow:var(--shadow-1);padding:28px;margin-top:30px}
.conv select{font-family:var(--mono);font-size:13px;padding:10px 14px;border:1px solid var(--rule);border-radius:8px;background:var(--paper);color:var(--ink);max-width:100%}
.conv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
@media(max-width:760px){.conv-grid{grid-template-columns:1fr}}
.conv-card{background:var(--paper-2);border-radius:10px;padding:18px;text-align:center}
.conv-v{font-family:var(--serif);font-size:clamp(26px,3vw,38px);color:var(--accent);font-weight:600}
.conv-l{font-size:12.5px;color:var(--ink-3);margin-top:4px;line-height:1.4}
/* ---------- ruta del dólar ---------- */
.ruta{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:26px}
@media(max-width:860px){.ruta{grid-template-columns:repeat(2,1fr)}}
.ruta-st{background:var(--card);border:1px solid var(--rule);border-radius:10px;padding:14px 12px;cursor:pointer;text-align:center;transition:all .2s;position:relative}
.ruta-st:hover{transform:translateY(-2px)}
.ruta-st.on{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in oklab,var(--accent) 30%,transparent)}
.ruta-st .rn{font-family:var(--mono);font-size:10px;color:var(--accent);letter-spacing:.1em}
.ruta-st .rt{font-size:13.5px;font-weight:600;margin-top:4px;line-height:1.25}
.ruta-det{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:22px 26px;margin-top:14px;min-height:96px}
.ruta-det .label{color:var(--accent)}

/* ---------- contador del robo ---------- */
.robo{background:linear-gradient(135deg,#1a0f0c,#3a1410);border-radius:16px;padding:38px 32px;margin:8px 0 26px;text-align:center;color:#f7f4f0;position:relative;overflow:hidden}
.robo:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(184,28,28,.25),transparent 60%)}
.robo-l{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#E8836A;position:relative}
.robo-n{font-family:var(--serif);font-size:clamp(40px,8vw,82px);line-height:1;font-weight:600;color:#fff;margin:10px 0 4px;position:relative;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.robo-u{font-family:var(--mono);font-size:13px;color:rgba(247,244,240,.7);position:relative}
.robo-sub{font-size:14px;color:rgba(247,244,240,.85);margin-top:16px;position:relative;line-height:1.6}
.robo-eq{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px;position:relative}
@media(max-width:640px){.robo-eq{grid-template-columns:1fr}}
.robo-eq div{background:rgba(247,244,240,.06);border:1px solid rgba(247,244,240,.12);border-radius:10px;padding:14px}
.robo-eq b{display:block;font-family:var(--serif);font-size:22px;color:#E8836A}
.robo-eq span{font-size:12px;color:rgba(247,244,240,.7);line-height:1.4}
/* hero robo badge */
.hero-robo{display:inline-flex;align-items:center;gap:10px;background:color-mix(in oklab,var(--accent) 14%,transparent);border:1px solid color-mix(in oklab,var(--accent) 40%,transparent);border-radius:999px;padding:8px 16px;margin:0 0 22px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--accent)}
.hero-robo b{font-family:var(--serif);font-size:16px;font-weight:600}
