/* MeasuredPatio — hand-written static. Design: Lokuma `swiss` (docs/DESIGN.md) + outdoor addendum
   (outdoor/docs/DESIGN_OUTDOOR.md), accent terracotta #C4622D. Rules: 0 radius, no shadow,
   visible-border grid, uppercase tracked labels, color-inversion hover, accent = functional signal
   only. Not overwritten by the builder. */
:root{
  --bg:#FFFFFF; --muted:#F5F5F5; --line:#D9D9D9; --sub:#797979; --ink:#000000;
  --acc:#C4622D; --acc-ink:#A94E1E;
  --ok:#0A7D33; --ok-bg:#E7F4EA; --warn:#7A5200; --warn-bg:#FFF3E0; --bad:#B3261E; --bad-bg:#FDEEEE;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --grot:"Space Grotesk",system-ui,sans-serif;
  --body:"Inter",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--body);
  font-size:16px;line-height:1.6;overflow-x:hidden;font-feature-settings:"kern";-webkit-font-smoothing:antialiased}
img,svg{max-width:100%}
a{color:inherit}
h1,h2,h3,h4,h5{font-family:var(--grot);font-weight:700;letter-spacing:-.01em;line-height:1.12;margin:0}
p{margin:0 0 1em}
main{display:block}
::selection{background:var(--acc);color:#fff}

.skip{position:absolute;left:-999px;top:0;background:#000;color:#fff;padding:10px 16px;z-index:100}
.skip:focus{left:8px;top:8px}
:focus-visible{outline:2px solid var(--acc);outline-offset:2px}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* ---------- header ---------- */
.topbar{background:var(--ink);color:#fff;font-size:12.5px;text-align:center;padding:8px 16px;letter-spacing:.01em}
.top{position:sticky;top:0;z-index:40;background:var(--bg);border-bottom:4px solid var(--ink);
  display:flex;align-items:center;gap:18px;padding:14px 22px}
.wordmark{display:flex;align-items:center;gap:9px;font-family:var(--grot);font-weight:700;font-size:20px;
  text-decoration:none;letter-spacing:-.01em}
.mark{width:15px;height:15px;background:var(--acc);display:inline-block}
.mainnav{display:flex;gap:20px;margin-left:8px}
.mainnav a{font-size:12px;text-transform:uppercase;letter-spacing:.09em;font-weight:600;text-decoration:none;
  color:var(--sub);padding:4px 0;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}
.mainnav a:hover,.mainnav a.active{color:var(--ink);border-color:var(--acc)}
.top-actions{margin-left:auto;display:flex;align-items:center;gap:12px}
.cart-btn{display:inline-flex;align-items:center;gap:7px;background:none;border:2px solid var(--ink);
  padding:7px 12px;font-family:var(--grot);font-weight:500;font-size:13px;cursor:pointer;color:var(--ink);
  transition:background .15s,color .15s}
.cart-btn svg{width:19px;height:19px}
.cart-btn:hover{background:var(--ink);color:#fff}
.cart-count{font-variant-numeric:tabular-nums;min-width:18px;text-align:center;background:var(--acc);color:#fff;
  font-size:11.5px;padding:1px 5px;font-family:var(--mono)}
.cart-btn:hover .cart-count{background:#fff;color:var(--ink)}
.preview-tag{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;
  color:var(--sub);border:1px solid var(--line);padding:3px 7px}
.meta-strip{font-family:var(--mono);font-size:11.5px;color:var(--sub);text-transform:uppercase;letter-spacing:.06em;
  padding:8px 22px;border-bottom:1px solid var(--line);background:var(--muted)}

main{max-width:1120px;margin:0 auto;padding:0 22px}
.kicker{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--acc-ink);
  margin:0 0 14px;font-weight:600}
.kicker.warn{color:var(--warn)}
h1{font-size:clamp(28px,5vw,40px);margin:0 0 14px}
.display{font-size:clamp(34px,7vw,58px);line-height:1.03;letter-spacing:-.025em;margin:0 0 18px}
h2{font-size:clamp(21px,3.5vw,27px);margin:38px 0 14px}
h3{font-size:17px}
.sub{font-size:clamp(16px,2vw,19px);color:#2b2b2b;max-width:62ch;margin:0 0 22px;line-height:1.5}
.note{font-size:14px;color:var(--sub);line-height:1.5}
.warn-note{color:var(--warn);background:var(--warn-bg);border-left:4px solid var(--warn);padding:10px 14px;margin:12px 0}
.basis{font-size:13px;color:var(--sub);border-top:1px solid var(--line);padding-top:12px;margin-top:18px;line-height:1.55}
.basis code,.note code{font-family:var(--mono);font-size:12px;background:var(--muted);padding:1px 5px}
.fear{font-size:17px;font-style:italic;color:#2b2b2b;border-left:4px solid var(--acc);padding:6px 16px;margin:0 0 24px}
.crumbs{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--sub);margin:22px 0 18px}
.crumbs a{color:var(--acc-ink);text-decoration:none}
.crumbs a:hover{text-decoration:underline}
.crumbs span{margin:0 4px}
.tlink{color:var(--ink);font-weight:600;text-decoration:none;border-bottom:2px solid var(--acc);padding-bottom:1px}
.tlink:hover{background:var(--acc);color:#fff;border-color:var(--acc)}
.plain-list{margin:12px 0 24px;padding-left:20px}
.plain-list li{margin-bottom:8px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--grot);font-weight:500;
  font-size:15px;padding:12px 20px;border:2px solid var(--ink);background:var(--bg);color:var(--ink);
  text-decoration:none;cursor:pointer;min-height:44px;transition:background .15s,color .15s,border-color .15s}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--acc);border-color:var(--acc);color:#fff}
.btn-ghost{background:none}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-sm{font-size:13px;padding:8px 13px;min-height:38px}
.btn-lg{font-size:16px;padding:15px 26px}
.btn-block{width:100%}
.btn[disabled]{opacity:.4;cursor:not-allowed}

/* ---------- hero ---------- */
.hero{padding:52px 0 40px;border-bottom:1px solid var(--line)}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin:26px 0 34px;align-items:center}
.price-lead{font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--sub)}
.price-lead b{font-family:var(--grot);font-size:18px;color:var(--ink)}
.promise-row{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--ink)}
.promise{padding:20px;border-right:1px solid var(--line)}
.promise:last-child{border-right:none}
.promise b{font-family:var(--grot);display:block;font-size:15px;margin-bottom:6px}
.promise span{font-size:13.5px;color:var(--sub);line-height:1.45}

.band{padding:44px 0;border-bottom:1px solid var(--line)}
.band.alt{margin:0 -22px;padding:44px 22px;position:relative;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:24px 24px;background-color:var(--muted)}
.band.alt::before{content:"";position:absolute;inset:0;background:rgba(245,245,245,.94);pointer-events:none}
.band.alt>*{position:relative}
.split{display:grid;grid-template-columns:1.3fr 1fr;gap:34px;align-items:start}
.gate-note{border:2px solid var(--ink);background:var(--bg);padding:22px}
.gate-note .kicker.warn{margin-bottom:10px}

/* ---------- family / line card grids ---------- */
.fam-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--ink);border-right:0;border-bottom:0}
.fam-card{display:flex;flex-direction:column;gap:8px;padding:24px;text-decoration:none;color:var(--ink);
  border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);transition:background .15s,color .15s;position:relative}
.fam-card:hover{background:var(--ink);color:#fff}
.fam-card.slim{gap:0;justify-content:center}
.fam-n{font-family:var(--mono);font-size:12px;color:var(--acc-ink);letter-spacing:.1em}
.fam-card:hover .fam-n{color:#fff}
.fam-card h3{font-size:18px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.fam-card p{font-size:13.5px;color:var(--sub);margin:0;line-height:1.45}
.fam-card:hover p{color:#cfcfcf}
.fam-go{margin-top:auto;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--acc-ink);padding-top:8px}
.fam-card:hover .fam-go{color:var(--acc)}
.soon-badge{font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;
  color:var(--acc-ink);background:#f6ede7;border:1px solid var(--acc);padding:2px 6px;vertical-align:middle}
.fam-card:hover .soon-badge{color:#fff;border-color:#fff;background:transparent}

/* ---------- target (shape) cards ---------- */
.tcard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:2px solid var(--ink);border-right:0;border-bottom:0;margin:18px 0}
.tcard{display:grid;grid-template-columns:120px 1fr;border-right:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.tc-diagram{background:var(--muted);border-right:1px solid var(--line);display:flex;align-items:center;justify-content:center;padding:14px;color:var(--ink)}
.tc-diagram svg{width:100%;height:auto;max-height:96px}
.tc-body{padding:18px 20px;display:flex;flex-direction:column;gap:6px}
.tc-body h3{font-size:17px}
.tc-body p{font-size:13.5px;color:#2b2b2b;margin:0;line-height:1.45}
.tc-fear{font-style:italic;color:var(--sub)!important;font-size:13px!important}
.tc-meta{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--sub);margin-top:2px}
.tcard .btn{margin-top:8px;align-self:flex-start}

/* ---------- PDP ---------- */
.pdp{display:grid;grid-template-columns:0.9fr 1.1fr;gap:34px;margin:8px 0 10px;align-items:start}
.pdp-media{background:var(--muted);border:2px solid var(--ink);color:var(--ink);display:flex;
  align-items:center;justify-content:center;aspect-ratio:1.1/1;padding:36px}
.pdp-media svg{width:100%;height:auto;max-height:260px}
.pdp-info h1{font-size:clamp(22px,3.5vw,30px)}
.buybox{display:flex;align-items:center;gap:16px;flex-wrap:wrap;border:2px solid var(--ink);padding:18px;margin:16px 0}
.buybox .price{font-size:30px}
.cad-tag{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--sub)}
.buybox .btn{margin-left:auto}
.price{font-family:var(--grot);font-weight:700;font-size:19px;font-variant-numeric:tabular-nums}

/* ---------- verdict blocks ---------- */
.verdict{border:2px solid var(--ink);border-left-width:6px;padding:15px 18px;margin:16px 0}
.verdict h3{display:flex;align-items:center;gap:9px;font-size:15px;margin-bottom:5px}
.verdict p{margin:0;font-size:14px;color:#2b2b2b}
.verdict .dot{width:11px;height:11px;flex:none}
.verdict.fit{border-left-color:var(--ok);background:var(--ok-bg)}
.verdict.fit .dot{background:var(--ok)}
.verdict.fit h3{color:var(--ok)}
.verdict.warn{border-left-color:var(--warn);background:var(--warn-bg)}
.verdict.warn h3{color:var(--warn)}

/* ---------- compat / chips ---------- */
.fab-tier{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.07em;padding:2px 6px;border:1px solid currentColor;white-space:nowrap}
.tier-value{color:var(--sub)}
.tier-standard{color:var(--acc-ink)}
.tier-premium{color:var(--ink);background:var(--acc);border-color:var(--acc);color:#fff}

/* ---------- tables ---------- */
.tbl-wrap{overflow-x:auto;margin:16px 0}
table.spec{width:100%;border-collapse:collapse;border-top:2px solid var(--ink)}
table.spec th,table.spec td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top}
table.spec th{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--sub);
  font-weight:600;white-space:nowrap;width:200px}
table.spec thead th{color:var(--ink);border-bottom:2px solid var(--ink);width:auto}
table.spec .num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--grot);width:auto}
tr:hover td{background:var(--muted)}

/* ---------- fabrics library ---------- */
.fab-section{margin:26px 0}
.fabgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--ink);border-right:0;border-bottom:0}
.fabcard{border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);padding:20px;display:flex;flex-direction:column;gap:12px}
.fab-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.fab-head h3{font-size:16px}
.fab-spec{border-top:1px solid var(--line);margin:0}
.fab-spec th{width:88px;padding:7px 0;border-bottom:1px solid var(--line)}
.fab-spec td{padding:7px 0 7px 10px;border-bottom:1px solid var(--line);font-size:13px}
.fab-honest{font-size:13px;color:#2b2b2b;background:var(--muted);border-left:3px solid var(--acc);padding:8px 12px;margin:0;line-height:1.45}
.fab-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-right:0;border-bottom:0;margin:16px 0}
.fab-mini{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px;display:flex;flex-direction:column;gap:6px}
.fab-mini b{font-family:var(--grot);font-size:14px}
.fab-mini span{font-size:12.5px;color:var(--sub);line-height:1.4}
.fab-mini .fab-tier{align-self:flex-start}
.sw-row{display:flex;gap:5px;flex-wrap:wrap;margin-top:2px}
.sw{width:18px;height:18px;border:1px solid rgba(0,0,0,.25);display:inline-block}

/* ---------- faq ---------- */
.faq{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;font-family:var(--grot);font-weight:500;font-size:16px;padding:15px 30px 15px 0;
  position:relative;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:13px;font-size:20px;color:var(--acc);transition:transform .15s}
.faq[open] summary::after{content:"\2013"}
.faq p{padding:0 0 16px;margin:0;font-size:14.5px;color:#2b2b2b;max-width:70ch}

/* ---------- check / track box ---------- */
.check-box{border:2px solid var(--ink);padding:22px;margin:18px 0;max-width:560px;display:flex;flex-direction:column;gap:6px}
.check-box label{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--sub);margin-top:10px}
.check-box select,.check-box input{font-size:16px;font-family:var(--body);padding:12px;border:2px solid var(--ink);
  background:var(--bg);width:100%;min-height:48px}
.check-box .btn{margin-top:16px}
.capture-card{border:2px solid var(--ink);border-top:6px solid var(--acc);padding:24px;max-width:560px;margin:20px 0}
.capture-card .rempty{color:var(--sub);font-size:14px;margin-bottom:16px}

/* ---------- measure diagrams (diagrams.js) ---------- */
.furn{color:inherit}
.dg{stroke:#c2c2c2}
.dg text{fill:#9a9a9a;stroke:none}
.dg.act{stroke:var(--acc)}
.dg.act text{fill:var(--acc-ink)}
[data-diagram]{color:var(--ink)}
.pick-card:hover [data-diagram],.pick-card:hover .pick-diagram{color:#fff}

/* =====================================================================
   MEASURE WIZARD
   ===================================================================== */
.wiz{border:2px solid var(--ink);margin:8px 0 24px;display:flex;flex-direction:column;min-height:min(72vh,620px)}
.wiz-rail{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:2px solid var(--ink);background:var(--muted)}
.wiz-count{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--sub);white-space:nowrap}
.wiz-bar{flex:1;display:flex;gap:4px}
.wiz-seg{flex:1;height:6px;background:var(--line)}
.wiz-seg.on{background:var(--acc)}
.wiz-seg.done{background:var(--ink)}
.wiz-target{font-family:var(--grot);font-weight:500;font-size:13px;white-space:nowrap;max-width:38%;overflow:hidden;text-overflow:ellipsis}
.wiz-stage{flex:1;padding:26px 24px}
.wiz-anim{animation:wizIn .18s ease-out}
@keyframes wizIn{from{opacity:0;transform:translateX(8px)}to{opacity:1;transform:none}}

/* step 0: target picker */
.wiz-pick h1{font-size:clamp(24px,4vw,32px);margin-bottom:6px}
.wiz-pick .sub{margin-bottom:22px}
.pick-groups{display:flex;flex-direction:column;gap:22px}
.pick-glabel{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.09em;color:var(--acc-ink);margin:0 0 10px;font-weight:600}
.pick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--ink);border-right:0;border-bottom:0}
.pick-card{display:flex;flex-direction:column;align-items:flex-start;gap:8px;text-align:left;padding:18px;background:var(--bg);
  border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);cursor:pointer;color:var(--ink);
  transition:background .15s,color .15s;font-family:var(--body)}
.pick-card:hover{background:var(--ink);color:#fff}
.pick-diagram{width:100%;height:76px;display:flex;align-items:center;justify-content:center;color:inherit}
.pick-diagram svg{max-height:76px;width:auto}
.pick-card b{font-family:var(--grot);font-size:14.5px}
.pick-card span{font-size:12.5px;color:var(--sub);line-height:1.4}
.pick-card:hover span{color:#cfcfcf}

/* dimension step: figure + form */
.wiz-step{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}
.wiz-figure{background:var(--muted);border:2px solid var(--ink);padding:22px;position:sticky;top:96px;
  display:flex;align-items:center;justify-content:center;min-height:260px}
.wiz-figure svg{width:100%;height:auto;max-height:300px}
.wiz-form .kicker{margin-bottom:10px}
.wiz-form h2{margin:0 0 10px;font-size:clamp(20px,3.2vw,26px)}
.wiz-instr{font-size:15.5px;color:#2b2b2b;margin-bottom:18px;line-height:1.5}
.wiz-input{display:flex;align-items:stretch;gap:0;border:2px solid var(--ink);max-width:340px;margin-bottom:8px}
.wiz-input input{flex:1;min-width:0;font-family:var(--grot);font-weight:700;font-size:26px;font-variant-numeric:tabular-nums;
  padding:12px 16px;border:0;background:var(--bg);color:var(--ink);min-height:56px}
.wiz-input input:focus{outline:none;background:#fff8f4}
.unit-toggle{display:flex;border-left:2px solid var(--ink)}
.unit-toggle button{width:52px;border:0;background:var(--bg);font-family:var(--mono);font-size:13px;text-transform:uppercase;
  letter-spacing:.06em;cursor:pointer;color:var(--sub);border-left:1px solid var(--line)}
.unit-toggle button:first-child{border-left:0}
.unit-toggle button.on{background:var(--ink);color:#fff}
.wiz-hint{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--sub);margin:0 0 16px}
.opt-row{display:flex;gap:0;border:2px solid var(--ink);max-width:340px;margin:4px 0 8px}
.opt{flex:1;padding:14px 8px;border:0;border-left:2px solid var(--ink);background:var(--bg);font-family:var(--grot);
  font-weight:500;font-size:15px;cursor:pointer;color:var(--ink);min-height:52px;transition:background .15s,color .15s}
.opt:first-child{border-left:0}
.opt.on{background:var(--acc);color:#fff}
.opt:hover:not(.on){background:var(--muted)}
.wiz-tip{display:flex;gap:9px;align-items:flex-start;font-size:13.5px;color:#2b2b2b;background:var(--muted);
  border-left:3px solid var(--acc);padding:10px 13px;margin:14px 0 0;line-height:1.45}
.wiz-tip svg{width:17px;height:17px;flex:none;color:var(--acc);margin-top:1px}
.wiz-err{display:flex;gap:8px;align-items:flex-start;font-size:13.5px;color:var(--warn);background:var(--warn-bg);
  border-left:3px solid var(--warn);padding:10px 13px;margin:12px 0 0;line-height:1.45}
.wiz-err[hidden]{display:none}
.q-saved[hidden]{display:none}
.wiz-nav{display:flex;gap:12px;padding:18px 24px;border-top:2px solid var(--ink);margin-top:auto;background:var(--bg)}
.wiz-nav .btn{min-width:120px}
.wiz-nav .spacer{flex:1}
.wiz-escape{margin:18px 0 0;font-size:13px}
.wiz-escape a{color:var(--sub);text-decoration:none;border-bottom:1px solid var(--line);cursor:pointer}
.wiz-escape a:hover{color:var(--acc-ink);border-color:var(--acc)}

/* concierge (U4) */
.pick-concierge{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  border:2px solid var(--ink);border-top:4px solid var(--acc);padding:20px 22px;margin-top:22px;background:var(--muted)}
.pick-concierge b{font-family:var(--grot);font-size:15px;display:block;margin-bottom:4px}
.pick-concierge span{font-size:13.5px;color:var(--sub);line-height:1.45;max-width:60ch}
.pick-concierge .btn{white-space:nowrap}
.cc-form{display:flex;flex-direction:column;gap:6px;max-width:560px;margin:18px 0;border:2px solid var(--ink);padding:22px}
.cc-form label{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--sub);margin-top:12px}
.cc-form input,.cc-form textarea{font-size:16px;font-family:var(--body);padding:11px 12px;border:2px solid var(--ink);background:var(--bg);width:100%}
.cc-form input[type=file]{padding:9px;font-family:var(--mono);font-size:12.5px}
.cc-form .btn{margin-top:18px}
.cc-done{color:var(--ok);font-weight:600;max-width:560px;border-left:4px solid var(--ok);background:var(--ok-bg);padding:12px 14px}
.cc-done[hidden]{display:none}

/* =====================================================================
   QUOTE CARD + FABRIC SELECTOR + VALIDATION ORDER
   ===================================================================== */
.quote-wrap{max-width:760px}
.quote-card{border:2px solid var(--ink)}
.q-top{padding:22px 24px;border-bottom:2px solid var(--ink)}
.q-top .kicker{margin-bottom:12px}
.q-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
.q-price{display:flex;align-items:baseline;gap:10px}
.q-amt{font-family:var(--grot);font-weight:700;font-size:clamp(40px,8vw,56px);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.q-unit{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--sub)}
.q-meta{display:flex;flex-direction:column;gap:6px;text-align:right}
.q-meta div{font-size:13.5px;color:#2b2b2b}
.q-meta b{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--sub);display:block}
.q-meta .q-dims{font-family:var(--grot);font-weight:700;font-size:17px;font-variant-numeric:tabular-nums}
.q-disclose{font-size:12.5px;color:var(--sub);margin:14px 0 0;line-height:1.45;font-style:italic}

.fab-select{padding:20px 24px;border-bottom:2px solid var(--ink)}
.fab-select .kicker{margin-bottom:12px}
.fab-opts{display:flex;flex-direction:column;gap:10px}
.fab-opt{display:grid;grid-template-columns:1fr auto;gap:6px 12px;text-align:left;padding:14px 16px;
  border:2px solid var(--line);background:var(--bg);cursor:pointer;color:var(--ink);font-family:var(--body);
  transition:border-color .15s,background .15s}
.fab-opt:hover{border-color:var(--ink)}
.fab-opt.on{border-color:var(--acc);background:#fdf6f1}
.fo-head{display:flex;align-items:center;gap:9px;grid-column:1}
.fo-head b{font-family:var(--grot);font-size:15px}
.fo-price{grid-column:2;grid-row:1/span 2;align-self:center;font-family:var(--grot);font-weight:700;font-size:20px;
  font-variant-numeric:tabular-nums;text-align:right}
.fo-spec{grid-column:1;font-family:var(--mono);font-size:11.5px;color:var(--sub);letter-spacing:.02em}
.fo-note{grid-column:1/-1;font-size:12.5px;color:#2b2b2b;line-height:1.4;margin-top:4px}
.fab-opt .sw-row{grid-column:1/-1;margin-top:6px}

.q-actions{padding:20px 24px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.q-actions .btn-primary{flex:1;min-width:220px}

.vo-block{margin:0 24px 22px;border:2px solid var(--ink);border-top:4px solid var(--acc);padding:16px 18px;background:#fdf9f6}
.vo-block .kicker{margin-bottom:8px}
.vo-block p{font-size:13.5px;color:#2b2b2b;margin:0;line-height:1.5}
.vo-price{display:inline-block;font-family:var(--grot);font-weight:700;color:var(--acc-ink);margin-top:4px}
.q-save{margin:0 24px 22px}
.q-save summary{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--acc-ink);cursor:pointer}
.q-save form{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.q-save input{flex:1;min-width:200px;font-size:16px;padding:11px 12px;border:2px solid var(--ink);background:var(--bg)}
.q-saved{color:var(--ok);font-weight:600;font-size:14px;margin-top:10px}

/* ---------- /my measurement file ---------- */
.mf-grid{display:grid;grid-template-columns:1fr;gap:0;border:2px solid var(--ink);border-bottom:0;margin:18px 0}
.mf-card{display:grid;grid-template-columns:120px 1fr;border-bottom:2px solid var(--ink)}
.mf-media{background:var(--muted);border-right:1px solid var(--line);display:flex;align-items:center;justify-content:center;padding:14px;color:var(--ink)}
.mf-media svg{width:100%;height:auto;max-height:86px}
.mf-body{padding:16px 20px;display:flex;flex-direction:column;gap:5px}
.mf-body h3{font-size:16px}
.mf-dims{font-family:var(--grot);font-weight:700;font-size:15px;font-variant-numeric:tabular-nums;margin:0;color:var(--acc-ink)}
.mf-meta{font-family:var(--mono);font-size:12px;color:var(--sub);margin:0}
.mf-status{margin:2px 0 0;font-size:13px}
.mf-status .mf-ok{color:var(--sub)}
.mf-status .mf-soft{color:var(--sub);font-style:italic}
.mf-status .mf-warn{color:var(--warn);font-weight:600}
.mf-status .mf-due{color:var(--acc-ink);font-weight:600}
.mf-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:10px}
.mf-rm{background:none;border:none;color:var(--sub);font-size:11px;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;text-decoration:underline;margin-left:auto}
.mf-rm:hover{color:var(--bad)}

/* ---------- cart drawer ---------- */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.42);opacity:0;visibility:hidden;transition:opacity .2s;z-index:60}
.cart-overlay.open{opacity:1;visibility:visible}
.cart-drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,94vw);background:var(--bg);border-left:4px solid var(--ink);
  transform:translateX(100%);transition:transform .2s ease-out;z-index:61;display:flex;flex-direction:column}
.cart-drawer.open{transform:translateX(0)}
.cart-drawer>header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:2px solid var(--ink)}
.cart-drawer h3{font-size:18px}
.cart-close{background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--ink);padding:0 4px}
.cart-items{flex:1;overflow-y:auto;padding:8px 20px}
.cart-item{display:grid;grid-template-columns:56px 1fr auto;gap:12px;align-items:start;padding:15px 0;border-bottom:1px solid var(--line)}
.ci-media{width:56px;height:56px;background:var(--muted);color:var(--ink);display:flex;align-items:center;justify-content:center;border:1px solid var(--line)}
.ci-media svg{width:38px;height:38px}
.ci-body b{font-family:var(--grot);font-weight:500;font-size:13.5px;display:block;line-height:1.3}
.ci-dims{font-family:var(--mono);font-size:11.5px;color:var(--acc-ink);display:block;margin-top:3px;letter-spacing:.02em}
.ci-body span.ci-sub{font-size:12px;color:var(--sub);display:block;margin-top:3px}
.ci-qty{display:inline-flex;align-items:center;gap:2px;vertical-align:middle;margin-top:6px}
.ci-qty button{width:26px;height:26px;border:1px solid var(--ink);background:var(--bg);cursor:pointer;font-size:15px;line-height:1;color:var(--ink)}
.ci-qty button:hover{background:var(--ink);color:#fff}
.ci-qty b{min-width:24px;text-align:center;font-variant-numeric:tabular-nums;font-size:13px}
.ci-price{font-family:var(--grot);font-weight:700;font-size:14px;font-variant-numeric:tabular-nums;text-align:right}
.ci-rm{background:none;border:none;color:var(--sub);font-size:11px;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;text-decoration:underline;margin-top:6px;display:block}
.ci-rm:hover{color:var(--bad)}
.cart-foot{border-top:2px solid var(--ink);padding:18px 20px}
.cart-foot .row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.cart-foot .row b{font-family:var(--grot);font-size:22px;font-variant-numeric:tabular-nums}
.cart-note{font-size:12px;color:var(--sub);margin:12px 0 0;text-align:center;line-height:1.45}
.cart-empty{color:var(--sub);font-size:14px;text-align:center;padding:36px 0}

/* ---------- footer ---------- */
.site-foot{background:var(--ink);color:#fff;margin-top:64px;padding:48px 22px 28px}
.foot-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:32px}
.foot-brand{font-family:var(--grot);font-weight:700;font-size:19px;display:flex;flex-direction:column;gap:10px}
.foot-brand .mark{width:14px;height:14px}
.foot-brand p{font-family:var(--body);font-weight:400;font-size:13.5px;color:#b9b9b9;line-height:1.5;margin:0}
.foot-grid h5{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.09em;color:#8f8f8f;margin:0 0 12px;font-weight:600}
.foot-grid a{display:block;color:#e2e2e2;text-decoration:none;font-size:14px;padding:5px 0}
.foot-grid a:hover{color:#fff;text-decoration:underline;text-decoration-color:var(--acc);text-underline-offset:3px}
.foot-bottom{max-width:1120px;margin:32px auto 0;padding-top:20px;border-top:1px solid #333;display:flex;
  flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:12.5px;color:#8f8f8f;line-height:1.5}
.foot-bottom a{color:#b9b9b9}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .split,.pdp,.wiz-step{grid-template-columns:1fr}
  .fam-grid,.fabgrid,.pick-grid{grid-template-columns:repeat(2,1fr)}
  .tcard-grid{grid-template-columns:1fr}
  .fab-mini-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .mainnav{display:none}
  .buybox .btn{margin-left:0;width:100%}
  .wiz-figure{position:static;min-height:200px}
  .wiz-figure svg{max-height:220px}
}
@media (max-width:560px){
  .promise-row{grid-template-columns:1fr}
  .promise{border-right:none;border-bottom:1px solid var(--line)}
  .promise:last-child{border-bottom:none}
  .fam-grid,.foot-grid,.fabgrid,.pick-grid{grid-template-columns:1fr}
  .tcard{grid-template-columns:88px 1fr}
  .split.cmp{grid-template-columns:1fr}
  .top{gap:12px;padding:12px 16px}
  main{padding:0 16px}
  .band.alt{margin:0 -16px;padding:36px 16px}
  .wiz-stage{padding:20px 16px}
  .wiz-rail{padding:12px 16px;gap:10px}
  .wiz-nav{padding:14px 16px}
  .wiz-nav .btn{min-width:0;flex:1}
  .q-head{gap:12px}
  .q-meta{text-align:left}
  .fo-price{grid-row:auto;grid-column:1;text-align:left}
}
