/* ============================================================
   Naylalabs — blog.css
   Blog list + article detail styles. Loaded with site.css.
   ============================================================ */

/* ---------- list page ---------- */
.bhero{position:relative;padding-top:clamp(48px,7vw,90px);padding-bottom:clamp(20px,3vw,36px);overflow:visible}
.bhero .kick{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;gap:10px;margin-bottom:20px}
.bhero h1{font-size:clamp(44px,7vw,104px);line-height:.95;letter-spacing:-.04em;font-weight:600;max-width:14ch}
.bhero .sub{font-size:clamp(15px,1.6vw,19px);line-height:1.6;color:var(--muted);max-width:52ch;margin-top:20px}

.bfilter{display:flex;flex-wrap:wrap;gap:8px;padding:26px 0 6px}
.bfilter button{font-family:var(--mono);font-size:12px;letter-spacing:.03em;border:1px solid var(--line-2);background:none;color:var(--muted);border-radius:999px;padding:8px 15px;cursor:pointer;transition:.18s}
.bfilter button:hover{color:var(--text);border-color:var(--line-2)}
.bfilter button.on{color:var(--orange);border-color:var(--orange)}

.brow{display:grid;grid-template-columns:56px 1fr 340px;gap:10px 28px;align-items:baseline;border-top:1px solid var(--line);padding:30px 8px;transition:background .3s,padding .3s;position:relative}
.brow:last-of-type{border-bottom:1px solid var(--line)}
.brow:hover{background:linear-gradient(90deg,rgba(247,69,22,.06),transparent 65%);padding-left:22px}
.brow .bn{font-family:var(--mono);font-size:13px;color:var(--muted-2)}
.brow h2{font-size:clamp(22px,3vw,36px);font-weight:600;letter-spacing:-.025em;line-height:1.05;transition:color .25s;text-wrap:balance}
.brow:hover h2{color:var(--orange)}
.brow .bx{font-size:14.5px;line-height:1.55;color:var(--muted);margin-top:10px;max-width:60ch}
.brow .bmeta{font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;color:var(--muted-2);display:flex;flex-direction:column;gap:8px;justify-self:end;text-align:right}
.brow .bmeta .tag{color:var(--orange)}
.brow .go{position:absolute;right:14px;top:30px;color:var(--muted-2);opacity:0;transition:.25s;font-size:18px}
.brow:hover .go{opacity:1;color:var(--orange)}

.bfeat{display:block;border:1px solid var(--line);border-radius:24px;background:var(--bg-2);padding:clamp(26px,4vw,46px);margin:26px 0 34px;position:relative;overflow:hidden;transition:border-color .3s,transform .3s}
.bfeat:hover{border-color:var(--line-2);transform:translateY(-3px)}
.bfeat .fglow{position:absolute;right:-15%;top:-40%;width:55%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(247,69,22,.22),transparent 65%);filter:blur(50px);pointer-events:none}
.bfeat .fk{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);margin-bottom:16px;display:flex;gap:14px;flex-wrap:wrap}
.bfeat .fk .d{color:var(--muted-2)}
.bfeat h2{font-size:clamp(28px,4.4vw,56px);font-weight:600;letter-spacing:-.03em;line-height:1;max-width:22ch;text-wrap:balance;position:relative}
.bfeat:hover h2{color:var(--orange)}
.bfeat p{font-size:15.5px;line-height:1.6;color:var(--muted);max-width:62ch;margin-top:16px;position:relative}
.bfeat .fcta{margin-top:22px;font-family:var(--mono);font-size:12px;color:var(--muted);display:inline-flex;gap:9px;align-items:center;transition:.2s;position:relative}
.bfeat:hover .fcta{color:var(--orange)}

/* ---------- article page ---------- */
.art-hero{position:relative;padding-top:clamp(44px,6vw,76px);padding-bottom:clamp(24px,3vw,40px)}
.art-kick{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);display:flex;flex-wrap:wrap;gap:8px 16px;margin-bottom:20px}
.art-kick .d{color:var(--muted-2)}
.art-hero h1{font-size:clamp(34px,5.4vw,72px);line-height:1;letter-spacing:-.035em;font-weight:600;max-width:20ch;text-wrap:balance}
.art-hero .lead{font-size:clamp(16px,1.7vw,20px);line-height:1.55;color:var(--muted);max-width:56ch;margin-top:22px}
.art-by{display:flex;align-items:center;gap:12px;margin-top:28px;font-family:var(--mono);font-size:12px;color:var(--muted-2)}
.art-by img{width:30px;height:30px;border-radius:8px}
.art-by b{color:var(--text);font-weight:500}

.art-body{max-width:760px;padding-top:clamp(24px,3vw,40px);padding-bottom:clamp(44px,6vw,72px)}
.art-body h2{font-size:clamp(23px,2.8vw,32px);font-weight:600;letter-spacing:-.025em;line-height:1.1;margin:44px 0 16px;text-wrap:balance}
.art-body h2 .n{font-family:var(--mono);font-size:.55em;color:var(--orange);letter-spacing:.04em;vertical-align:.25em;margin-right:10px}
.art-body p{font-size:16.5px;line-height:1.75;color:var(--muted);margin-bottom:18px}
.art-body p strong,.art-body li strong{color:var(--text);font-weight:600}
.art-body ul{list-style:none;margin:0 0 20px;display:flex;flex-direction:column;gap:11px}
.art-body ul li{position:relative;padding-left:27px;font-size:16px;line-height:1.65;color:var(--muted)}
.art-body ul li::before{content:"—";color:var(--orange);position:absolute;left:0;top:0}
.art-body blockquote{border-left:2px solid var(--orange);padding:6px 0 6px 22px;margin:28px 0;font-size:clamp(19px,2.2vw,24px);line-height:1.4;letter-spacing:-.015em;color:var(--text);font-weight:500;text-wrap:balance}
.art-note{border:1px solid var(--line-2);border-left:3px solid var(--orange);border-radius:0 12px 12px 0;background:rgba(247,69,22,.05);padding:16px 20px;margin:22px 0;font-size:14.5px;line-height:1.65;color:var(--text)}
.art-note b{color:var(--orange)}
.bcode{border:1px solid var(--line-2);border-radius:14px;background:#070708;overflow:hidden;margin:22px 0}
.bcode .bar{display:flex;align-items:center;gap:7px;padding:11px 15px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;color:var(--muted-2)}
.bcode .bar i{width:9px;height:9px;border-radius:50%;background:#2a2a2d}
.bcode .bar i:first-child{background:var(--orange)}
.bcode pre{padding:18px 20px;overflow-x:auto;font-family:var(--mono);font-size:13px;line-height:1.75;color:#cfccc4}
.bcode pre .c{color:var(--muted-2)}
.bcode pre .k{color:var(--orange)}
.bcode pre .s{color:#9fd0a6}

.art-tags{display:flex;flex-wrap:wrap;gap:8px;padding-bottom:8px}
.art-tags span{font-family:var(--mono);font-size:11.5px;border:1px solid var(--line-2);padding:6px 12px;border-radius:999px;color:var(--muted)}

@media(max-width:860px){
  .brow{grid-template-columns:40px 1fr}
  .brow .bmeta{grid-column:2;flex-direction:row;justify-self:start;text-align:left;gap:16px}
  .brow .go{display:none}
}
