/* ============================================================
   ONIGIRI · Blog (Recursos) — editorial, Ghost / Fintualist style
   ============================================================ */
:root{
  --red:#E0312A; --red-deep:#BC1F1A; --red-tint:#FCEAE9; --red-tint-2:#F8DAD8;
  --bg:#FFFFFF; --bg-2:#F7F6F4; --bg-3:#F0EEEB;
  --ink:#16161A; --ink-2:#56565E; --ink-3:#8C8C95; --ink-4:#B6B6BD;
  --line:#E9E7E3; --line-2:#DEDCD7; --paper:#0F0F12;
  --shadow-sm:0 1px 2px rgba(20,20,22,.04),0 1px 3px rgba(20,20,22,.05);
  --shadow-md:0 8px 28px rgba(20,20,22,.07),0 2px 8px rgba(20,20,22,.05);
  --shadow-lg:0 28px 70px rgba(20,20,22,.14),0 8px 24px rgba(20,20,22,.08);
  --f-ui:'Zen Kaku Gothic New',-apple-system,BlinkMacSystemFont,sans-serif;
  --f-round:'Fredoka',var(--f-ui);
  --f-serif:'Newsreader',Georgia,'Times New Roman',serif;
  --f-mono:'JetBrains Mono',ui-monospace,monospace;
  --r-xl:24px; --r-lg:18px; --r-md:12px; --r-pill:999px;
  --maxw:1180px; --read:720px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0}
body{background:var(--bg);color:var(--ink);font-family:var(--f-ui);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{max-width:100%;display:block}
::selection{background:var(--red-tint-2)}
.mono{font-family:var(--f-mono);font-variant-numeric:tabular-nums}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- nav (unificado con el landing) ---------- */
.nav{position:sticky;top:0;left:0;right:0;z-index:60;transition:background .3s,box-shadow .3s,border-color .3s}
.nav.scrolled{background:color-mix(in srgb,var(--bg) 82%,transparent);backdrop-filter:blur(14px) saturate(1.4);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;gap:26px;max-width:var(--maxw);margin:0 auto;padding:18px 28px;transition:padding .3s}
.nav.scrolled .nav-inner{padding:12px 28px}
.brand{display:flex;align-items:center;gap:11px;cursor:pointer}
.brand .wm{font-family:var(--f-round);font-weight:600;font-size:23px;letter-spacing:-.01em;line-height:1}
.brand .wm small{display:block;font-family:var(--f-ui);font-weight:500;font-size:8.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);margin-top:4px}
.nav-links{display:flex;gap:2px;margin-left:14px;align-items:center}
.nav-links a,.nav-link{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;border-radius:var(--r-pill);font-weight:600;font-size:14.5px;color:var(--ink-2);transition:background .15s,color .15s;cursor:pointer;background:none;border:none;font-family:inherit;line-height:1}
.nav-links a:hover,.nav-link:hover{background:var(--bg-2);color:var(--ink)}
.nav-links a.on{color:var(--red);background:var(--red-tint)}
.nav-link .cz{width:13px;height:13px;transition:transform .2s;color:var(--ink-4)}
.nav-item{position:relative}
.nav-item:hover .cz{transform:rotate(180deg)}
.nav-menu{position:absolute;top:calc(100% + 9px);left:0;min-width:270px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:8px;opacity:0;visibility:hidden;transform:translateY(7px);transition:opacity .18s,transform .18s,visibility .18s;z-index:70}
.nav-menu::before{content:"";position:absolute;top:-11px;left:0;right:0;height:11px}
.nav-item:hover .nav-menu{opacity:1;visibility:visible;transform:none}
.nav-menu a{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;border-radius:var(--r-md);transition:background .14s;text-align:left}
.nav-menu a:hover{background:var(--bg-2)}
.nav-menu a b{font-weight:700;font-size:14px;color:var(--ink)}
.nav-menu a span{font-size:12.5px;color:var(--ink-3);font-weight:500}
.nav-spacer{flex:1}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav .btn{padding:11px 18px;font-size:14.5px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--r-pill);font-weight:700;
  font-size:14.5px;padding:11px 18px;transition:transform .14s,background .16s,box-shadow .18s,border-color .16s;white-space:nowrap;line-height:1}
.btn:active{transform:scale(.97)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 4px 14px rgba(224,49,42,.25)}
.btn-red:hover{background:var(--red-deep);transform:translateY(-1px)}
.btn-ghost{background:var(--bg);color:var(--ink);border:1.5px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--ink);background:var(--bg-2)}
.btn-lg{padding:15px 26px;font-size:16px}

/* mascota (idéntica al landing) */
.oni-mark{display:block;flex:none;overflow:visible}
.oni-mark .food,.oni-mark .spark{opacity:0}
.oni-mark .mouth,.oni-mark .cheeks,.oni-mark .eyes,.oni-mark .food,.oni-mark .spark{transform-box:fill-box;transform-origin:center}
.brand:hover .oni-mark .food{animation:oniEat 1.5s ease-in-out infinite}
.brand:hover .oni-mark .mouth{animation:oniChew .26s ease-in-out infinite}
.brand:hover .oni-mark .cheeks{animation:oniPuff .5s ease-in-out infinite alternate}
.brand:hover .oni-mark .eyes{animation:oniSquint .5s ease-in-out infinite alternate}
.brand:hover .oni-mark .spark{animation:oniSpark 1.5s ease-in-out infinite}
@keyframes oniEat{0%{opacity:0;transform:translate(56px,-8px) scale(.85) rotate(-10deg)}11%{opacity:1}44%{opacity:1;transform:translate(0,1px) scale(1) rotate(0)}56%{transform:translate(0,3px) scale(.5)}63%{opacity:1;transform:translate(0,3px) scale(.12)}66%{opacity:0}100%{opacity:0}}
@keyframes oniChew{0%,100%{transform:scaleY(1)}50%{transform:scaleY(2) translateY(1px)}}
@keyframes oniPuff{from{transform:scale(1)}to{transform:scale(1.22)}}
@keyframes oniSquint{from{transform:scaleY(1)}to{transform:scaleY(.82)}}
@keyframes oniSpark{0%,55%{opacity:0;transform:scale(.3)}64%{opacity:1;transform:scale(1.1)}76%{opacity:0;transform:scale(1.4)}100%{opacity:0}}
@media (prefers-reduced-motion:reduce){.oni-mark *{animation:none!important}}

/* toggle de tema (idéntico al landing) */
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;flex:none;
  border-radius:var(--r-pill);border:1.5px solid var(--line-2);background:var(--bg);color:var(--ink-2);
  transition:transform .14s cubic-bezier(.2,.7,.3,1),background .16s,border-color .16s,color .16s}
.theme-toggle:hover{border-color:var(--ink);color:var(--ink);background:var(--bg-2)}
.theme-toggle:active{transform:scale(.93)}
.theme-toggle svg{display:block}
.theme-toggle .ic-sun{display:none}
html.dark .theme-toggle .ic-moon{display:none}
html.dark .theme-toggle .ic-sun{display:block}

/* ---------- masthead ---------- */
.masthead{padding:64px 0 30px;text-align:center;border-bottom:1px solid var(--line)}
.masthead .eyebrow{font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin:0 0 14px}
.masthead h1{font-weight:900;font-size:clamp(38px,5vw,60px);letter-spacing:-.035em;line-height:1.02;margin:0}
.masthead p{font-size:18px;color:var(--ink-2);margin:16px auto 0;max-width:54ch}
.cats{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.cat{font-weight:600;font-size:13.5px;color:var(--ink-2);background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--r-pill);padding:8px 16px;transition:all .15s;cursor:pointer}
.cat:hover{border-color:var(--ink-4);color:var(--ink)}
.cat.on{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---------- tag chip ---------- */
.tag{display:inline-flex;align-items:center;font-weight:700;font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--red-deep);background:var(--red-tint);border-radius:var(--r-pill);padding:5px 11px;white-space:nowrap}

/* ---------- featured ---------- */
.featured{padding:54px 0}
.featured a.card-link{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.featured image-slot,.featured .imgph{width:100%;height:380px;border-radius:var(--r-xl);box-shadow:var(--shadow-md)}
.featured .meta-top{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.featured .read{font-family:var(--f-mono);font-size:12px;color:var(--ink-3);font-weight:600}
.featured h2{font-weight:900;font-size:clamp(28px,3.4vw,42px);letter-spacing:-.03em;line-height:1.06;margin:0;transition:color .15s}
.featured a.card-link:hover h2{color:var(--red-deep)}
.featured .dek{font-size:18px;color:var(--ink-2);line-height:1.55;margin:16px 0 0;max-width:48ch}

/* ---------- author row ---------- */
.byline{display:flex;align-items:center;gap:11px;margin-top:22px}
.avatar{width:38px;height:38px;border-radius:var(--r-pill);background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:14px;flex:none;overflow:hidden}
.avatar.r{background:var(--red)} .avatar.b{background:#2A2A30}
.byline .who{line-height:1.3}
.byline .who b{font-weight:700;font-size:14px}
.byline .who span{display:block;font-size:12.5px;color:var(--ink-3)}

/* ---------- grid ---------- */
.section-h{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:8px 0 26px}
.section-h h3{font-weight:900;font-size:22px;letter-spacing:-.02em;margin:0}
.section-h a{font-weight:700;font-size:14px;color:var(--red-deep)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 26px;padding-bottom:30px}
.post{display:flex;flex-direction:column}
.post .thumb{width:100%;height:200px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:16px}
.post image-slot,.post .imgph{width:100%;height:200px;border-radius:var(--r-lg)}
.post .pmeta{display:flex;align-items:center;gap:10px;margin-bottom:11px}
.post .read{font-family:var(--f-mono);font-size:11.5px;color:var(--ink-4);font-weight:600}
.post h4{font-weight:800;font-size:19px;letter-spacing:-.02em;line-height:1.22;margin:0;transition:color .15s}
.post a.card-link:hover h4{color:var(--red-deep)}
.post .ex{font-size:14.5px;color:var(--ink-2);line-height:1.5;margin:9px 0 0}
.post .byline{margin-top:14px}
.post .avatar{width:30px;height:30px;font-size:12px}

/* image placeholder (duotone) */
.imgph{position:relative;background:linear-gradient(135deg,var(--c1,#16161A),var(--c2,#3a3a44));overflow:hidden;display:flex;align-items:flex-end;padding:16px}
.imgph::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.1) 1px,transparent 1px);background-size:16px 16px;opacity:.5}
.imgph svg{position:absolute;right:14px;top:14px;width:30px;height:30px;color:rgba(255,255,255,.7)}
.imgph .lab{position:relative;color:rgba(255,255,255,.92);font-weight:800;font-size:15px;letter-spacing:-.01em;max-width:80%;line-height:1.2}

/* ---------- newsletter ---------- */
.news{margin:40px 0 70px;background:var(--ink);color:#fff;border-radius:var(--r-xl);padding:48px 40px;position:relative;overflow:hidden}
.news::after{content:"";position:absolute;top:-120px;right:-90px;width:340px;height:340px;border-radius:50%;background:rgba(224,49,42,.18)}
.news-in{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
.news .eyebrow{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#FF6B64;margin:0 0 12px}
.news h3{font-weight:900;font-size:clamp(24px,2.8vw,32px);letter-spacing:-.02em;line-height:1.1;margin:0}
.news p{color:#B9B9C0;font-size:15.5px;margin:12px 0 0;max-width:42ch}
.news form{display:flex;gap:10px;flex-wrap:wrap}
.news input{flex:1;min-width:180px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:var(--r-pill);
  padding:14px 18px;color:#fff;font-family:inherit;font-size:15px}
.news input::placeholder{color:#85858E}
.news input:focus{outline:none;border-color:#FF6B64}
.news .fine{font-size:12px;color:#85858E;margin-top:10px}

/* ---------- footer ---------- */
.footer{background:var(--paper);color:#9A9AA2;padding:54px 0 34px}
.footer .ft{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer .wm{font-family:var(--f-round);font-weight:600;font-size:22px;color:#fff;display:flex;align-items:center;gap:11px}
.footer .fnav{display:flex;gap:20px;flex-wrap:wrap}
.footer .fnav a{font-size:14px;color:#C2C2C9;font-weight:600}
.footer .fnav a:hover{color:#fff}
.footer .cc{margin-top:26px;padding-top:22px;border-top:1px solid rgba(255,255,255,.09);font-size:13px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* ============================================================
   ARTICLE (post) page
   ============================================================ */
.art-wrap{max-width:var(--read);margin:0 auto;padding:0 28px}
.art-head{padding:54px 0 0;text-align:center}
.crumbs{font-family:var(--f-mono);font-size:12.5px;color:var(--ink-3);display:flex;gap:8px;justify-content:center;margin-bottom:22px}
.crumbs a:hover{color:var(--red-deep)}
.art-head h1{font-weight:900;font-size:clamp(32px,4.6vw,52px);letter-spacing:-.035em;line-height:1.04;margin:18px 0 0;text-wrap:balance}
.art-head .dek{font-family:var(--f-serif);font-size:clamp(19px,2vw,23px);line-height:1.5;color:var(--ink-2);margin:20px auto 0;max-width:50ch;font-weight:400}
.art-head .byline{justify-content:center;margin-top:28px}
.art-hero{max-width:1040px;margin:38px auto 0;padding:0 28px}
.art-hero image-slot,.art-hero .imgph{width:100%;height:clamp(280px,42vw,500px);border-radius:var(--r-xl);box-shadow:var(--shadow-md)}

/* prose */
.prose{font-family:var(--f-serif);font-size:20px;line-height:1.72;color:#23232a;margin-top:44px}
.prose>p{margin:0 0 26px}
.prose>p:first-of-type::first-letter{font-weight:700}
.prose .lead{font-size:23px;line-height:1.55;color:var(--ink)}
.prose h2{font-family:var(--f-ui);font-weight:900;font-size:28px;letter-spacing:-.025em;line-height:1.15;margin:46px 0 16px;color:var(--ink)}
.prose h3{font-family:var(--f-ui);font-weight:800;font-size:21px;letter-spacing:-.02em;margin:36px 0 12px;color:var(--ink)}
.prose a{color:var(--red-deep);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
.prose strong{font-weight:700;color:var(--ink)}
.prose ul,.prose ol{margin:0 0 26px;padding-left:26px}
.prose li{margin:9px 0}
.prose li::marker{color:var(--red)}
.prose blockquote{margin:34px 0;padding:6px 0 6px 26px;border-left:3px solid var(--red);
  font-weight:600;font-size:25px;line-height:1.4;color:var(--ink);letter-spacing:-.01em}
.prose figure{margin:36px 0}
.prose figure image-slot,.prose figure .imgph{width:100%;height:clamp(240px,36vw,380px);border-radius:var(--r-lg)}
.prose figcaption{font-family:var(--f-ui);font-size:13px;color:var(--ink-3);margin-top:10px;text-align:center}
.callout{font-family:var(--f-ui);background:var(--red-tint);border:1px solid var(--red-tint-2);border-radius:var(--r-lg);
  padding:22px 24px;margin:34px 0;font-size:16.5px;line-height:1.55;color:var(--ink)}
.callout .k{display:block;font-size:11.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--red-deep);margin-bottom:8px}
.callout b{font-weight:800}
.def{font-family:var(--f-ui);background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 22px;margin:30px 0;font-size:15.5px;line-height:1.55;color:var(--ink-2)}
.def b{color:var(--ink);font-weight:800}

/* article footer bits */
.art-foot{max-width:var(--read);margin:50px auto 0;padding:0 28px}
.share{display:flex;align-items:center;gap:12px;padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.share span{font-weight:700;font-size:13px;color:var(--ink-3)}
.share .sbtn{width:40px;height:40px;border-radius:var(--r-pill);border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:var(--ink-2);transition:all .15s}
.share .sbtn:hover{border-color:var(--ink);color:var(--ink);background:var(--bg-2)}
.authorcard{display:flex;gap:18px;align-items:flex-start;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-xl);padding:24px;margin:34px 0}
.authorcard .avatar{width:60px;height:60px;font-size:22px}
.authorcard b{font-weight:800;font-size:17px}
.authorcard .role{font-size:13px;color:var(--ink-3);margin:1px 0 8px}
.authorcard p{font-size:14.5px;color:var(--ink-2);line-height:1.55;margin:0}

/* related */
.related{max-width:var(--maxw);margin:60px auto 0;padding:0 28px}
.related h3{font-weight:900;font-size:22px;letter-spacing:-.02em;margin:0 0 24px}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .featured a.card-link{grid-template-columns:1fr;gap:24px}
  .featured image-slot,.featured .imgph{height:300px}
  .grid{grid-template-columns:1fr 1fr}
  .news-in{grid-template-columns:1fr;gap:22px}
  .nav-links{display:none}
}
@media (max-width:620px){
  .grid{grid-template-columns:1fr}
  .masthead{padding:44px 0 24px}
  .prose{font-size:18.5px}
  .footer .ft{flex-direction:column;align-items:flex-start;gap:18px}
}

/* ---------- modo oscuro (unificado con el landing; store 'oni-theme') ---------- */
html.dark{
  --bg:#0E0E11; --bg-2:#16161B; --bg-3:#1F1F25;
  --ink:#F1EFEC; --ink-2:#B3B3BB; --ink-3:#83838C; --ink-4:#56565E;
  --line:#2A2A31; --line-2:#3A3A42;
  --red-tint:rgba(224,49,42,.15); --red-tint-2:rgba(224,49,42,.30);
  --paper:#070709;
  --shadow-sm:0 1px 2px rgba(0,0,0,.5);
  --shadow-md:0 10px 30px rgba(0,0,0,.55);
  --shadow-lg:0 26px 64px rgba(0,0,0,.62);
}
/* re-pin de elementos con colores fijos o que invierten con --ink */
html.dark .prose{color:#C9C9CF}
html.dark .cat.on{background:var(--ink);color:#16161A;border-color:var(--ink)}
html.dark .news{background:#15151B}
/* cross-fade suave solo al togglear */
html.theming *,html.theming *::before,html.theming *::after{
  transition:background-color .32s ease,color .32s ease,border-color .32s ease,fill .32s ease,box-shadow .32s ease !important}
