/* PartFit — hand-written static. Design system: Lokuma `swiss` (docs/DESIGN.md), accent teal #0E7C7B.
   Rules: 0 radius everywhere, no shadows, 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:#0E7C7B; --acc-ink:#0B5F5E;
  --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:22px;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:60ch;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)}

/* ---------- 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}
.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{background:var(--muted);margin:0 -22px;padding:44px 22px;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:24px 24px;background-blend-mode:normal;background-color:var(--muted);position:relative}
.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 / 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}
.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)}
.gate-badge{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;
  color:var(--warn);background:var(--warn-bg);padding:2px 6px;vertical-align:middle}

/* ---------- product grid / cards ---------- */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-right:0;border-bottom:0;margin:18px 0}
.pcard{display:flex;flex-direction:column;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg)}
.pc-media{display:flex;align-items:center;justify-content:center;aspect-ratio:1.3/1;background:var(--muted);
  color:var(--acc);border-bottom:1px solid var(--line);padding:24px}
.pc-media svg{width:64px;height:64px;opacity:.7}
.pcard:hover .pc-media{background:#eef4f4}
.pc-body{display:flex;flex-direction:column;gap:8px;padding:14px 15px 15px;flex:1}
.pc-link{text-decoration:none;color:var(--ink);display:flex;flex-direction:column;gap:5px}
.pc-fits{font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--acc-ink);font-weight:600}
.pc-title{font-family:var(--grot);font-weight:500;font-size:14px;line-height:1.3}
.pcard:hover .pc-title{text-decoration:underline}
.pc-meta{display:flex;flex-direction:column;gap:2px;font-size:12px;color:var(--sub);font-family:var(--mono)}
.pc-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:8px}
.price{font-family:var(--grot);font-weight:700;font-size:19px;font-variant-numeric:tabular-nums}

/* ---------- 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(--acc);display:flex;
  align-items:center;justify-content:center;aspect-ratio:1/1;padding:48px}
.pdp-media svg{width:140px;height:140px;opacity:.75}
.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:26px}
.buybox.gated{display:block;background:var(--warn-bg);border-color:var(--warn)}
.cad-tag{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--sub)}
.buybox .btn{margin-left:auto}

/* ---------- 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)}
.verdict.bad{border-left-color:var(--bad);background:var(--bad-bg)}
.verdict.bad h3{color:var(--bad)}

/* ---------- chips / compat links ---------- */
.chip-fit{display:inline-flex;align-items:center;gap:6px;font-size:12px;text-transform:uppercase;letter-spacing:.06em;
  font-weight:600;color:var(--ok);background:var(--ok-bg);border:1px solid var(--ok);padding:3px 9px;vertical-align:middle}
.chip-fit .dot{width:8px;height:8px;background:var(--ok);display:inline-block}
.cc-wrap{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}
.cc{font-size:13px;text-decoration:none;color:var(--ink);border:1px solid var(--ink);padding:6px 11px;
  transition:background .15s,color .15s}
.cc:hover{background:var(--acc);color:#fff;border-color:var(--acc)}

/* ---------- 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)}
table.spec .num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--grot);width:auto}
.cmp-tbl th{width:auto}
tr:hover td{background:var(--muted)}

/* ---------- split / comparison ---------- */
.cmp{margin:20px 0}
.cmp-col{border:2px solid var(--ink);padding:20px}
.cmp-col h3{margin-bottom:12px}
.cmp-col ul{margin:0;padding-left:18px}
.cmp-col li{font-size:14px;margin-bottom:8px;line-height:1.45}

/* ---------- checker / results ---------- */
.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}
#results{margin:18px 0 8px}
.result-head{border:2px solid var(--ink);border-left-width:6px;border-left-color:var(--ok);background:var(--ok-bg);padding:16px 18px;margin-bottom:6px}
.result-head.miss{border-left-color:var(--warn);background:var(--warn-bg)}
.result-head h2{margin:0 0 4px;font-size:19px}
.result-head p{margin:0;font-size:14px;color:#2b2b2b}
.result-note{font-size:13.5px;color:var(--sub);margin:14px 0 0}

/* ---------- 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}

/* ---------- capture / reminder ---------- */
.capture-card{border:2px solid var(--ink);border-top:6px solid var(--acc);padding:24px;max-width:520px;margin:20px 0}
.rform{display:flex;flex-direction:column;gap:6px}
.rform label{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--sub);margin-top:10px}
.rform input,.rform select{font-size:16px;padding:12px;border:2px solid var(--ink);background:var(--bg);min-height:48px}
.rform .btn{margin-top:16px}
.rdone{color:var(--ok);font-weight:600}
.gate-panel{border:2px solid var(--warn);background:var(--warn-bg);padding:18px;margin:16px 0}
.gate-panel p{margin:0;font-size:14px}
.gate-panel .kicker{margin-bottom:6px}

/* ---------- 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(400px,92vw);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:52px 1fr auto;gap:12px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line)}
.ci-media{width:52px;height:52px;background:var(--muted);color:var(--acc);display:flex;align-items:center;justify-content:center}
.ci-media svg{width:30px;height:30px;opacity:.7}
.ci-body b{font-family:var(--grot);font-weight:500;font-size:13.5px;display:block;line-height:1.3}
.ci-body span{font-size:12.5px;color:var(--sub);display:block;margin-top:4px;font-family:var(--mono)}
.ci-qty{display:inline-flex;align-items:center;gap:2px;vertical-align:middle}
.ci-qty button{width:24px;height:24px;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:22px;text-align:center;font-variant-numeric:tabular-nums;font-size:13px}
.ci-rm{background:none;border:none;color:var(--sub);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;text-decoration:underline}
.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}
.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{grid-template-columns:1fr}
  .fam-grid{grid-template-columns:repeat(2,1fr)}
  .pgrid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .mainnav{display:none}
  .buybox .btn{margin-left:0;width:100%}
}
@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,.pgrid,.foot-grid{grid-template-columns: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}
}

/* ==================================================================
   Layer-1 engine components (U6/U7/U8/U9). Same Swiss skeleton:
   0 radius, no shadows, hairline grid, color-inversion hover, teal signal.
   ================================================================== */

/* ---------- U9 seasonal pool band (home top) ---------- */
.seasonal{border:2px solid var(--ink);background:var(--acc);color:#fff;margin:22px 0 0}
.seasonal-in{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:22px 24px;flex-wrap:wrap}
.seasonal-in h2{font-size:clamp(20px,3vw,26px);margin:8px 0 6px;color:#fff}
.seasonal-in p{margin:0;font-size:14px;color:#e6f2f1;max-width:60ch;line-height:1.5}
.season-tag{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;
  background:#fff;color:var(--acc-ink);padding:3px 8px;font-weight:600}
.seasonal-cta{display:flex;flex-direction:column;gap:10px;flex:none}
.seasonal-cta .btn{border-color:#fff}
.seasonal-cta .btn-primary{background:#fff;color:var(--acc-ink)}
.seasonal-cta .btn-primary:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.seasonal-cta .btn-ghost{color:#fff}
.seasonal-cta .btn-ghost:hover{background:#fff;color:var(--acc-ink)}

/* ---------- U2 typeahead combobox (/check) ---------- */
.combo{position:relative}
.combo input{font-size:16px;font-family:var(--body);padding:12px;border:2px solid var(--ink);background:var(--bg);width:100%;min-height:48px}
.combo-list{position:absolute;left:0;right:0;top:calc(100% - 2px);z-index:20;list-style:none;margin:0;padding:0;
  background:var(--bg);border:2px solid var(--ink);max-height:320px;overflow-y:auto}
.combo-list li{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:11px 13px;
  cursor:pointer;border-bottom:1px solid var(--line)}
.combo-list li:last-child{border-bottom:none}
.combo-list li b{font-family:var(--grot);font-weight:500;font-size:14.5px}
.combo-list li span{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--sub)}
.combo-list li:hover,.combo-list li.on{background:var(--ink);color:#fff}
.combo-list li:hover span,.combo-list li.on span{color:#cfcfcf}
.browse-fallback{margin-top:12px}
.browse-fallback summary{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--acc-ink);cursor:pointer}
.browse-fallback select{font-size:16px;padding:12px;border:2px solid var(--ink);background:var(--bg);width:100%;min-height:48px;margin-top:10px}

/* ---------- honesty grade badges (three tiers) ---------- */
.grade{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;padding:3px 9px;border:1px solid;vertical-align:middle}
.grade::before{content:"";width:8px;height:8px;flex:none}
.grade-verified{color:var(--ok);background:var(--ok-bg);border-color:var(--ok)}
.grade-verified::before{background:var(--ok)}
.grade-official{color:var(--acc-ink);background:#e9f4f3;border-color:var(--acc)}
.grade-official::before{background:var(--acc)}
.grade-ai{color:var(--warn);background:var(--warn-bg);border-color:var(--warn)}
.grade-ai::before{background:var(--warn);clip-path:polygon(50% 0,100% 100%,0 100%)} /* triangle = caution */

/* ---------- U8 miss dual-track ---------- */
.miss-track{margin:14px 0}
.miss-loading{font-family:var(--mono);font-size:13px;color:var(--sub);padding:12px 0}
.miss-card{border:2px solid var(--ink);padding:20px}
.miss-card.ai{border-left:6px solid var(--warn)}
.miss-card.wait{border-left:6px solid var(--acc);background:var(--muted)}
.miss-card-head{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px}
.miss-card-head h3{font-size:18px}
.miss-card h3{font-size:18px;margin:0 0 8px}
.miss-oem{font-size:14px;margin:0 0 12px}
.miss-oem code,.miss-caveat code{font-family:var(--mono);font-size:12.5px;background:var(--bg);border:1px solid var(--line);padding:1px 6px}
.miss-lead{font-size:13px;font-weight:600;margin:14px 0 6px;color:#2b2b2b}
.miss-cands{list-style:none;margin:0 0 8px;padding:0;border-top:1px solid var(--line)}
.miss-cands li{padding:10px 0;border-bottom:1px solid var(--line)}
.miss-cands li a{text-decoration:none;color:var(--ink)}
.miss-cands li a:hover{text-decoration:underline;text-decoration-color:var(--acc)}
.miss-cands li b{font-family:var(--grot);font-weight:500;font-size:14.5px;display:block}
.miss-cands li span{font-size:13px;color:var(--sub);display:block;margin-top:2px}
.miss-verify{background:var(--warn-bg);border-left:4px solid var(--warn);padding:12px 14px;margin:12px 0}
.miss-verify ol{margin:6px 0 0;padding-left:20px}
.miss-verify li{font-size:14px;margin-bottom:5px}
.miss-caveat{font-size:13px;color:var(--sub);font-style:italic;line-height:1.5;border-top:1px solid var(--line);padding-top:12px;margin:12px 0 0}
.rform.inline{flex-direction:row;gap:8px;flex-wrap:wrap;margin-top:8px}
.rform.inline input{flex:1;min-width:200px;margin:0}
.rform.inline .btn{margin-top:0}
.miss-done{color:var(--ok);font-weight:600;margin:10px 0 0}

/* ---------- /my calendar (U6) ---------- */
.my-state{padding:8px 0}
.dev-card{border:2px solid var(--ink);margin:16px 0}
.dev-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 18px;border-bottom:2px solid var(--ink);background:var(--muted)}
.dev-head h3{font-size:17px}
.dev-remove{font-size:11px}
.cal-list{list-style:none;margin:0;padding:0}
.cal-item{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--line)}
.cal-item:last-child{border-bottom:none}
.cal-dot{width:12px;height:12px;flex:none;border:2px solid var(--ink)}
.cal-ok .cal-dot{background:var(--ok);border-color:var(--ok)}
.cal-soon .cal-dot{background:var(--warn);border-color:var(--warn)}
.cal-due .cal-dot{background:var(--bad);border-color:var(--bad)}
.cal-unknown .cal-dot{background:var(--bg)}
.cal-body{flex:1;min-width:0}
.cal-body b{font-family:var(--grot);font-weight:500;font-size:14.5px;display:block;line-height:1.3}
.cal-meta{font-family:var(--mono);font-size:12px;color:var(--sub);display:block;margin-top:3px}
.cal-due .cal-meta{color:var(--bad)}
.cal-item .btn{flex:none}
.mark-changed{font-size:inherit;border-bottom-width:1px}
.my-prefs{border:2px solid var(--ink);border-top:6px solid var(--acc);padding:20px;margin:26px 0}
.my-prefs h2{margin:0 0 12px;font-size:18px}
.my-prefs label{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--sub);display:block;margin-bottom:6px}
.my-prefs select{font-size:16px;padding:11px;border:2px solid var(--ink);background:var(--bg);min-height:46px;max-width:260px}
#my-prefs-note{color:var(--ok);font-weight:600;margin:10px 0}

/* ---------- U7 census card ---------- */
.census-card{border:2px dashed var(--acc);padding:20px;margin:22px 0}
.census-q{font-size:16px;line-height:1.5;margin:2px 0 16px;max-width:60ch}
.census-keys{display:flex;gap:10px;flex-wrap:wrap}

@media (max-width:560px){
  .seasonal-in{flex-direction:column;align-items:flex-start}
  .seasonal-cta{width:100%}
  .seasonal-cta .btn{width:100%}
  .cal-item{flex-wrap:wrap}
  .cal-item .btn{width:100%;margin-top:6px}
  .census-keys .btn{width:100%}
  .rform.inline{flex-direction:column}
  .rform.inline input{width:100%}
}
