/*
Theme Name: Stitchmend
Theme URI: https://stitchmend.com/
Author: Stitchmend
Description: Custom theme for Stitchmend, a US home sewing-machine repair site. Honest, plain-language repair guides and free diagnostic tools. Pine / brass / cream palette, Fraunces + Hanken Grotesk + JetBrains Mono.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: stitchmend
*/

/* ==========================================================================
   DESIGN SYSTEM - shared tokens (from all 3 mockups, consolidated once)
   ========================================================================== */
:root{
  --pine:#1F4A3A; --pine-d:#163729; --pine-l:#2c6249; --brass:#B4823A; --brass-d:#956a2c; --brass-dd:#8a6028; --brass-l:#eccc99;
  --cream:#F5F0E6; --paper:#FFFFFF; --ink:#1B1916; --muted:#5f5a50; --line:#E5DECF;
  --mist:#EAF0EA; --mist-d:#dde7df; --rust:#A8502E;
  --disp:'Fraunces',Georgia,serif; --body:'Hanken Grotesk',system-ui,sans-serif; --mono:'JetBrains Mono',monospace;
  --r1:9px; --r2:12px; --r3:16px; --r4:20px;
  --sh:0 12px 28px -16px rgba(27,25,22,.28); --sh2:0 22px 44px -22px rgba(27,25,22,.42);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:var(--body);background:var(--cream);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip}
h1,h2,h3,h4{font-family:var(--disp);font-weight:600;line-height:1.12;letter-spacing:-.01em;font-optical-sizing:auto}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.wrap{max-width:1160px;margin:0 auto;padding:0 26px}
.eyebrow{font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--brass-d);display:inline-flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--brass);display:inline-block}

/* skip link */
.skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--pine);color:#fff;padding:10px 16px;border-radius:0 0 var(--r2) 0;font-weight:700;font-size:14px}
.skip:focus{left:0}

/* motion: reveal-on-scroll - only hides when JS active, with no-JS + failsafe safety */
.js .reveal{opacity:0;transform:translateY(22px)}
.js .reveal.in{opacity:1;transform:none;transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.2,1)}

/* ==========================================================================
   HEADER (shared) - logo + category nav + rounded-square search + hamburger + drawer
   ========================================================================== */
header{background:var(--cream);border-bottom:1px solid var(--line);position:relative;z-index:50}
.bar{display:flex;align-items:center;justify-content:space-between;height:70px;gap:22px}
.logo{display:flex;align-items:center;gap:9px;font-family:var(--disp);font-weight:600;font-size:27px;color:var(--ink);flex:0 0 auto}
.logo img{height:46px;width:auto;display:block}
nav.main{display:flex;gap:22px;font-size:14.5px;font-weight:600}
nav.main a{position:relative;padding:4px 0;color:#3a352e}
nav.main a:hover{color:var(--pine)}
nav.main a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--brass);transition:right .24s cubic-bezier(.4,0,.2,1)}
nav.main a:hover::after{right:0}
nav.main a:focus-visible{outline:2px solid var(--brass);outline-offset:4px;border-radius:2px}
.hactions{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.search{width:44px;height:44px;border:1px solid var(--line);border-radius:var(--r2);display:grid;place-items:center;color:var(--muted);cursor:pointer;background:#fff;transition:.15s}
.search:hover{border-color:var(--pine);color:var(--pine)}
.search:focus-visible{outline:2px solid var(--brass);outline-offset:2px}
.btn-diag{font-size:14.5px;font-weight:700;background:var(--pine);color:#fff;padding:11px 20px;border-radius:var(--r2);transition:background .15s,transform .08s}
.btn-diag:hover{background:var(--pine-d)}
.btn-diag:active{background:#0e2420;transform:scale(.97)}
.btn-diag:focus-visible{outline:3px solid var(--brass-l);outline-offset:3px}
.menutoggle{display:none;width:44px;height:44px;background:none;border:0;color:var(--ink);cursor:pointer;place-items:center;border-radius:var(--r2)}
.menutoggle:hover{background:rgba(0,0,0,.04)}
/* mobile drawer */
#mnav{display:none;flex-direction:column;background:var(--cream);border-bottom:1px solid var(--line);padding:10px 26px 18px}
#mnav.open{display:flex}
#mnav a{font-size:17px;font-weight:600;color:#2a2620;padding:13px 2px;border-bottom:1px solid var(--line)}
#mnav a:last-of-type{border-bottom:0}
#mnav .btn-diag{color:#fff;border-bottom:0;margin-top:14px;text-align:center;padding:14px;font-size:16px}

/* search panel (collapses under header, no-JS friendly) */
.searchpanel{display:none;background:var(--cream);border-bottom:1px solid var(--line);padding:14px 26px}
.searchpanel.open{display:block}
.searchpanel form{max-width:1160px;margin:0 auto;display:flex;gap:10px}
.searchpanel input[type=search]{flex:1;font-family:var(--body);font-size:16px;padding:12px 15px;border:1.5px solid var(--line);border-radius:var(--r2);background:#fff;color:var(--ink)}
.searchpanel input[type=search]:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(180,130,58,.3)}
.searchpanel button{font-family:var(--body);font-weight:700;font-size:15px;background:var(--pine);color:#fff;border:0;padding:12px 22px;border-radius:var(--r2);cursor:pointer}
.searchpanel button:hover{background:var(--pine-d)}

/* ==========================================================================
   SECTIONS (shared scaffolding)
   ========================================================================== */
section{padding:58px 0;scroll-margin-top:24px}
.sec-head{margin-bottom:28px;max-width:660px}
.sec-head.center{margin:0 auto 30px;text-align:center}
.sec-head h2{font-size:clamp(27px,3.4vw,40px);margin:8px 0;text-wrap:balance;font-variation-settings:'opsz' 40}
.sec-head p{color:var(--muted);font-size:16px;line-height:1.65;text-wrap:pretty}
.sec-head.center .eyebrow{gap:10px}
.sec-head.center .eyebrow::after{content:"";width:22px;height:2px;background:var(--brass);display:inline-block}

/* ==========================================================================
   HOMEPAGE (front-page.php) - from proto-pro.html
   ========================================================================== */
/* hero */
.hero{background:radial-gradient(640px 520px at 92% 6%,rgba(180,130,58,.26),transparent 56%),radial-gradient(900px 620px at 12% 118%,rgba(12,28,20,.5),transparent 60%),var(--pine);color:#fff;position:relative;overflow:hidden;padding:64px 0}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.04fr .96fr;gap:56px;align-items:center}
.hero .eyebrow{color:var(--brass-l);margin-bottom:18px}
.hero .eyebrow::before{background:var(--brass)}
.hero h1{font-size:clamp(38px,4.7vw,60px);color:#fff;font-weight:600;margin-bottom:18px;letter-spacing:-.02em;line-height:1.02;text-wrap:balance;font-variation-settings:'opsz' 144}
.hero h1 em{font-style:italic;color:var(--brass-l);font-weight:600}
.hero .sub{font-size:18.5px;line-height:1.6;color:#cfe0d4;max-width:460px;margin-bottom:26px;text-wrap:pretty}
.hero .btn-cta{display:inline-block;font-size:15.5px;font-weight:700;background:var(--brass);color:#231a0d;padding:14px 28px;border-radius:var(--r2);transition:background .15s,transform .08s}
.hero .btn-cta:hover{background:#c79350}
.hero .btn-cta:active{background:#9a6d28;transform:scale(.97)}
.hero .btn-cta:focus-visible{outline:3px solid var(--brass-l);outline-offset:3px}
.stats{display:flex;margin-top:30px}
.stats .s{padding-right:28px;margin-right:28px;border-right:1px solid rgba(255,255,255,.3)}
.stats .s:last-child{border-right:0;margin-right:0;padding-right:0}
.stats .s b{display:block;font-family:var(--disp);font-size:30px;font-weight:600;color:#fff;line-height:1;font-variant-numeric:tabular-nums lining-nums}
.stats .s span{font-size:12.5px;color:#a9c4b3;display:block;margin-top:4px}
.herogrid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:14px}
.hg{border-radius:var(--r3);overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.22)}
.hg img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:1}
.hg.stat{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:22px;background:rgba(180,130,58,.16);border-color:rgba(180,130,58,.6)}
.hg.stat .k{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--brass-l);margin-bottom:7px}
.hg.stat b{font-family:var(--disp);font-size:42px;font-weight:600;color:var(--brass-l);line-height:1;font-variant-numeric:lining-nums;font-variation-settings:'opsz' 72}
.hg.stat span{font-size:13px;color:#cfe0d4;margin-top:7px;line-height:1.35}

/* diagnostic */
.diagsec{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:56px 0}
.diaglayout{display:grid;grid-template-columns:.92fr 1.08fr;gap:24px;align-items:stretch}
.symlist{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.sym{background:var(--cream);border:1.5px solid var(--line);border-radius:var(--r3);padding:18px 20px;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s,background .15s;text-align:left}
.sym:hover{border-color:var(--brass);transform:translateY(-2px);box-shadow:var(--sh)}
.sym.active{border-color:var(--pine);background:var(--mist);box-shadow:0 0 0 2px rgba(31,74,58,.12)}
.sym:focus-visible{outline:2px solid var(--brass);outline-offset:2px}
.sym h3{font-family:var(--disp);font-size:19px;font-weight:700;color:var(--ink);margin-bottom:5px;line-height:1.18}
.sym p{font-size:13px;color:#4a463e;line-height:1.5;text-wrap:pretty}
.sym .most{display:block;margin-top:10px;font-family:var(--mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:#7a5820}
.rpane{background:var(--pine);color:#dfece2;border-radius:var(--r4);padding:26px 30px;box-shadow:var(--sh2);transition:opacity .2s ease;display:flex;flex-direction:column}
.rpane .rlabel{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--brass-l);margin-bottom:6px}
.rpane .rtitle{font-family:var(--disp);font-size:23px;font-weight:600;color:#fff;margin-bottom:14px}
.rpane .causes{flex:1;display:flex;flex-direction:column;justify-content:space-between}
.cause{display:flex;gap:16px;padding:17px 0;border-bottom:1px solid rgba(255,255,255,.12);align-items:flex-start}
.cause:first-child{padding-top:2px}
.cause:last-of-type{border-bottom:0;padding-bottom:2px}
.cause .num{flex:0 0 auto;width:34px;height:34px;border-radius:var(--r1);background:var(--brass);color:#231a0d;font-family:var(--disp);font-weight:700;display:grid;place-items:center;font-size:16.5px;font-variant-numeric:lining-nums;margin-top:1px}
.cause h4{font-family:var(--disp);font-size:17px;font-weight:600;color:#fff;margin-bottom:4px}
.cause p{font-size:14.5px;color:#bcd0c4;margin-bottom:9px;line-height:1.5;text-wrap:pretty}
.cause .fix{display:inline-block;font-size:13.5px;font-weight:700;color:#fff;background:rgba(180,130,58,.24);border-left:3px solid var(--brass);padding:6px 12px;border-radius:6px}
.pro{margin-top:14px;display:flex;gap:11px;align-items:flex-start;background:rgba(168,80,46,.2);border-left:3px solid var(--rust);padding:12px 15px;font-size:13.5px;color:#f0cdbe;line-height:1.45;border-radius:0 6px 6px 0}
.pro .pill{background:var(--rust);color:#fff;font-family:var(--mono);font-size:10px;padding:3px 8px;border-radius:5px;flex:0 0 auto;text-transform:uppercase;letter-spacing:.05em;margin-top:1px}

/* toolkit (know your machine, part by part) */
.toolkit{background:var(--cream)}
.toolkit .tk{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.tkcard{display:block;text-align:center}
.tkcard .ph{border-radius:var(--r3);overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh);transition:transform .16s,box-shadow .16s,border-color .16s;background:#fff}
.tkcard img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.tkcard:hover .ph{transform:translateY(-4px);box-shadow:var(--sh2);border-color:var(--brass)}
.tkcard:focus-visible{outline:none}
.tkcard:focus-visible .ph{outline:2px solid var(--brass);outline-offset:3px;border-color:var(--brass)}
.tkcard .lab{margin-top:12px;font-family:var(--disp);font-size:15.5px;font-weight:600;color:var(--ink);transition:color .16s}
.tkcard .sub{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:2px;transition:color .16s}
.tkcard:hover .lab{color:var(--pine)}
.tkcard:hover .sub{color:var(--brass-d)}

/* needle selector */
.needle{background:var(--pine);color:#fff}
.needle .row{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.needle .sec-head .eyebrow{color:var(--brass-l)}.needle .sec-head .eyebrow::before{background:var(--brass)}
.needle .sec-head h2{color:#fff}.needle .sec-head p{color:#cfe0d4}
.selectors{display:flex;flex-direction:column;gap:11px}
.selectors select{font-family:var(--body);font-size:15px;padding:14px 15px;border:1.5px solid var(--pine-l);border-radius:var(--r2);background:#fff;color:var(--ink);cursor:pointer;transition:border-color .15s,box-shadow .15s}
.selectors select:hover{border-color:var(--brass-d)}
.selectors select:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(180,130,58,.35)}
.btn{font-family:var(--body);font-weight:700;font-size:15px;background:var(--brass);color:#231a0d;border:0;padding:14px 24px;border-radius:var(--r2);cursor:pointer;margin-top:2px;transition:background .15s,transform .08s}
.btn:hover{background:#c79350}
.btn:active{background:var(--brass-d);transform:scale(.97)}
.btn:focus-visible{outline:3px solid var(--brass-l);outline-offset:3px}
.result{margin-top:18px;background:rgba(255,255,255,.08);border:1.5px solid var(--brass);border-radius:var(--r3);padding:18px 20px;opacity:0;transform:translateY(10px);max-height:0;overflow:hidden;transition:opacity .25s ease,transform .25s ease,max-height .25s ease}
.result.show{opacity:1;transform:none;max-height:280px}
.result .big{font-family:var(--disp);font-size:27px;font-weight:600;color:var(--brass-l);margin-bottom:4px}
.result p{font-size:14px;color:#cfe0d4;line-height:1.5}
.needle .imgs{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.needle .imgs figure{position:relative;border-radius:var(--r3);overflow:hidden}
.needle .imgs img{width:100%;height:188px;object-fit:cover;display:block}
.needle .imgs figcaption{position:absolute;left:10px;bottom:10px;font-family:var(--mono);font-size:10px;font-weight:400;text-transform:uppercase;letter-spacing:.05em;background:rgba(22,55,41,.85);color:#e7c79a;padding:4px 9px;border-radius:6px}

/* photo cards (browse + latest) - shared between home + read-next */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cards.three{grid-template-columns:repeat(3,1fr)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r3);overflow:hidden;transition:transform .16s,box-shadow .16s,border-color .16s;display:block}
.card:hover{transform:translateY(-3px);box-shadow:var(--sh2);border-color:var(--brass)}
.card:focus-visible{outline:2px solid var(--brass);outline-offset:3px;border-color:var(--brass)}
.card .imgwrap{position:relative}
.card .imgwrap img{width:100%;height:182px;object-fit:cover;display:block}
.card .kbadge{position:absolute;left:12px;top:12px;font-family:var(--mono);font-size:10px;font-weight:400;letter-spacing:.05em;text-transform:uppercase;background:rgba(31,74,58,.92);color:var(--brass-l);padding:5px 10px;border-radius:20px}
.card .b{padding:18px 20px}
.card .b h3{font-family:var(--disp);font-size:18px;font-weight:600;margin:0 0 5px;line-height:1.18}
.card .b p{font-size:13px;color:var(--muted);line-height:1.5;text-wrap:pretty}
.card .b .meta{margin-top:11px;font-family:var(--mono);font-size:11px;color:var(--brass-d);display:flex;justify-content:space-between}
.latest{background:var(--cream)}

/* trust */
.trust{background:var(--mist)}
.trust .row{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.trust .t{padding:22px 0 8px;border-top:2px solid var(--brass)}
.trust .t .n{font-family:var(--disp);font-size:46px;font-weight:600;color:var(--brass-dd);line-height:1;margin-bottom:8px;font-variant-numeric:tabular-nums lining-nums;font-variation-settings:'opsz' 60}
.trust .t h3{font-family:var(--disp);font-size:22px;font-weight:600;margin-bottom:6px}
.trust .t p{font-size:14.5px;color:#4a463e;line-height:1.55;text-wrap:pretty}

/* ==========================================================================
   PILLAR / ARCHIVE (archive.php, category.php) - from pillar.html
   ========================================================================== */
.phero{background:radial-gradient(700px 420px at 88% -10%,rgba(180,130,58,.22),transparent 60%),var(--pine);color:#fff;padding:54px 0 50px}
.phero .breadcrumb{font-family:var(--mono);font-size:12px;color:#a9c4b3;margin-bottom:18px;display:flex;gap:8px;flex-wrap:wrap}
.phero .breadcrumb a{color:var(--brass-l)}.phero .breadcrumb span{opacity:.5}
.phero .eyebrow{color:var(--brass-l);margin-bottom:14px}.phero .eyebrow::before{background:var(--brass)}
.phero h1{font-size:clamp(32px,4.6vw,52px);color:#fff;max-width:760px;line-height:1.05;text-wrap:balance;font-variation-settings:'opsz' 96}
.phero p{font-size:18.5px;color:#cfe0d4;max-width:620px;margin-top:16px;line-height:1.55;text-wrap:pretty}
.phero .jump{display:flex;flex-wrap:wrap;gap:9px;margin-top:26px}
.phero .jump span{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#a9c4b3;width:100%;margin-bottom:2px}
.phero .jump a{font-size:13.5px;font-weight:600;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#eef5ef;padding:8px 15px;border-radius:30px;transition:.15s}
.phero .jump a:hover{background:var(--brass);border-color:var(--brass);color:#231a0d}

/* featured "start here" diagnostic feature (degrades gracefully) */
.start{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.feat{display:grid;grid-template-columns:1.15fr .85fr;gap:0;border:1px solid var(--line);border-radius:var(--r4);overflow:hidden;background:var(--cream)}
.feat .txt{padding:38px 40px;display:flex;flex-direction:column;justify-content:center}
.feat .txt .eyebrow{margin-bottom:14px}
.feat .txt h3{font-size:30px;line-height:1.1;margin-bottom:12px;font-variation-settings:'opsz' 40}
.feat .txt p{font-size:16.5px;color:#43403a;line-height:1.55;margin-bottom:22px;text-wrap:pretty}
.feat .txt .go{align-self:flex-start;font-size:15px;font-weight:700;background:var(--pine);color:#fff;padding:13px 26px;border-radius:var(--r2)}
.feat .txt .go:hover{background:var(--pine-d)}
.feat .txt .go:focus-visible{outline:3px solid var(--brass-l);outline-offset:3px}
.feat img{width:100%;height:100%;min-height:300px;object-fit:cover}

/* pillar card grid (3-up, flex cards) */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid .card{display:flex;flex-direction:column}
.grid .card .imgwrap img{width:100%;height:170px;object-fit:cover;display:block}
.grid .card .b{padding:18px 20px;display:flex;flex-direction:column;flex:1}
.grid .card .b h3{font-size:19px;line-height:1.18;margin-bottom:6px}
.grid .card .b p{font-size:13.5px;color:var(--muted);line-height:1.5;flex:1}
.grid .card .b .more{margin-top:12px;font-family:var(--mono);font-size:11px;color:var(--brass-d);font-weight:500;display:inline-flex;align-items:center;gap:6px}
.grid .card:hover .b .more{color:var(--pine)}
.subhead{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--brass-d);margin:46px 0 18px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.subhead:first-of-type{margin-top:0}

/* ==========================================================================
   ARTICLE (single.php) - from article.html
   ========================================================================== */
main{padding-bottom:10px}
.artwrap{max-width:760px;margin:0 auto;padding:0 26px}
.breadcrumb{font-family:var(--mono);font-size:12px;color:var(--muted);margin:26px 0 0;display:flex;gap:8px;flex-wrap:wrap}
.breadcrumb a{color:var(--brass-d)}.breadcrumb a:hover{color:var(--pine)}
.breadcrumb span{opacity:.5}
.arthead{padding:14px 0 4px}
.arthead .eyebrow{margin-bottom:14px}
.arthead h1{font-size:clamp(30px,4.4vw,44px);line-height:1.08;text-wrap:balance;margin-bottom:16px;font-variation-settings:'opsz' 80}
.arthead .standfirst{font-size:20px;line-height:1.55;color:#43403a;text-wrap:pretty}
.byline{display:flex;align-items:center;gap:13px;margin:22px 0 0;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.byline .mark{width:42px;height:42px;border-radius:50%;background:var(--mist);display:grid;place-items:center;flex:0 0 auto;overflow:hidden}
.byline .mark img{width:42px;height:42px;object-fit:cover}
.byline .who{font-size:14.5px}
.byline .who b{font-family:var(--disp);font-weight:600;display:block;font-size:15.5px}
.byline .who span{color:var(--muted);font-family:var(--mono);font-size:11.5px;letter-spacing:.02em}

.featured{margin:26px 0 8px}
.featured img{width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;display:block;border-radius:var(--r4);box-shadow:var(--sh)}
.featured figcaption{font-family:var(--mono);font-size:11.5px;color:var(--muted);margin-top:10px;text-align:center}

/* body typography (article prose, the_content) */
.body{font-size:18px;line-height:1.72;color:#262320}
.body>p{margin:18px 0;text-wrap:pretty}
.body>p:first-of-type{margin-top:24px}
.body h2{font-size:27px;margin:40px 0 4px;font-variation-settings:'opsz' 40;scroll-margin-top:24px}
.body h2+p{margin-top:10px}
.body h3{font-size:20px;margin:28px 0 2px}
.body ul,.body ol{margin:16px 0 16px 24px}
.body li{margin:7px 0}
.body a{color:var(--pine);font-weight:600;border-bottom:2px solid var(--brass-l);transition:border-color .15s}
.body a:hover{border-color:var(--brass)}
.body a.inl{color:var(--pine);font-weight:600;border-bottom:2px solid var(--brass-l)}
.body a.inl:hover{border-color:var(--brass)}
.body strong{font-weight:700;color:var(--ink)}
.body img{width:100%;height:auto;display:block;border-radius:var(--r3);margin:8px 0 4px;box-shadow:var(--sh)}
.body figure{margin:24px 0}
.body figure img{margin:0}
.body figure.fig-4x3 .frame img,.body .fig-4x3 img{width:100%;height:auto;display:block;object-fit:contain}
.body figcaption,.body .cap{font-family:var(--mono);font-size:11px;color:var(--muted);margin:8px 0 0}
.body blockquote{border-left:3px solid var(--brass);background:var(--mist);padding:16px 22px;margin:24px 0;border-radius:0 var(--r3) var(--r3) 0;font-size:18px;color:#2a2722}
.body blockquote p{margin:0}

/* responsive table wrap (importer-friendly; functions.php wraps tables in .table-wrap) */
.table-wrap{overflow-x:auto;margin:24px 0;border:1px solid var(--line);border-radius:var(--r3)}
.body table{width:100%;border-collapse:collapse;font-size:15px;background:var(--paper)}
.body table th,.body table td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.body table th{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--brass-d);background:var(--cream)}
.body table tr:last-child td{border-bottom:0}

/* table of contents (functions.php hv_build_toc output) */
.toc-lbl{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--brass-d);display:flex;align-items:center;gap:8px;margin-bottom:10px}
.toc-lbl svg{width:15px;height:15px}
.body nav[aria-label="Table of contents"]{background:var(--paper);border:1px solid var(--line);border-radius:var(--r3);padding:18px 22px;margin:24px 0 28px}
.body nav[aria-label="Table of contents"] ol{counter-reset:toc;list-style:none;margin:0}
.body nav[aria-label="Table of contents"] li{counter-increment:toc;margin:6px 0;padding-left:26px;position:relative}
.body nav[aria-label="Table of contents"] li::before{content:counter(toc);position:absolute;left:0;top:2px;font-family:var(--mono);font-size:11px;color:var(--brass-d)}
.body nav[aria-label="Table of contents"] a{color:#3a352e;font-weight:600;border:0}
.body nav[aria-label="Table of contents"] a:hover,.body nav[aria-label="Table of contents"] a.active{color:var(--pine)}

/* honest-answer lead block (authors can add <div class="answer">) */
.answer{background:var(--mist);border-left:3px solid var(--brass);border-radius:0 var(--r3) var(--r3) 0;padding:20px 24px;margin:26px 0}
.answer .k{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--brass-d);margin-bottom:7px}
.answer p{font-size:18.5px;line-height:1.55;margin:0;color:#2a2722}
.answer p b{color:var(--pine)}

/* ranked fix-order (info-gain artifact, NOT a table) */
.fixorder{margin:28px 0;border:1px solid var(--line);border-radius:var(--r3);overflow:hidden;background:var(--paper)}
.fixorder .fh{background:var(--pine);color:#fff;padding:14px 22px;font-family:var(--disp);font-size:18px;font-weight:600;display:flex;align-items:center;gap:10px}
.fixorder .fh .t{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--brass-l);margin-left:auto;font-weight:500}
.fixorder .step{display:flex;gap:16px;padding:17px 22px;border-bottom:1px solid var(--line);align-items:flex-start}
.fixorder .step:last-child{border-bottom:0}
.fixorder .step .n{flex:0 0 auto;width:32px;height:32px;border-radius:var(--r1);background:var(--brass);color:#231a0d;font-family:var(--disp);font-weight:700;display:grid;place-items:center;font-size:16px;margin-top:1px}
.fixorder .step h4{font-size:17px;margin-bottom:3px}
.fixorder .step p{font-size:15px;color:#4a463e;line-height:1.5;margin:0}
.fixorder .step .pct{font-family:var(--mono);font-size:11px;color:var(--brass-d);display:block;margin-top:4px}

/* honest stop-line callout */
.callout{display:flex;gap:14px;background:rgba(168,80,46,.08);border:1px solid rgba(168,80,46,.25);border-radius:var(--r3);padding:18px 22px;margin:28px 0}
.callout .ic{flex:0 0 auto;width:34px;height:34px;border-radius:50%;background:var(--rust);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--disp)}
.callout b{font-family:var(--disp);font-size:16.5px;display:block;margin-bottom:3px}
.callout p{font-size:15px;color:#4a463e;line-height:1.5;margin:0}

/* FAQ accordion (functions.php hv_faq output - native details/summary, no FAQPage) */
.faq-section{padding:8px 0 0}
.faq-section .sec-h{margin:16px 0 18px}
.faq-section .sec-h .k{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--brass-d);display:block;margin-bottom:6px}
.faq-section .sec-h h2{font-size:27px}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{border:1px solid var(--line);border-radius:var(--r3);background:var(--paper);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:16px 20px;font-family:var(--disp);font-size:17px;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:12px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:focus-visible{outline:2px solid var(--brass);outline-offset:-2px}
.faq-item .chev{flex:0 0 auto;color:var(--brass-d);transition:transform .2s}
.faq-item[open] .chev{transform:rotate(180deg)}
.faq-item .faq-body{padding:0 20px 18px}
.faq-item .faq-body p{font-size:15.5px;color:#4a463e;line-height:1.6;margin:0}
.faq-item .faq-body a{color:var(--pine);font-weight:600}

/* sources (functions.php hv_sources output) */
.refs{margin:40px 0 10px;border-top:2px solid var(--brass);padding-top:20px}
.refs .refs-lbl{font-family:var(--disp);font-size:20px;font-weight:600;display:flex;align-items:center;gap:9px;margin:0 0 12px}
.refs .refs-lbl svg{width:18px;height:18px;color:var(--brass-d)}
.refs ol{list-style:none;counter-reset:s;margin:0}
.refs li{counter-increment:s;font-size:14.5px;padding:9px 0 9px 30px;position:relative;border-bottom:1px solid var(--line);color:#3a352e}
.refs li:last-child{border-bottom:0}
.refs li::before{content:counter(s);position:absolute;left:0;top:9px;font-family:var(--mono);font-size:11px;color:var(--brass-d);font-weight:500}
.refs li a{color:var(--pine);font-weight:600}
.refs li .desc{display:block;color:var(--muted);font-size:13px;margin-top:2px}

/* author card */
.author{display:flex;gap:16px;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--r3);padding:20px 22px;margin:34px 0 8px}
.author .av{flex:0 0 auto;width:54px;height:54px;border-radius:50%;background:var(--mist);display:grid;place-items:center;overflow:hidden}
.author .av img{width:54px;height:54px;object-fit:cover}
.author h3{font-family:var(--disp);font-size:18px;font-weight:600;margin-bottom:3px}
.author p{font-size:14px;color:var(--muted);line-height:1.55}
.author p a{color:var(--pine);font-weight:600}

/* read next (single.php) */
.readnext{background:var(--paper);border-top:1px solid var(--line);margin-top:40px;padding:50px 0}
.readnext .sec-head{max-width:760px;margin:0 auto 24px;padding:0 26px}
.readnext .sec-head h2{font-size:27px}
.readnext .cards{max-width:1160px;margin:0 auto;padding:0 26px;grid-template-columns:repeat(3,1fr)}
.readnext .card{background:var(--cream)}
.readnext .card img{width:100%;height:160px;object-fit:cover;display:block}
.readnext .card .b{padding:16px 18px}
.readnext .card .b h3{font-size:18px;line-height:1.2;margin-bottom:5px}
.readnext .card .b p{font-size:13px;color:var(--muted)}

/* reading progress bar */
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--brass);z-index:120;transition:width .08s linear}

/* ==========================================================================
   PAGE (page.php) - readable column wrapper
   ========================================================================== */
.pagewrap{max-width:760px;margin:0 auto;padding:30px 26px 64px}
.pagewrap h1{font-size:clamp(30px,4.4vw,46px);line-height:1.08;margin-bottom:24px;font-variation-settings:'opsz' 80}
.pagewrap .body{padding-top:0}
.pagewrap .body h2{font-size:25px;margin:34px 0 4px}

/* ==========================================================================
   INDEX / SEARCH / pagination / 404
   ========================================================================== */
.listwrap{padding:40px 0 64px}
.listwrap h1{font-family:var(--disp);font-weight:600;font-size:clamp(28px,3.6vw,40px);line-height:1.05;margin:6px 0 26px}
.pagination{margin:40px 0 0;display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.pagination .page-numbers{font-family:var(--mono);font-size:14px;font-weight:500;padding:9px 15px;border:1px solid var(--line);border-radius:var(--r2);background:#fff;color:#3a352e;transition:.15s}
.pagination .page-numbers:hover{border-color:var(--brass);color:var(--pine)}
.pagination .page-numbers.current{background:var(--pine);color:#fff;border-color:var(--pine)}
.page-404{min-height:54vh;display:grid;place-items:center;text-align:center;padding:60px 26px}
.page-404 .code{font-family:var(--disp);font-size:90px;font-weight:700;color:var(--brass);line-height:1;font-variant-numeric:lining-nums}
.page-404 h1{font-family:var(--disp);font-size:32px;font-weight:600;margin:8px 0 12px}
.page-404 p{color:var(--muted);font-size:16px;max-width:440px;margin:0 auto 24px;line-height:1.6}
.page-404 .btn-cta{display:inline-block;font-size:15.5px;font-weight:700;background:var(--pine);color:#fff;padding:13px 26px;border-radius:var(--r2)}
.page-404 .btn-cta:hover{background:var(--pine-d)}

/* ==========================================================================
   FOOTER (shared)
   ========================================================================== */
footer{background:var(--pine-d);color:#aec4b6}
footer .wrap{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;padding:56px 26px 28px}
footer .logo{color:#fff;margin-bottom:12px}
footer .logo img{height:30px}
footer p.about{font-size:14px;color:#9bb3a4;max-width:280px;line-height:1.6}
footer h4{font-family:var(--mono);font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--brass-l);margin-bottom:14px}
footer a{font-size:14.5px;color:#aec4b6;display:block;margin-bottom:9px}
footer a:hover{color:#fff}
footer a:focus-visible{outline:2px solid var(--brass-l);outline-offset:3px}
.copy{font-size:12.5px;color:#9bb3a4;text-align:center;padding:18px;border-top:1px solid rgba(255,255,255,.08)}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media(max-width:980px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .toolkit .tk{grid-template-columns:repeat(3,1fr)}
  .trust .row{grid-template-columns:1fr;gap:8px}.trust .t{padding:24px 0 8px}
}
@media(max-width:880px){
  nav.main,.hactions .btn-diag,.search{display:none}.menutoggle{display:grid}
  .hero .wrap,.needle .row,.diaglayout{grid-template-columns:1fr;gap:30px}
  .cards.three,.readnext .cards{grid-template-columns:1fr}
  .feat{grid-template-columns:1fr}.feat img{order:-1;min-height:220px}
  .grid{grid-template-columns:1fr 1fr}
  .rpane{min-height:0}
  footer .wrap{grid-template-columns:1fr 1fr}footer .wrap>div:first-child{grid-column:1/-1}
}
@media(max-width:560px){
  section{padding:46px 0}
  .symlist{grid-template-columns:1fr 1fr;gap:10px}.sym{padding:15px 14px}
  .toolkit .tk{grid-template-columns:repeat(2,1fr)}
  .cards,.grid{grid-template-columns:1fr}
  .hero .sub{font-size:15.5px;margin-bottom:20px}
  .herogrid{gap:10px}.hg img{aspect-ratio:4/3}
  .stats{flex-wrap:wrap;gap:14px 0}.stats .s{padding-right:22px;margin-right:22px}.stats .s:last-child{flex-basis:100%;border-top:1px solid rgba(255,255,255,.18);padding-top:12px;margin-top:2px}
  .body{font-size:17px}.arthead h1{font-size:28px}
  .feat .txt{padding:28px 24px}
  footer .wrap{grid-template-columns:1fr}footer a{padding:9px 0;margin-bottom:0;border-bottom:1px solid rgba(255,255,255,.07)}
}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1!important;transform:none!important}*{animation:none!important;transition:none!important}html{scroll-behavior:auto}}
