/* La Ferreteria Diario — Calcado de La Derecha Diario, azul -> GRAFITO (#0C0E1B, fondo del logo). */
/* Fuentes de diario: titulares Libre Franklin 700/800, cuerpo Source Serif 4 400/600. */
@import url("https://fonts.googleapis.com/css2?family=Libre+Franklin:wght@400;700;800&family=Source+Serif+4:ital,wght@0,400;0,600;1,400&display=swap");
:root{
  --grafito:#0c0e1b; --grafito-2:#14172a; --grafito-3:#222843;
  --rojo:#e01f2d; --rojo-2:#b3141f; --rojo-ink:#fff;
  --bg:#ffffff; --bg-2:#f3f4f6; --surface:#ffffff; --border:#e4e6ea;
  --text:#14161c; --text-dim:#586172; --text-faint:#4a5568;
  --sem-verde:#1f9d5a; --sem-amarillo:#c8881a; --sem-rojo:#d32f3a; --sem-gris:#8a9199;
  --wrap:1200px; --radius:10px;
  /* Sistema tipografico (spec): head=titulares, body=lectura serif, ui=chrome/meta */
  --font-head:"Libre Franklin",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --font-body:"Source Serif 4",Georgia,"Times New Roman",serif;
  --font-ui:"Libre Franklin",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --read:720px; /* ancho de columna de lectura */
  --font:var(--font-ui); /* compat: el viejo --font ahora apunta a la UI */
}
:root[data-theme="dark"]{
  --bg:#0c0e1b; --bg-2:#0f1221; --surface:#14172a; --border:#232844;
  --text:#eef0f6; --text-dim:#a6adbf; --text-faint:#8a92ad;
  --sem-verde:#37b576; --sem-amarillo:#e0a72a; --sem-rojo:#ef5a52;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 18px}
a:focus-visible,button:focus-visible{outline:2px solid var(--rojo);outline-offset:2px}
.ncard:focus-visible,.mini:focus-visible,.lead:focus-visible{box-shadow:0 0 0 4px rgba(224,31,45,.22)}

.topbar{background:var(--grafito);color:#fff;position:sticky;top:0;z-index:50}
.topbar-in{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;max-width:var(--wrap);margin:0 auto;padding:10px 18px}
.hamb{justify-self:start;background:none;border:none;color:#fff;font-size:22px;cursor:pointer;width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;padding:0}
.brand{justify-self:center;display:flex;align-items:center;gap:11px}
.brand img{width:40px;height:40px;border-radius:8px}
.brand .wm{display:flex;flex-direction:column;line-height:1}
.brand .wm b{font-size:21px;font-weight:800;letter-spacing:3px}
.brand .wm span{font-size:10px;letter-spacing:6px;color:#c9ccd6;margin-top:3px}
.actions{justify-self:end;display:flex;align-items:center;gap:10px}
.lang{background:none;border:none;color:#fff;font-weight:700;font-size:13px;cursor:pointer;opacity:.85}
.socials{display:flex;gap:7px}
.socials a{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;opacity:.92}
.socials a:hover{color:var(--rojo);opacity:1}
.socials svg{width:16px;height:16px;fill:currentColor}
.toggle{width:56px;height:30px;border-radius:20px;border:1px solid #ffffff33;background:#ffffff1a;cursor:pointer;position:relative;flex:none}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:.2s}
:root[data-theme="dark"] .toggle::after{left:29px;background:#0c0e1b}

.nav{background:var(--grafito);border-top:1px solid #ffffff14;border-bottom:2px solid var(--rojo)}
.nav-in{display:flex;gap:2px;justify-content:center;flex-wrap:wrap;max-width:var(--wrap);margin:0 auto;padding:0 18px}
.nav a{color:#dfe2ea;font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:11px 12px;border-bottom:3px solid transparent;margin-bottom:-3px;white-space:nowrap}
.nav a:hover{color:#fff}
.nav a.active{color:#fff;border-bottom-color:var(--rojo)}
.nav a.tv{color:#fff;display:inline-flex;align-items:center;gap:6px}
.nav a.tv svg{width:15px;height:15px;fill:var(--rojo)}

.scrim{position:fixed;inset:0;background:#0008;opacity:0;visibility:hidden;transition:.2s;z-index:60}
.scrim.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;left:0;height:100%;width:300px;max-width:84vw;background:var(--grafito);color:#fff;transform:translateX(-100%);transition:.25s;z-index:61;overflow-y:auto;border-right:2px solid var(--rojo)}
.drawer.open{transform:translateX(0)}
.drawer .dh{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid #ffffff1a}
.drawer .dh b{letter-spacing:2px;font-size:14px}
.drawer .dc{background:none;border:none;color:#fff;font-size:24px;cursor:pointer}
.drawer a{display:block;padding:13px 18px;color:#e7e9f0;font-weight:700;font-size:14px;border-bottom:1px solid #ffffff10}
.drawer a:hover{background:#ffffff10;box-shadow:inset 4px 0 0 var(--rojo)}
.drawer .grp{padding:14px 18px 6px;font-size:11px;letter-spacing:1.5px;color:#8990a8;text-transform:uppercase}

main{padding:22px 0 40px;min-height:60vh}
.hero{display:grid;grid-template-columns:1.7fr 1.2fr .9fr;gap:20px;margin-bottom:30px}
.lead{cursor:pointer}
.lead .tile{aspect-ratio:16/9;border-radius:var(--radius)}
.lead .photo{aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;background:var(--bg-2);position:relative}
.lead .photo img{width:100%;height:100%;object-fit:cover;display:block}
.lead h1{font-family:var(--font-head);font-size:44px;line-height:1.08;margin:12px 0 8px;font-weight:800;letter-spacing:-.01em}
.lead p{margin:0;color:var(--text-dim);font-family:var(--font-body);font-size:17px;line-height:1.5}
.sec-list{display:flex;flex-direction:column;gap:14px}
.mini{display:grid;grid-template-columns:104px 1fr;gap:11px;cursor:pointer}
.mini .tile{aspect-ratio:1/1;border-radius:8px}
.mini .photo{aspect-ratio:1/1;border-radius:8px;overflow:hidden;background:var(--bg-2);position:relative}
.mini .photo img{width:100%;height:100%;object-fit:cover;display:block}
.mini h3{margin:0;font-family:var(--font-head);font-size:18px;line-height:1.25;font-weight:700}
.mini .tag{margin-bottom:4px}
.rail{display:flex;flex-direction:column;gap:16px}

.tile{position:relative;background:var(--grafito);overflow:hidden;display:flex;align-items:flex-end;color:#fff}
.tile .big{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:46px;opacity:.20}
.tile.feat .big{font-size:84px}
.tile .lbl{position:relative;padding:10px 12px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;font-size:13px;text-shadow:0 1px 4px #0008}
.tile .dot{position:absolute;top:9px;left:9px}

/* helper photo() — foto real con semaforo encima (reemplaza cajas negras .tile) */
.photo{position:relative;overflow:hidden;background:var(--bg-2)}
.photo img{width:100%;height:100%;object-fit:cover;display:block}
.photo .dot{position:absolute;top:9px;left:9px;z-index:2}

.tag{display:inline-block;background:var(--rojo);color:#fff;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;padding:3px 8px;border-radius:3px}
.dot{width:11px;height:11px;border-radius:50%;display:inline-block;flex:none;box-shadow:0 0 0 2px #ffffff55}
.dot.verde{background:var(--sem-verde)} .dot.amarillo{background:var(--sem-amarillo)}
.dot.rojo{background:var(--sem-rojo)} .dot.gris{background:var(--sem-gris)}

.widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.widget h4{margin:0 0 12px;font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--text-faint);border-left:3px solid var(--rojo);padding-left:8px}
.panel-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px dashed var(--border);font-size:14px}
.panel-row:last-child{border-bottom:none}
.sponsor{background:var(--grafito);color:#fff;border-radius:var(--radius);padding:22px 16px;text-align:center}
.sponsor .big{font-size:30px} .sponsor p{margin:6px 0 12px;color:#c9ccd6;font-size:13px}

.sec-block{margin:34px 0}
.sec-head{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--grafito);margin-bottom:16px;padding-bottom:6px}
.sec-head h2{margin:0;font-family:var(--font-head);font-size:22px;line-height:1.2;font-weight:800;text-transform:uppercase;letter-spacing:.5px;position:relative;padding-left:12px}
.sec-head h2::before{content:"";position:absolute;left:0;top:2px;bottom:2px;width:5px;background:var(--rojo)}
.sec-head a{color:var(--rojo);font-weight:800;font-size:12.5px;text-transform:uppercase}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.ncard{cursor:pointer}
.ncard .tile{aspect-ratio:16/10;border-radius:9px;margin-bottom:9px}
.ncard .photo{aspect-ratio:16/10;border-radius:9px;overflow:hidden;background:var(--bg-2);margin-bottom:10px}
.ncard .photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.ncard:hover .photo img{transform:scale(1.04)}
.ncard .tag{margin-bottom:6px}
.ncard h3{margin:0;font-family:var(--font-head);font-size:18px;line-height:1.25;font-weight:700}
.ncard p{margin:6px 0 0;color:var(--text-dim);font-family:var(--font-body);font-size:15px;line-height:1.45}
.ncard .meta{margin-top:8px;display:flex;align-items:center;gap:7px;color:var(--text-faint);font-family:var(--font-ui);font-size:12px}

.btn-red{display:inline-flex;align-items:center;gap:8px;background:var(--rojo);color:#fff;font-weight:800;padding:11px 20px;border-radius:8px;border:none;cursor:pointer;font-size:14px}
.btn-red:hover{background:var(--rojo-2)}
.btn-yt{display:inline-flex;align-items:center;gap:9px;background:var(--grafito);color:#fff;font-weight:700;padding:10px 18px;border-radius:8px;font-size:14px;border:1px solid var(--grafito-3)}
.btn-yt svg{width:20px;height:20px;fill:var(--rojo)}

.tv-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:6px 0 22px;flex-wrap:wrap}
.tv-head .ttl{display:flex;align-items:center;gap:12px}
.tv-head .ttl svg{width:38px;height:38px;fill:var(--rojo)}
.tv-head h1{margin:0;font-size:28px;font-weight:800}
.tv-feature{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;margin-bottom:30px}
.vid{cursor:pointer}
.vid .frame{position:relative;border-radius:10px;overflow:hidden;background:var(--grafito-2);aspect-ratio:16/9;display:flex;align-items:flex-end}
.vid .frame .play{position:absolute;inset:0;margin:auto;width:56px;height:56px;border-radius:50%;background:#000a;display:flex;align-items:center;justify-content:center}
.vid .frame .play svg{width:24px;height:24px;fill:#fff;margin-left:3px}
.vid .frame .wmk{position:absolute;top:10px;left:12px;font-weight:800;letter-spacing:1px;font-size:12px;color:#ffffffcc}
.vid .frame .cap{position:relative;padding:14px;color:#fff;font-weight:800;font-size:17px;text-shadow:0 1px 6px #000a;background:linear-gradient(transparent,#000000aa)}
.vid h3{margin:9px 0 0;font-size:15px;line-height:1.25}
.vid .ch{margin-top:4px;color:var(--text-faint);font-size:12.5px;display:flex;align-items:center;gap:6px}
.vid .ch svg{width:16px;height:16px;fill:var(--rojo)}
.tv-side{display:grid;grid-template-rows:repeat(4,1fr);gap:12px}
.tv-side .vid{display:grid;grid-template-columns:150px 1fr;gap:10px;align-items:start}
.tv-side .vid h3{margin:0;font-size:13.5px}
.shorts-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.short{cursor:pointer}
.short .frame{position:relative;border-radius:10px;overflow:hidden;background:var(--grafito);aspect-ratio:9/16;display:flex;align-items:flex-end}
.short .frame .big{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:54px;opacity:.18}
.short .frame .wmk{position:absolute;top:9px;left:0;right:0;text-align:center;font-weight:800;letter-spacing:1px;font-size:10px;color:#ffffffcc}
.short .frame .play{position:absolute;inset:0;margin:auto;width:42px;height:42px;border-radius:50%;background:var(--rojo);display:flex;align-items:center;justify-content:center}
.short .frame .play svg{width:18px;height:18px;fill:#fff;margin-left:2px}
.short .frame .cap{position:relative;padding:10px;color:#fff;font-weight:800;font-size:12.5px;text-shadow:0 1px 5px #000;background:linear-gradient(transparent,#000000cc)}

.footer{background:var(--grafito);color:#fff;margin-top:44px;padding:36px 0 26px}
.footer-cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:24px}
.footer .fbrand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.footer .fbrand img{width:46px;height:46px;border-radius:9px}
.footer .fbrand b{font-size:19px;letter-spacing:2px;font-weight:800}
.footer .fsoc{display:flex;gap:10px;margin:12px 0}
.footer .fsoc a{color:#fff;opacity:.85} .footer .fsoc a:hover{color:var(--rojo)}
.footer .fsoc svg{width:18px;height:18px;fill:currentColor}
.footer h4{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:#8a90a8;margin:0 0 12px}
.footer a.fl{display:block;color:#cfd2dc;padding:5px 0;font-size:14px} .footer a.fl:hover{color:#fff}
.footer .ytpill{display:inline-flex;align-items:center;gap:8px;background:#000;border:1px solid #ffffff22;color:#fff;padding:8px 14px;border-radius:20px;font-size:13px;font-weight:700;margin-top:6px}
.footer .ytpill svg{width:18px;height:18px;fill:var(--rojo)}
.footer .legal{border-top:1px solid #ffffff1a;margin-top:24px;padding-top:16px;color:#8a90a8;font-size:12.5px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.fuentes{color:#8a90a8;font-size:12px;margin-top:8px}

@media(max-width:1000px){
  .hero{grid-template-columns:1fr 1fr}.rail{grid-column:1 / -1;flex-direction:row}
  .cards{grid-template-columns:repeat(2,1fr)}.shorts-grid{grid-template-columns:repeat(3,1fr)}
  .tv-feature{grid-template-columns:1fr}.footer-cols{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .nav{display:none}.hero{grid-template-columns:1fr}.rail{flex-direction:column}
  .cards{grid-template-columns:1fr 1fr}.shorts-grid{grid-template-columns:repeat(2,1fr)}
  .tv-side .vid{grid-template-columns:120px 1fr}.footer-cols{grid-template-columns:1fr}
  .brand .wm b{font-size:16px;letter-spacing:1.5px}.brand .wm span{display:none}.socials{display:none}
}
/* ===== HUB / SECCION ===== */
.hub-head{border-bottom:3px solid var(--rojo);margin:4px 0 20px;padding-bottom:8px}
.hub-head h1{margin:0;font-family:var(--font-head);font-size:30px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}
.hub-head p{margin:6px 0 0;color:var(--text-dim);font-family:var(--font-body);font-size:16px;line-height:1.5;max-width:760px}
.related{margin-top:34px}
.related h2,.related .sec-head h2{font-family:var(--font-head)}
/* ===== ARTICULO ===== */
.back{color:var(--text-dim);font-family:var(--font-ui);font-size:13px;font-weight:700;display:inline-block;margin-bottom:12px}
.art{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:40px;align-items:start;max-width:1140px;margin:0 auto}
.art-main{max-width:820px}
.art-main h1{font-family:var(--font-head);font-size:44px;line-height:1.12;font-weight:800;margin:6px 0 14px;letter-spacing:-.01em}
.lede{font-family:var(--font-body);font-size:21px;line-height:1.5;color:var(--text);margin:0 0 24px;max-width:var(--read)}
.art-hero{aspect-ratio:16/8;border-radius:10px;margin:14px 0 18px}
.art-meta{display:flex;align-items:center;gap:10px;color:var(--text-faint);font-family:var(--font-ui);font-size:13.5px;margin-bottom:4px}

/* kicker / categoria de nota (pill oscura como la referencia) */
.kicker{display:inline-block;background:var(--grafito);color:#fff;font-family:var(--font-ui);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;padding:6px 12px;border-radius:4px;margin-bottom:8px;text-decoration:none;transition:background .15s}
a.kicker:hover{background:var(--rojo)}

/* autoria */
.byline{display:flex;align-items:center;gap:12px;margin:8px 0 14px}
.byline .avatar{width:44px;height:44px;border-radius:50%;background:var(--grafito);flex:none;display:flex;align-items:center;justify-content:center;overflow:hidden}
.byline .avatar img{width:100%;height:100%;object-fit:cover}
.byline .who b{font-family:var(--font-ui);font-size:14px;font-weight:700}
.byline .who .date{display:block;font-family:var(--font-ui);font-size:13px;color:var(--text-faint);margin-top:2px}
.byline .cat{margin-left:auto;background:var(--grafito);color:#fff;font-family:var(--font-ui);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;padding:8px 14px;border-radius:4px}

/* compartir */
.share{display:flex;align-items:center;gap:10px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:12px 0;margin:0 0 22px;max-width:var(--read)}
.share .lbl{font-family:var(--font-ui);font-size:13px;font-weight:700;color:var(--text-dim)}
.share a{width:34px;height:34px;border-radius:50%;background:var(--bg-2);display:flex;align-items:center;justify-content:center;color:var(--text-dim)}
.share a:hover{background:var(--rojo);color:#fff}
.share svg{width:16px;height:16px;fill:currentColor}
.share .native-share{width:34px;height:34px;border-radius:50%;background:var(--bg-2);border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-dim)}
.share .native-share:hover{background:var(--rojo);color:#fff}
.buscador{display:flex;gap:8px;max-width:var(--read);margin:0 0 22px}
.buscador input{flex:1;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg-2);color:inherit;font-size:16px;font-family:var(--font-body)}
.srch{display:inline-flex;align-items:center}
.srch svg{width:20px;height:20px;fill:currentColor}
.sub-cta{display:flex;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap;background:var(--grafito);color:#fff;border:1px solid rgba(255,255,255,.08);border-left:4px solid var(--rojo);border-radius:12px;padding:22px 24px;margin:30px 0}
.sub-cta-tx b{font-family:var(--font-head);font-size:19px;display:block;color:#fff}
.sub-cta-tx p{margin:5px 0 0;color:rgba(255,255,255,.82);font-size:14.5px;max-width:48ch}
.sub-cta .btn-red{white-space:nowrap;flex:none}
.nl-hero{margin:6px 0 26px}
.nl-hero-in{display:flex;gap:20px;align-items:center;justify-content:space-between;flex-wrap:wrap;background:var(--grafito);color:#fff;border-radius:14px;padding:26px 28px;border-left:5px solid var(--rojo)}
.nl-hero-tx h2{margin:0;font-family:var(--font-head);font-size:24px;color:#fff;border:none;padding:0;line-height:1.15}
.nl-hero-tx p{margin:8px 0 0;color:rgba(255,255,255,.84);font-size:15px;max-width:62ch}
.nl-hero .btn-red{white-space:nowrap;flex:none;font-size:15px}
.bh-embed{max-width:540px;margin:8px auto 0;min-height:120px}
.marcas-tiers{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:0 0 8px}
.mtier{border:1px solid var(--border);border-radius:12px;padding:18px 20px;background:var(--bg-2)}
.mtier.destacado{border-color:var(--rojo);border-left-width:4px}
.mtier h3{margin:0 0 6px;font-family:var(--font-head)}
.mtier p{margin:0;color:var(--text-dim);font-size:14.5px}
@media(max-width:600px){.marcas-tiers{grid-template-columns:1fr}}
.tbl-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:12px;margin:4px 0}
.precios-tbl{width:100%;border-collapse:collapse;font-size:14px}
.precios-tbl th{text-align:right;padding:11px 12px;background:var(--bg-2);font-family:var(--font-ui);font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-dim)}
.precios-tbl th:first-child{text-align:left}
.precios-tbl td{padding:10px 12px;text-align:right;border-top:1px solid var(--border);white-space:nowrap}
.precios-tbl td.prod{text-align:left;white-space:normal;min-width:210px;color:var(--text)}
.precios-tbl td.min{color:var(--rojo);font-weight:800}
.precios-tbl td.sd{color:var(--text-faint)}
.precios-tbl tr.cat td{background:var(--grafito);color:#fff;font-family:var(--font-ui);font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;text-align:left;padding:8px 12px}
.calc-hint{display:inline-block;margin:6px 0 18px;padding:11px 16px;background:rgba(224,31,45,.08);border:1px solid var(--rojo);border-radius:10px;color:var(--rojo);font-weight:700;text-decoration:none}
.calc-hint:hover{background:var(--rojo);color:#fff}
.calc{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin:0 0 24px;align-items:start}
.calc-form{display:flex;flex-direction:column;gap:9px;background:transparent;border:1px solid var(--border);border-radius:12px;padding:20px}
.calc-form label{font-size:13.5px;font-weight:600;color:var(--text-dim)}
.calc-form input,.calc-form select{padding:11px 13px;border:1px solid var(--border);border-radius:8px;background:var(--bg-2);color:inherit;font-size:16px;font-family:var(--font-body)}
.calc-radios{display:flex;gap:16px;flex-wrap:wrap;margin:2px 0}
.calc-radios label{display:flex;align-items:center;gap:6px;font-weight:500;color:inherit}
.calc-form h3{margin:0 0 2px;font-family:var(--font-head);border:none;padding:0}
.calc-form .btn-red{justify-content:center;margin-top:8px}
.calc-out{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:20px;min-height:130px}
.calc-res{display:flex;flex-direction:column;gap:14px}
.calc-big{display:flex;flex-direction:column;gap:3px;border-left:4px solid var(--rojo);padding-left:14px}
.calc-big span{font-size:12.5px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}
.calc-big b{font-family:var(--font-head);font-size:34px;line-height:1.05}
.calc-break{display:flex;flex-direction:column;gap:5px;font-size:14.5px;color:var(--text-dim)}
.calc-res.verde .calc-big{border-color:#1a8f3c}
.calc-res.amarillo .calc-big{border-color:#c79100}
.calc-res.rojo .calc-big{border-color:var(--rojo)}
@media(max-width:720px){.calc{grid-template-columns:1fr}}

/* hero foto + epigrafe (reemplaza .tile.feat en nota) */
.art-figure{margin:0 0 8px}
.art-figure img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:10px;background:var(--bg-2)}
.art-figure figcaption{font-family:var(--font-body);font-size:13px;font-style:italic;color:var(--text-faint);padding:8px 2px 18px;max-width:var(--read);line-height:1.4}

.veredicto{background:var(--surface);border:1px solid var(--border);border-left:5px solid var(--sem-gris);border-radius:10px;padding:14px 16px;margin:16px 0;font-family:var(--font-body);font-size:16px;line-height:1.55;max-width:var(--read)}
.veredicto.verde{border-left-color:var(--sem-verde)} .veredicto.amarillo{border-left-color:var(--sem-amarillo)} .veredicto.rojo{border-left-color:var(--sem-rojo)}
.cuerpo{max-width:var(--read)}
.cuerpo h2{font-family:var(--font-head);font-size:32px;line-height:1.25;font-weight:800;margin:32px 0 12px;border-top:1px solid var(--border);padding-top:24px}
.cuerpo h3{font-family:var(--font-head);font-size:22px;line-height:1.3;font-weight:700;margin:24px 0 8px}
.cuerpo p{font-family:var(--font-body);font-size:19px;line-height:1.8;margin:0 0 18px}
.cuerpo strong{font-weight:600}
.cuerpo a{color:var(--rojo);text-decoration:underline;text-underline-offset:2px}
.cuerpo figure.inline-img{margin:22px 0}
.cuerpo figure.inline-img img{width:100%;border-radius:8px}
.cuerpo figure.inline-img figcaption{font-family:var(--font-body);font-size:13px;font-style:italic;color:var(--text-faint);margin-top:6px;line-height:1.4}

/* VIDEO embebido — SOLO en nota */
.art-video{margin:24px 0;max-width:var(--read)}
.art-video .frame{position:relative;aspect-ratio:16/9;border-radius:10px;overflow:hidden;background:#000}
.art-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.art-video figcaption{font-family:var(--font-body);font-size:13px;color:var(--text-faint);margin-top:6px}
.callout{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:16px;margin:22px 0}
.callout .lbl{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--rojo);margin-bottom:6px}
.callout.accion{border-color:var(--rojo);border-left-width:4px;background:rgba(224,31,45,.12)}
:root[data-theme="dark"] .callout.accion{background:rgba(224,31,45,.18)}
.callout.accion .lbl::before{content:"\2192\00A0"}
.read-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--rojo);z-index:200;transition:width .08s linear}
.crumbs{font-size:13px;color:var(--text-faint);margin:0 0 12px}
.crumbs a{color:inherit;text-decoration:none}
.crumbs a:hover{text-decoration:underline}
.byline .readtime{color:var(--text-faint);font-size:13px}
.byline .readtime::before{content:"\00B7\00A0"}
blockquote{margin:0 0 10px;padding:10px 16px;border-left:4px solid var(--rojo);background:var(--bg-2);border-radius:6px;font-family:var(--font-body);font-style:italic;font-size:18px;line-height:1.55;max-width:var(--read)}
.datos{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;margin:18px 0}
.datos h4{margin:0 0 12px;font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--text-faint)}
.stats{display:flex;flex-wrap:wrap;gap:10px}
.stat{background:var(--bg-2);border:1px solid var(--border);border-radius:9px;padding:9px 13px;min-width:108px}
.stat b{display:block;font-size:18px} .stat span{font-size:11.5px;color:var(--text-dim);text-transform:uppercase}
.tblwrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
table.tbl th,table.tbl td{text-align:left;padding:7px 9px;border-bottom:1px solid var(--border)}
table.tbl th{color:var(--text-faint);font-size:11px;text-transform:uppercase}
.dl .term{font-weight:800;margin-top:12px} .dl .def{color:var(--text-dim);font-size:14.5px}
.art-rail{position:sticky;top:118px;display:flex;flex-direction:column;gap:16px}
.related{margin-top:34px}
.agenda{display:flex;flex-direction:column;gap:10px}
.agenda .ev{display:flex;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px}
.agenda .date{background:var(--rojo);color:#fff;border-radius:8px;padding:8px 10px;text-align:center;font-weight:800;min-width:62px;height:fit-content}
.agenda .date b{display:block;font-size:18px} .agenda .date span{font-size:10px;text-transform:uppercase}
/* ===== SUSCRIBITE / PLACEHOLDERS ===== */
.suscribe{max-width:560px;margin:10px auto;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:30px}
.suscribe h1{margin:0 0 6px;font-size:26px} .suscribe p.sub{margin:0 0 18px;color:var(--text-dim)}
.suscribe label{display:block;font-size:13px;font-weight:700;margin:12px 0 5px}
.suscribe input,.suscribe select{width:100%;padding:11px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:14px}
.empty{text-align:center;padding:56px 20px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius)}
.empty .big{font-size:46px;margin-bottom:8px} .empty h2{margin:0 0 8px} .empty p{color:var(--text-dim);max-width:520px;margin:0 auto 16px}
.dlgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:20px}
@media(max-width:1000px){
  .art{grid-template-columns:1fr;gap:24px}
  .art-rail{position:static}
  .art-main{max-width:none}
}
@media(max-width:900px){.dlgrid{grid-template-columns:1fr}}
@media(max-width:620px){
  .art-main h1{font-size:30px;line-height:1.15}
  .lead h1{font-size:28px}
  .cuerpo p{font-size:17px;line-height:1.7}
  .lede{font-size:18px}
  .cuerpo h2{font-size:22px}
  .ncard h3{font-size:16px}
  .cards{grid-template-columns:1fr}      /* 1 columna; cards full-width con foto grande */
  .ncard .photo{aspect-ratio:16/9}       /* foto feed full-width */
  .byline .cat{display:none}             /* el kicker arriba del H1 ya cubre categoria */
  .share{flex-wrap:wrap}
}

/* ===== claro/oscuro: fotos y enlaces serif en ambos temas ===== */
:root[data-theme="dark"] .photo,
:root[data-theme="dark"] .ncard .photo,
:root[data-theme="dark"] .lead .photo,
:root[data-theme="dark"] .mini .photo,
:root[data-theme="dark"] .art-figure img,
:root[data-theme="dark"] .cuerpo figure.inline-img img{background:var(--grafito-2)}
:root[data-theme="dark"] .cuerpo a{color:var(--sem-amarillo)}
:root[data-theme="dark"] .art-figure figcaption,
:root[data-theme="dark"] .cuerpo figure figcaption{color:var(--text-faint)}
/* === fixes auditoria (52 agentes) === */
body{overflow-x:hidden}
.socials a{background:#ffffff1a;border:1px solid #ffffff22}
:root[data-theme="dark"] .toggle::after{background:#eef0f6}
:root[data-theme="dark"] .toggle{background:#ffffff33;border-color:#ffffff55}
.sec-head{border-bottom-color:var(--rojo)}
.vid .frame .play{background:var(--rojo)}
.footer .fsoc a{width:34px;height:34px;border-radius:50%;background:#ffffff15;display:inline-flex;align-items:center;justify-content:center}
.footer .ytpill{background:var(--grafito-2)}
.footer .fcol{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:#9aa0b5;margin:0 0 12px}
.footer .fcol b{font-weight:800}
.fuentes{color:var(--text-faint)}
.footer .fuentes{color:#9aa0b5}
.btn-yt:hover{background:var(--grafito-2);border-color:var(--grafito-3)}
.cta-top{padding:10px 16px;font-size:13px;white-space:nowrap;box-shadow:0 2px 6px rgba(224,31,45,.25)}
.art-main h1,.cuerpo h2{font-weight:800}
.ncard h3,.mini h3{font-weight:700}
.nav a.tv svg,.drawer a.tv svg{fill:var(--rojo);width:15px;height:15px;vertical-align:middle;margin-right:5px}
.drawer a.tv{color:#fff}
@media(max-width:620px){
  .topbar-in{grid-template-columns:auto 1fr auto}
  .lang,.cta-top{display:none}
}
@media(prefers-reduced-motion:reduce){.drawer,.scrim,.toggle::after,.card,.ncard{transition:none!important}}
