/* PROGRESS BAR */
.read-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;background:var(--bds)}
.read-progress-fill{height:100%;background:var(--ac);width:0%;transition:width 80ms linear;border-radius:0 2px 2px 0}

/* BREADCRUMB */
.breadcrumb{padding:var(--s6) 0 0;display:flex;align-items:center;gap:var(--s2)}
.bc-link{font-size:.8rem;color:var(--t3);transition:color 150ms}
.bc-link:hover{color:var(--ac)}
.bc-sep{color:var(--bds)}
.bc-cur{font-size:.8rem;color:var(--t2)}

/* ARTICLE HEADER */
.art-header{padding:clamp(var(--s8),5vw,56px) 0 clamp(var(--s6),3vw,40px)}
.art-header-inner{max-width:800px;margin:0 auto}
.art-cat{display:inline-flex;align-items:center;gap:var(--s2);font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ac);background:var(--acd);padding:4px 14px;border-radius:var(--rp);margin-bottom:var(--s5)}
.art-title{font-family:var(--fd);font-size:clamp(1.8rem,3.5vw + .4rem,3rem);font-weight:800;color:var(--t);letter-spacing:-.04em;line-height:1.12;margin-bottom:var(--s5)}
.art-lead{font-size:clamp(1rem,1.2vw + .1rem,1.15rem);color:var(--t2);line-height:1.75;margin-bottom:var(--s8)}
.art-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--s4);padding:var(--s5) 0;border-top:1px solid var(--bds);border-bottom:1px solid var(--bds)}
.art-author{display:flex;align-items:center;gap:var(--s3)}
.art-av{width:44px;height:44px;border-radius:50%;background:var(--ac);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--oa);flex-shrink:0}
.art-author-name{font-size:.9rem;font-weight:600;color:var(--t)}
.art-author-role{font-size:.78rem;color:var(--t3)}
.art-stats{display:flex;align-items:center;gap:var(--s6)}
.art-stat{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--t3)}

/* HERO IMAGE */
.art-hero{margin:clamp(var(--s6),4vw,48px) 0;border-radius:var(--rxl);overflow:hidden;height:clamp(260px,30vw,460px);position:relative;background:linear-gradient(135deg,oklch(90% 0.055 285) 0%,oklch(85% 0.08 295) 60%,oklch(80% 0.09 280) 100%)}
.art-hero-deco1{position:absolute;width:400px;height:400px;border-radius:50%;top:-80px;right:-80px;background:oklch(85% 0.08 285);opacity:.55}
.art-hero-deco2{position:absolute;width:260px;height:260px;border-radius:50%;bottom:-60px;left:60px;background:oklch(78% 0.1 300);opacity:.35}
.art-hero-wave{position:absolute;bottom:clamp(24px,4vw,48px);right:clamp(32px,5vw,80px);display:flex;align-items:flex-end;gap:5px;height:72px}
.art-hero-wave span{width:5px;border-radius:4px;background:var(--ac);opacity:.5;flex-shrink:0}

/* ARTICLE BODY */
.art-layout{display:grid;grid-template-columns:1fr 280px;gap:clamp(var(--s8),4vw,56px);align-items:start;padding:0 0 clamp(var(--s12),6vw,80px)}
.art-content{min-width:0}

/* Typography */
.art-content h2{font-family:var(--fd);font-size:clamp(1.1rem,1.8vw + .1rem,1.4rem);font-weight:700;color:var(--t);letter-spacing:-.03em;line-height:1.3;margin:clamp(var(--s8),4vw,48px) 0 var(--s5)}
.art-content h3{font-family:var(--fb);font-size:1.05rem;font-weight:600;color:var(--t);line-height:1.4;margin:var(--s8) 0 var(--s4)}
.art-content p{font-size:1rem;color:var(--t2);line-height:1.85;margin-bottom:var(--s5);max-width:72ch}
.art-content ul,.art-content ol{margin:0 0 var(--s5) var(--s6);display:flex;flex-direction:column;gap:var(--s2)}
.art-content ul li,.art-content ol li{font-size:1rem;color:var(--t2);line-height:1.75;padding-left:var(--s2)}
.art-content ul{list-style:none}
.art-content ul li::before{content:'—';color:var(--ac);font-weight:600;margin-right:var(--s3);margin-left:calc(-1 * var(--s6))}
.art-content strong{font-weight:600;color:var(--t)}
.art-content a{color:var(--ac);text-decoration:underline;text-decoration-color:oklch(78% 0.1 285);text-underline-offset:3px;transition:color 150ms}
.art-content a:hover{color:var(--ach)}

/* Blockquote */
.art-content blockquote{background:var(--acd);border-radius:var(--rl);padding:var(--s6) var(--s8);margin:var(--s8) 0;position:relative}
.art-content blockquote::before{content:'\201C';font-family:var(--fd);font-size:4rem;color:var(--ac);opacity:.2;position:absolute;top:-8px;left:var(--s6);line-height:1;pointer-events:none}
.art-content blockquote p{font-size:1.05rem;font-style:italic;color:var(--t);font-weight:500;line-height:1.7;margin:0;max-width:100%}
.art-content blockquote cite{display:block;font-size:.8rem;color:var(--t3);font-style:normal;margin-top:var(--s3)}

/* Step cards */
.art-steps{display:flex;flex-direction:column;gap:var(--s4);margin:var(--s6) 0}
.art-step{display:flex;gap:var(--s5);align-items:flex-start;background:var(--surf);border:1px solid var(--bd);border-radius:var(--rl);padding:var(--s5) var(--s6)}
.art-step-num{font-family:var(--fd);font-size:1.2rem;font-weight:800;color:var(--ac);line-height:1;flex-shrink:0;width:32px}
.art-step-body h4{font-family:var(--fd);font-size:.82rem;font-weight:700;color:var(--t);letter-spacing:-.02em;margin-bottom:var(--s2)}
.art-step-body p{font-size:.875rem;color:var(--t2);line-height:1.7;margin:0;max-width:100%}

/* Inline tip */
.art-tip{display:flex;gap:var(--s4);background:oklch(91% 0.05 160);border-radius:var(--rl);padding:var(--s5) var(--s6);margin:var(--s6) 0;align-items:flex-start}
.art-tip-icon{flex-shrink:0;color:oklch(36% 0.14 160);margin-top:2px}
.art-tip p{font-size:.875rem;color:oklch(28% 0.1 160);line-height:1.7;margin:0;max-width:100%}
.art-tip strong{color:oklch(24% 0.12 160)}

/* Inline CTA */
.art-cta{background:var(--ac);border-radius:var(--rxl);padding:clamp(var(--s6),3vw,36px) clamp(var(--s6),3vw,40px);margin:clamp(var(--s8),4vw,48px) 0;position:relative;overflow:hidden}
.art-cta-deco{position:absolute;width:200px;height:200px;border-radius:50%;top:-60px;right:-60px;background:oklch(66% 0.14 285);pointer-events:none}
.art-cta-deco2{position:absolute;width:140px;height:140px;border-radius:50%;bottom:-40px;left:-40px;background:oklch(50% 0.18 300);pointer-events:none;opacity:.5}
.art-cta-content{position:relative;z-index:1;display:grid;grid-template-columns:1fr auto;gap:var(--s6);align-items:center}
.art-cta h3{font-family:var(--fd);font-size:clamp(1rem,1.5vw + .1rem,1.25rem);font-weight:700;color:var(--oa);letter-spacing:-.03em;line-height:1.3;margin-bottom:var(--s2)}
.art-cta p{font-size:.875rem;color:oklch(90% 0.05 285);line-height:1.6;margin:0;max-width:100%}
.art-cta-btn{font-family:var(--fb);height:44px;padding:0 var(--s6);background:var(--oa);border:none;border-radius:var(--rp);font-size:.9rem;font-weight:600;color:var(--ac);cursor:pointer;white-space:nowrap;transition:background 120ms;flex-shrink:0}
.art-cta-btn:hover{background:var(--acdd)}

/* Share + tags */
.art-bottom{display:flex;align-items:center;justify-content:space-between;gap:var(--s4);padding:var(--s6) 0;border-top:1px solid var(--bds);flex-wrap:wrap}
.art-tags{display:flex;flex-wrap:wrap;gap:var(--s2)}
.art-tag{font-size:.78rem;color:var(--t3);background:var(--bg-s);border:1px solid var(--bds);border-radius:var(--rp);padding:4px 12px;cursor:pointer;transition:border-color 150ms,color 150ms}
.art-tag:hover{border-color:var(--bd);color:var(--t)}
.art-share{display:flex;align-items:center;gap:var(--s3)}
.art-share-lbl{font-size:.8rem;color:var(--t3)}
.share-btn{width:36px;height:36px;border-radius:var(--rm);background:var(--surf);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;color:var(--t2);cursor:pointer;transition:border-color 150ms,color 150ms}
.share-btn:hover{border-color:var(--ac);color:var(--ac)}

/* SIDEBAR */
.art-sidebar{position:sticky;top:88px;display:flex;flex-direction:column;gap:var(--s6)}
.sidebar-card{background:var(--surf);border:1px solid var(--bd);border-radius:var(--rxl);padding:var(--s6);overflow:hidden}
.sidebar-title{font-family:var(--fd);font-size:.72rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--t3);margin-bottom:var(--s5)}
.toc-list{display:flex;flex-direction:column;gap:2px}
.toc-item{font-size:.82rem;color:var(--t3);padding:6px var(--s3);border-radius:var(--r);cursor:pointer;transition:color 150ms,background 150ms;line-height:1.4}
.toc-item:hover{color:var(--ac);background:var(--acd)}
.toc-item.active{color:var(--ac);background:var(--acd);font-weight:500}
.toc-item.h3{padding-left:var(--s6);font-size:.78rem}
.author-full-av{width:52px;height:52px;border-radius:50%;background:var(--ac);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--oa);margin-bottom:var(--s3)}
.author-full-name{font-family:var(--fd);font-size:.82rem;font-weight:700;color:var(--t);letter-spacing:-.02em;margin-bottom:var(--s1)}
.author-full-bio{font-size:.8rem;color:var(--t2);line-height:1.6;margin-bottom:var(--s4)}
.sidebar-divider{height:1px;background:var(--bds);margin:var(--s4) 0}
.try-mini-btn{width:100%;font-family:var(--fb);height:40px;background:var(--ac);color:var(--oa);border:none;border-radius:var(--rp);font-size:.85rem;font-weight:600;cursor:pointer;transition:background 120ms}
.try-mini-btn:hover{background:var(--ach)}

/* RELATED */
.related{padding:clamp(var(--s8),5vw,56px) 0;border-top:1px solid var(--bds)}
.related-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--s8)}
.related-title{font-family:var(--fd);font-size:clamp(1rem,1.4vw + .1rem,1.25rem);font-weight:700;color:var(--t);letter-spacing:-.025em}
.related-all{font-size:.82rem;color:var(--ac);display:flex;align-items:center;gap:5px;transition:gap 180ms}
.related-all:hover{gap:var(--s2)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6)}
.post-card{background:var(--surf);border:1px solid var(--bd);border-radius:var(--rxl);overflow:hidden;display:flex;flex-direction:column;cursor:pointer;transition:box-shadow 280ms var(--ex),transform 280ms var(--ex)}
.post-card:hover{box-shadow:0 6px 28px oklch(16% 0.015 285 / 0.09);transform:translateY(-2px)}
.post-img{height:180px;position:relative;overflow:hidden;flex-shrink:0}
.post-body{padding:var(--s5) var(--s6);display:flex;flex-direction:column;flex:1}
.post-cat{display:inline-flex;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 10px;border-radius:var(--rp);margin-bottom:var(--s3);width:fit-content}
.post-title{font-family:var(--fd);font-size:.88rem;font-weight:700;color:var(--t);letter-spacing:-.02em;line-height:1.35;margin-bottom:var(--s3)}
.post-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--s3);padding-top:var(--s4);border-top:1px solid var(--bds);margin-top:auto}
.post-meta{display:flex;align-items:center;gap:var(--s2)}
.post-av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:var(--oa);flex-shrink:0}
.post-author-name{font-size:.72rem;font-weight:600;color:var(--t2)}
.post-read{font-size:.72rem;color:var(--t3)}

/* FOOTER */
.foot{background:oklch(13% 0.018 285)}
.foot-brand{padding:clamp(var(--s12),6vw,80px) 0 clamp(var(--s8),4vw,48px);display:grid;grid-template-columns:1fr auto;align-items:end;gap:var(--s8);border-bottom:1px solid oklch(22% 0.018 285)}
.foot-wordmark{font-family:var(--fd);font-size:clamp(2.4rem,5vw + .5rem,4.5rem);font-weight:800;color:oklch(92% 0.015 285);letter-spacing:-.05em;line-height:1;margin-bottom:var(--s3)}
.foot-tagline{font-size:.95rem;color:oklch(48% 0.018 285);line-height:1.6;max-width:38ch}
.foot-cta-btn{font-family:var(--fb);height:46px;padding:0 var(--s6);background:var(--ac);color:var(--oa);border:none;border-radius:var(--rp);font-size:.9rem;font-weight:600;cursor:pointer;transition:background 120ms;white-space:nowrap}
.foot-cta-btn:hover{background:var(--ach)}
.fg2{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(var(--s6),3vw,var(--s12));padding:clamp(var(--s8),4vw,48px) 0}
.fct{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:oklch(38% 0.015 285);margin-bottom:var(--s4)}
.flk{display:block;font-size:.85rem;color:oklch(52% 0.018 285);margin-bottom:var(--s3);text-decoration:none;transition:color 150ms;cursor:pointer}
.flk:hover{color:oklch(78% 0.025 285)}
.fsoc{display:flex;gap:var(--s3);margin-top:var(--s4)}
.fsoc-a{width:36px;height:36px;border-radius:var(--rm);background:oklch(20% 0.018 285);display:flex;align-items:center;justify-content:center;color:oklch(52% 0.018 285);text-decoration:none;transition:background 150ms,color 150ms}
.fsoc-a:hover{background:oklch(26% 0.02 285);color:oklch(80% 0.025 285)}
.fbot{border-top:1px solid oklch(20% 0.015 285);padding:var(--s5) 0;display:flex;align-items:center;justify-content:space-between;gap:var(--s4)}
.fcp{font-size:.78rem;color:oklch(32% 0.012 285)}
.flgl{display:flex;gap:var(--s6)}

/* ── PROSE TYPOGRAPHY ─────────────────────────────────────────────────────── */
.prose{font-size:1.05rem;color:var(--t2);line-height:1.85}

/* Headings */
.prose h1{font-family:var(--fd);font-size:clamp(2rem,4vw + .5rem,3.2rem);font-weight:800;letter-spacing:-.05em;line-height:1.08;color:var(--t);margin:0 0 var(--s6)}
.prose h2{font-family:var(--fd);font-size:clamp(1.2rem,2vw + .2rem,1.55rem);font-weight:700;letter-spacing:-.03em;line-height:1.25;color:var(--t);margin:clamp(var(--s8),4vw,52px) 0 var(--s4)}
.prose h3{font-family:var(--fb);font-size:1.1rem;font-weight:600;color:var(--t);line-height:1.4;margin:var(--s8) 0 var(--s3)}
.prose h4{font-family:var(--fb);font-size:.8rem;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.1em;margin:var(--s6) 0 var(--s3)}

/* Paragraph */
.prose p{margin-bottom:var(--s5);max-width:77ch}

/* Inline */
.prose strong{font-weight:600;color:var(--t)}
.prose em{font-style:italic;color:var(--t)}
.prose a{color:var(--ac);text-decoration:underline;text-decoration-color:oklch(78% 0.1 285);text-underline-offset:3px;transition:color 150ms}
.prose a:hover{color:var(--ach)}

/* Mark / highlight */
.prose mark{background:oklch(93% 0.11 85);color:oklch(28% 0.09 70);border-radius:3px;padding:1px 5px;font-weight:500}

/* Lists */
.prose ul,.prose ol{margin:0 0 var(--s5) var(--s6);display:flex;flex-direction:column;gap:var(--s2)}
.prose ul{list-style:none}
.prose ul li{padding-left:var(--s2);position:relative}
.prose ul li::before{content:'→';color:var(--ac);font-weight:600;position:absolute}
.prose ol{list-style:none;counter-reset:ol-counter}
.prose ol li{counter-increment:ol-counter;padding-left:var(--s2);position:relative}
.prose ol li::before{content:counter(ol-counter) '.';position:absolute;left:calc(-1 * var(--s5));font-weight:600;color:var(--ac);font-variant-numeric:tabular-nums;font-size:.9em}
.prose li{font-size:1rem;color:var(--t2);line-height:1.75}

/* Blockquote */
.prose blockquote{background:var(--acd);border-radius:var(--rl);padding:var(--s6) var(--s8) var(--s6) clamp(var(--s8),4vw,56px);margin:var(--s8) 0;position:relative}
.prose blockquote::before{content:'\201C';font-family:var(--fd);font-size:5rem;color:var(--ac);opacity:.18;position:absolute;top:-12px;left:var(--s5);line-height:1;pointer-events:none}
.prose blockquote p{font-size:1.08rem;font-style:italic;color:var(--t);font-weight:500;line-height:1.7;margin:0;max-width:100%}
.prose blockquote cite{display:block;font-size:.8rem;color:var(--t3);font-style:normal;margin-top:var(--s3)}

/* Code block */
.prose pre{background:oklch(13% 0.016 285);border-radius:var(--rl);padding:var(--s6);margin:var(--s6) 0;overflow-x:auto;position:relative}
.prose pre::before{content:attr(data-lang);position:absolute;top:var(--s3);right:var(--s4);font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:oklch(48% 0.022 285)}
.prose pre code{font-family:'JetBrains Mono','Fira Code','Cascadia Code',monospace;font-size:.875rem;color:oklch(84% 0.022 285);line-height:1.7;tab-size:2}
.prose pre .kw{color:oklch(78% 0.14 285)}
.prose pre .str{color:oklch(76% 0.12 155)}
.prose pre .cm{color:oklch(48% 0.018 285);font-style:italic}
.prose pre .fn{color:oklch(82% 0.1 60)}
.prose pre .nu{color:oklch(78% 0.1 40)}
.prose code:not(pre code){font-family:'JetBrains Mono','Fira Code',monospace;font-size:.875em;background:var(--bg-s);border:1px solid var(--bds);border-radius:4px;padding:1px 6px;color:var(--t)}

/* Details / Summary (TipTap collapsible) */
.prose details{background:var(--surf);border:1px solid var(--bd);border-radius:var(--rl);margin:var(--s5) 0;overflow:hidden;transition:box-shadow 200ms}
.prose details[open]{box-shadow:0 4px 16px oklch(16% 0.015 285 / 0.06)}
.prose summary{padding:var(--s4) var(--s5);font-size:.95rem;font-weight:600;color:var(--t);cursor:pointer;display:flex;align-items:center;gap:var(--s3);list-style:none;transition:background 150ms;user-select:none}
.prose summary::-webkit-details-marker{display:none}
.prose summary::after{content:'';width:18px;height:18px;flex-shrink:0;margin-left:auto;background:var(--t3);mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none'%3E%3Cpath d='M3 6l5 5 5-5' stroke='currentColor' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none'%3E%3Cpath d='M3 6l5 5 5-5' stroke='currentColor' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;transition:transform 220ms,background 150ms}
.prose summary:hover{background:var(--bg-s)}
.prose summary:hover::after{background:var(--ac)}
.prose details[open] summary::after{transform:rotate(180deg);background:var(--ac)}
.prose details[open] summary{background:var(--bg-s)}
.prose details [data-type="detailsContent"]{padding:var(--s5) var(--s5);border-top:1px solid var(--bds)}
.prose details [data-type="detailsContent"] > div{padding-top:var(--s4)}
.prose details [data-type="detailsContent"] p{font-size:.95rem;color:var(--t2);line-height:1.75;margin-bottom:0;max-width:87ch}

/* Table (TipTap) */
.prose table{width:100%;border-collapse:collapse;margin:var(--s6) 0;font-size:.95rem;background:var(--surf);border-radius:var(--rl);overflow:hidden;border:1px solid var(--bd)}
.prose thead{background:var(--bg-s)}
.prose thead th{padding:var(--s3) var(--s5);font-family:var(--fb);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--t3);text-align:left;white-space:nowrap}
.prose thead th:first-child{border-radius:var(--rl) 0 0 0}
.prose thead th:last-child{border-radius:0 var(--rl) 0 0}
.prose tbody tr{border-top:1px solid var(--bds);transition:background 120ms}
.prose tbody tr:hover{background:oklch(97.5% 0.008 285)}
.prose tbody td{padding:var(--s3) var(--s5);color:var(--t2);line-height:1.6;vertical-align:top}
.prose tbody td strong{color:var(--t)}
.prose tbody td:first-child{font-weight:500;color:var(--t)}
.prose tfoot tr{border-top:1px solid var(--bd);background:var(--bg-s)}
.prose tfoot td{padding:var(--s3) var(--s5);font-size:.82rem;color:var(--t3)}

/* Horizontal rule */
.prose hr{border:none;border-top:1px solid var(--bds);margin:var(--s8) 0}

/* ── RESPONSIVE */
@media(max-width:1000px){
  .art-layout{grid-template-columns:1fr}
  .art-sidebar{position:static}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .art-cta-content{grid-template-columns:1fr}
}
@media(max-width:640px){
  .related-grid{grid-template-columns:1fr}
  .fg2{grid-template-columns:repeat(2,1fr)}
  .foot-brand{grid-template-columns:1fr}
  .fbot{flex-direction:column;gap:var(--s3);text-align:center}
  .nls{display:none}
  .art-meta{flex-direction:column;align-items:flex-start;gap:var(--s4)}
}
