:root{
  --ink:#0c0d10; --paper:#fff; --soft:#f7f6f3; --soft2:#efeee9;
  --line:#e6e5df; --muted:#6c6c66; --accent:#2533c9; --accent-ink:#1a247f;
  --good:#1f7a4d; --warn:#9a6b00;
  --r:14px; --maxw:1180px;
  --shadow:0 1px 2px rgba(12,13,16,.04),0 12px 32px -18px rgba(12,13,16,.22);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.6;font-size:16px;
  -webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.serif{font-family:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,"Times New Roman",serif}

/* ---------- header ---------- */
.topbar{background:var(--ink);color:#e9e9e6;font-size:13px;letter-spacing:.02em}
.topbar .wrap{display:flex;justify-content:center;gap:8px;padding:9px 24px;text-align:center}
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:34px;height:70px}
.brand{display:flex;align-items:baseline;gap:9px;font-weight:700;font-size:21px;letter-spacing:-.02em}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);align-self:center}
.brand small{font-weight:500;color:var(--muted);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.nav nav{display:flex;gap:28px;margin-left:8px}
.nav nav a{font-size:15px;color:#2b2b28;font-weight:500}
.nav nav a:hover{color:var(--accent)}
.nav .spacer{flex:1}
.cartbtn{display:flex;align-items:center;gap:7px;font-weight:600;font-size:15px;
  border:1px solid var(--line);padding:9px 16px;border-radius:999px;background:#fff}
.cartbtn:hover{border-color:var(--ink)}
.cartbtn .n{background:var(--accent);color:#fff;font-size:12px;min-width:20px;height:20px;
  border-radius:999px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}
.menutoggle{display:none;background:none;border:0;font-size:24px;cursor:pointer}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:600;font-size:15px;padding:14px 26px;border-radius:999px;cursor:pointer;
  border:1px solid transparent;transition:.15s;line-height:1}
.btn.primary{background:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-ink)}
.btn.ghost{background:#fff;border-color:var(--ink);color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:#fff}
.btn.lg{padding:17px 34px;font-size:16px}
.btn.block{width:100%}
.btn[disabled]{opacity:.45;cursor:not-allowed}

/* ---------- hero ---------- */
.hero{padding:78px 0 64px;border-bottom:1px solid var(--line);
  background:radial-gradient(1100px 460px at 78% -8%,#eef0ff 0,transparent 60%),var(--paper)}
.hero .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:22px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent)}
h1.display{font-size:clamp(38px,5.4vw,62px);line-height:1.04;letter-spacing:-.03em;font-weight:700}
.hero p.sub{font-size:18px;color:#3b3b37;margin:22px 0 32px;max-width:30em}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}
.trustline{margin-top:26px;font-size:13.5px;color:var(--muted);display:flex;align-items:center;gap:9px}
.herocard{background:var(--soft);border:1px solid var(--line);border-radius:24px;
  padding:34px;box-shadow:var(--shadow)}
.herocard .kit{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.herocard .kit:last-child{border-bottom:0}
.herocard .gl{width:52px;height:52px;border-radius:13px;background:#fff;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:24px;flex:0 0 auto}
.herocard .kit b{font-size:15px;display:block}
.herocard .kit span{font-size:13px;color:var(--muted)}
.herocard .price{margin-left:auto;font-weight:700}

/* ---------- sections ---------- */
section.blk{padding:72px 0}
.sechead{max-width:38em;margin-bottom:38px}
.sechead h2{font-size:clamp(26px,3.4vw,36px);letter-spacing:-.02em;line-height:1.12}
.sechead p{color:var(--muted);margin-top:12px;font-size:16.5px}
.kicker{font-size:12.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}

/* value props */
.props{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prop{border:1px solid var(--line);border-radius:var(--r);padding:28px;background:#fff}
.prop .ic{font-size:24px;width:46px;height:46px;border-radius:11px;background:var(--soft);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.prop h3{font-size:18px;letter-spacing:-.01em;margin-bottom:7px}
.prop p{font-size:14.5px;color:var(--muted)}

/* product grid */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pgrid.two{grid-template-columns:repeat(3,1fr)}
.card{border:1px solid var(--line);border-radius:var(--r);background:#fff;overflow:hidden;
  display:flex;flex-direction:column;transition:.16s}
.card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.card .thumb{aspect-ratio:4/3;background:linear-gradient(145deg,var(--soft),var(--soft2));
  display:flex;align-items:center;justify-content:center;position:relative;border-bottom:1px solid var(--line)}
.card .thumb .glyph{font-size:62px;filter:saturate(.9)}
.badge{position:absolute;top:14px;left:14px;background:var(--ink);color:#fff;font-size:11px;
  font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:6px 11px;border-radius:999px}
.badge.soon{background:var(--warn)}
.badge.kit{background:var(--accent)}
.card .body{padding:20px;display:flex;flex-direction:column;gap:7px;flex:1}
.card .cat{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.card h3{font-size:17.5px;letter-spacing:-.01em;line-height:1.25}
.card p.d{font-size:14px;color:var(--muted);flex:1}
.card .foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.card .price b{font-size:18px}
.card .price s{color:var(--muted);font-size:13.5px;margin-left:6px;font-weight:400}
.card .go{font-size:14px;font-weight:600;color:var(--accent)}

/* filters */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.filters a{font-size:14px;font-weight:500;padding:9px 16px;border-radius:999px;
  border:1px solid var(--line);background:#fff;color:#33332f}
.filters a.on,.filters a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* product detail */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:54px;padding:56px 0}
.pd .vis{aspect-ratio:1;background:linear-gradient(150deg,var(--soft),var(--soft2));
  border:1px solid var(--line);border-radius:20px;display:flex;align-items:center;justify-content:center}
.pd .vis .glyph{font-size:140px}
.pd h1{font-size:34px;letter-spacing:-.02em;line-height:1.12;margin:10px 0 14px}
.pd .lead{font-size:16.5px;color:#3b3b37;margin-bottom:22px}
.pd .priced{display:flex;align-items:baseline;gap:12px;margin-bottom:22px}
.pd .priced b{font-size:28px}
.pd .priced s{color:var(--muted);font-size:18px;font-weight:400}
.pd ul.specs{list-style:none;margin:20px 0;border-top:1px solid var(--line)}
.pd ul.specs li{padding:11px 0;border-bottom:1px solid var(--line);font-size:15px;
  display:flex;gap:10px}
.pd ul.specs li::before{content:"—";color:var(--accent)}
.pd .incl{background:var(--soft);border:1px solid var(--line);border-radius:14px;padding:20px 22px;margin:20px 0}
.pd .incl h4{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.pd .incl li{font-size:15px;padding:6px 0;display:flex;gap:9px}
.pd .incl li::before{content:"✓";color:var(--good);font-weight:700}
.warn{font-size:13.5px;color:var(--warn);margin-top:14px}
.soonbox{background:#fff7e8;border:1px solid #f0dca6;border-radius:14px;padding:18px 20px;margin:18px 0}
.soonbox b{display:block;margin-bottom:6px}

/* cart / forms */
.panel{border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:26px}
.crow{display:flex;align-items:center;gap:18px;padding:18px 0;border-bottom:1px solid var(--line)}
.crow:last-child{border-bottom:0}
.crow .g{width:60px;height:60px;border-radius:11px;background:var(--soft);display:flex;
  align-items:center;justify-content:center;font-size:28px;flex:0 0 auto}
.crow .qty{display:flex;align-items:center;gap:10px}
.crow .qty a{width:30px;height:30px;border:1px solid var(--line);border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-weight:600}
.summary{display:flex;justify-content:space-between;padding:9px 0;font-size:15px}
.summary.tot{border-top:1px solid var(--line);margin-top:10px;padding-top:16px;font-size:19px;font-weight:700}
label{display:block;font-size:13.5px;font-weight:600;margin:14px 0 6px}
input,textarea,select{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:10px;
  font:inherit;background:#fff}
input:focus,textarea:focus,select:focus{outline:2px solid var(--accent);border-color:transparent}
.flash{background:#eef6f0;border:1px solid #bfe0cc;color:var(--good);padding:13px 18px;
  border-radius:10px;margin:18px 0;font-size:14.5px}

/* email capture band */
.capture{background:var(--ink);color:#fff;border-radius:22px;padding:54px;text-align:center}
.capture h2{font-size:clamp(26px,3.4vw,38px);letter-spacing:-.02em}
.capture p{color:#bcbcb6;margin:14px auto 26px;max-width:34em}
.capture form{display:flex;gap:10px;max-width:480px;margin:0 auto}
.capture input{background:#191a1f;border-color:#34343a;color:#fff}
.capture input::placeholder{color:#85857e}

/* generic content */
.lede{font-size:19px;color:#3b3b37;max-width:34em}
.prose{max-width:42em;font-size:16.5px}
.prose h3{margin:28px 0 10px;font-size:21px;letter-spacing:-.01em}
.prose p{margin:14px 0;color:#33332f}
.glist{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.gcard{border:1px solid var(--line);border-radius:var(--r);padding:26px;background:#fff}
.gcard h3{font-size:18px;margin-bottom:8px;letter-spacing:-.01em}
.gcard p{font-size:14.5px;color:var(--muted)}

/* footer */
footer.site{background:var(--soft);border-top:1px solid var(--line);margin-top:80px;padding:60px 0 36px}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px}
footer h4{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
footer a{display:block;font-size:14.5px;color:#33332f;padding:5px 0}
footer a:hover{color:var(--accent)}
.fbrand{font-weight:700;font-size:20px;letter-spacing:-.02em;margin-bottom:10px}
.fbrand small{display:block;font-weight:500;color:var(--muted);font-size:13px;margin-top:8px;max-width:24em}
.fbot{border-top:1px solid var(--line);margin-top:40px;padding-top:24px;display:flex;
  justify-content:space-between;font-size:13px;color:var(--muted);flex-wrap:wrap;gap:8px}

@media(max-width:900px){
  .hero .grid,.pd,.props,.pgrid,.pgrid.two,.glist,.fgrid{grid-template-columns:1fr}
  .nav nav,.topbar{display:none}
  .menutoggle{display:block}
  .nav nav.open{display:flex;position:absolute;top:70px;left:0;right:0;background:#fff;
    flex-direction:column;padding:18px 24px;border-bottom:1px solid var(--line);gap:6px}
  .capture{padding:36px 22px}.capture form{flex-direction:column}
  section.blk{padding:52px 0}
}
