/* ============================================================
   Classic Woodworking & Vanity — Luxury Catalogue
   Print-ready system · 8.5 × 11 in portrait
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=Jost:wght@300;400;500;600&display=swap');

:root{
  --ink:        #14110d;
  --ink-2:      #1b1712;
  --ink-3:      #241e17;
  --ink-line:   rgba(227,190,115,.18);

  --ivory:      #f6f1e7;
  --ivory-2:    #efe6d6;
  --paper:      #fbf8f1;

  --gold:        #b88a3e;
  --gold-deep:   #9c6f2b;
  --gold-bright: #e3be73;
  --copper:      #b9722f;
  --gold-grad:   linear-gradient(105deg,#9c6f2b 0%,#d9b46e 38%,#f0d99a 52%,#cFa55f 66%,#9c6f2b 100%);
  --gold-grad-bright: linear-gradient(105deg,#b9722f 0%,#e9c87f 32%,#f3dc9a 50%,#e3b96e 68%,#b9722f 100%);

  --on-dark:      #ede5d6;
  --on-dark-mut:  #a99d86;
  --on-dark-faint:#6f6553;
  --on-light:     #2a241c;
  --on-light-mut: #6c6151;
  --on-light-faint:#9a8f7d;

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Jost', system-ui, sans-serif;

  --pw: 8.5in;
  --ph: 11in;
  --pad: 0.82in;
}

*{ box-sizing:border-box; }

html,body{ margin:0; padding:0; }
body{
  background:#3a342c;
  font-family:var(--sans);
  font-weight:300;
  color:var(--on-light);
  -webkit-font-smoothing:antialiased;
  -webkit-print-color-adjust:exact;
  print-color-adjust:exact;
}

/* ---------- screen viewer ---------- */
.viewer{ display:flex; flex-direction:column; align-items:center; gap:28px; padding:40px 16px 80px; counter-reset:pg; }
.page{ counter-increment:pg; }
.folio .pageno::before{ content:counter(pg, decimal-leading-zero); }
@media print{ .viewer{ display:block; gap:0; padding:0; } }

/* ---------- page ---------- */
.page{
  position:relative;
  width:var(--pw);
  height:var(--ph);
  overflow:hidden;
  background:var(--paper);
  color:var(--on-light);
  box-shadow:0 18px 50px rgba(0,0,0,.4);
}
@media print{
  .page{ box-shadow:none; break-after:page; margin:0; }
  .page:last-child{ break-after:auto; }
}
.page.dark{ background:var(--ink); color:var(--on-dark); }
.page.ivory{ background:var(--ivory); }
.pad{ position:absolute; inset:var(--pad); }

/* ---------- mobile: scale the fixed 8.5x11in pages to fit the screen ---------- */
@media (max-width:900px){
  .viewer{ padding:16px 10px 48px; gap:16px; }
  .page{ box-shadow:0 8px 26px rgba(0,0,0,.4); }
}

/* ---------- shared type ---------- */
.eyebrow{
  font-family:var(--sans); font-weight:500;
  font-size:9.5px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex; align-items:center; gap:.9em;
}
.dark .eyebrow{ color:var(--gold-bright); }
.eyebrow.line::before{ content:""; width:34px; height:1px; background:currentColor; opacity:.7; }

.display{ font-family:var(--serif); font-weight:500; line-height:1.02; letter-spacing:.004em; margin:0; }
.display em{ font-style:italic; }
.gold-text{
  background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.dark .gold-text{ background:var(--gold-grad-bright); -webkit-background-clip:text; background-clip:text; color:transparent; }

p{ text-wrap:pretty; }
.serif{ font-family:var(--serif); }

/* page number / running foot */
.folio{
  position:absolute; left:var(--pad); right:var(--pad); bottom:.5in;
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--sans); font-size:8px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--on-light-faint);
}
.dark .folio{ color:var(--on-dark-faint); }
.folio .brandmark{ font-family:var(--serif); font-style:italic; letter-spacing:.04em; font-size:11px; text-transform:none; }

/* hairline */
.rule{ height:1px; background:var(--ink-line); border:0; }
.rule.dark{ background:rgba(42,36,28,.16); }
.gold-rule{ height:2px; width:60px; background:var(--gold-grad); border:0; }

/* ============================================================
   COVER
   ============================================================ */
.cover .cover-img{ position:absolute; inset:0; }
.cover .cover-img img{ width:100%; height:100%; object-fit:cover; }
.cover .scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg,rgba(12,10,7,.62) 0%,rgba(12,10,7,.28) 32%,rgba(12,10,7,.55) 66%,rgba(12,10,7,.95) 100%);
}
.cover .frame{ position:absolute; inset:.34in; border:1px solid rgba(227,190,115,.45); pointer-events:none; }
.cover .cover-top{ position:absolute; top:.78in; left:0; right:0; text-align:center; }
.cover .cover-mono{ height:1.5in; width:auto; margin:0 auto; display:block; filter:drop-shadow(0 6px 24px rgba(0,0,0,.5)); }
.cover .cover-foot{ position:absolute; left:.78in; right:.78in; bottom:.92in; text-align:center; color:var(--on-dark); }
.cover h1{ font-family:var(--serif); font-weight:500; font-size:58px; line-height:.98; margin:0; }
.cover h1 em{ display:block; font-style:italic; }
.cover .cover-sub{ font-family:var(--sans); font-weight:400; font-size:11px; letter-spacing:.4em; text-transform:uppercase; color:var(--on-dark-mut); margin-top:22px; }
.cover .cover-vol{ position:absolute; left:0; right:0; bottom:.5in; text-align:center; font-family:var(--sans); font-size:8.5px; letter-spacing:.36em; text-transform:uppercase; color:var(--on-dark-faint); }

/* ============================================================
   OPENING STATEMENT
   ============================================================ */
.statement{ display:flex; flex-direction:column; justify-content:center; height:100%; text-align:center; }
.statement .q{ font-family:var(--serif); font-weight:400; font-size:38px; line-height:1.28; letter-spacing:.005em; max-width:6.4in; margin:0 auto; }
.statement .q em{ font-style:italic; }
.statement .by{ margin-top:36px; font-family:var(--sans); font-size:9px; letter-spacing:.34em; text-transform:uppercase; color:var(--on-dark-mut); }

/* ============================================================
   TABLE OF CONTENTS
   ============================================================ */
.toc-head{ margin-bottom:.5in; }
.toc-head h2{ font-family:var(--serif); font-weight:500; font-size:46px; margin:.2em 0 0; }
.toc-list{ list-style:none; margin:0; padding:0; }
.toc-list li{ display:flex; align-items:baseline; gap:14px; padding:14px 0; border-top:1px solid rgba(42,36,28,.14); }
.toc-list li:last-child{ border-bottom:1px solid rgba(42,36,28,.14); }
.toc-num{ font-family:var(--serif); font-style:italic; font-size:15px; color:var(--gold-deep); width:30px; flex:none; }
.toc-title{ font-family:var(--serif); font-size:21px; color:var(--on-light); }
.toc-dots{ flex:1; border-bottom:1px dotted rgba(42,36,28,.3); transform:translateY(-4px); }
.toc-pg{ font-family:var(--sans); font-size:12px; letter-spacing:.1em; color:var(--on-light-mut); }

/* ============================================================
   GENERIC EDITORIAL
   ============================================================ */
.kicker-head .eyebrow{ margin-bottom:18px; }
.kicker-head h2{ font-family:var(--serif); font-weight:500; font-size:44px; line-height:1.04; margin:0; max-width:7in; }
.lead{ font-family:var(--serif); font-weight:400; font-size:19px; line-height:1.5; color:var(--on-light); }
.dark .lead{ color:var(--on-dark); }
.body{ font-size:11.5px; line-height:1.78; color:var(--on-light-mut); }
.dark .body{ color:var(--on-dark-mut); }
.columns-2{ column-count:2; column-gap:.5in; }

/* brand story split */
.story-grid{ display:grid; grid-template-columns:1fr 1fr; height:100%; }
.story-media{ position:relative; }
.story-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.story-copy{ padding:var(--pad); display:flex; flex-direction:column; justify-content:center; }
.story-copy h2{ font-family:var(--serif); font-weight:500; font-size:40px; line-height:1.05; margin:.3em 0 0; }
.dropcap::first-letter{ font-family:var(--serif); font-size:58px; line-height:.7; float:left; padding:8px 12px 0 0; color:var(--gold-deep); font-weight:500; }

.stat-row{ display:flex; gap:34px; margin-top:30px; }
.stat .n{ font-family:var(--serif); font-weight:500; font-size:40px; line-height:1; }
.stat .l{ font-family:var(--sans); font-size:8.5px; letter-spacing:.22em; text-transform:uppercase; color:var(--on-light-mut); margin-top:7px; max-width:14ch; }
.dark .stat .l{ color:var(--on-dark-mut); }

/* ============================================================
   WHY CLASSIC — feature grid
   ============================================================ */
.why-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--ink-line); border:1px solid var(--ink-line); margin-top:.42in; }
.why-cell{ background:var(--ink); padding:30px 30px 34px; }
.ivory .why-grid{ background:rgba(42,36,28,.12); border-color:rgba(42,36,28,.12); }
.ivory .why-cell{ background:var(--ivory); }
.why-cell .wn{ font-family:var(--serif); font-style:italic; font-size:16px; color:var(--gold-deep); }
.why-cell h3{ font-family:var(--serif); font-weight:500; font-size:24px; margin:.4em 0 .4em; line-height:1.04; }
.why-cell p{ font-size:11px; line-height:1.7; color:var(--on-light-mut); margin:0; }
.dark .why-cell p{ color:var(--on-dark-mut); }

/* ============================================================
   SECTION DIVIDER
   ============================================================ */
.divider{ display:flex; flex-direction:column; justify-content:center; height:100%; }
.divider-media{ position:absolute; inset:0; }
.divider-media img{ width:100%; height:100%; object-fit:cover; }
.divider .scrim{ position:absolute; inset:0; background:linear-gradient(110deg,rgba(12,10,7,.92) 0%,rgba(12,10,7,.55) 55%,rgba(12,10,7,.2) 100%); }
.divider .d-inner{ position:relative; padding:var(--pad); }
.divider .d-no{ font-family:var(--serif); font-style:italic; font-size:20px; color:var(--gold-bright); }
.divider h2{ font-family:var(--serif); font-weight:500; font-size:62px; line-height:.98; margin:.1em 0 0; color:var(--on-dark); }
.divider .d-sub{ font-family:var(--serif); font-style:italic; font-size:21px; color:var(--on-dark-mut); margin-top:18px; max-width:5in; }

/* ============================================================
   COLLECTION PAGE
   ============================================================ */
.coll{ display:grid; grid-template-rows:62% 38%; height:100%; }
.coll-media{ position:relative; overflow:hidden; }
.coll-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.coll-tag{
  position:absolute; left:.5in; top:.5in;
  font-family:var(--sans); font-weight:500; font-size:9px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--gold-bright); background:rgba(12,10,7,.5); padding:7px 13px; backdrop-filter:blur(3px);
}
.coll-body{ padding:.5in var(--pad) 0; position:relative; }
.coll-head{ display:flex; justify-content:space-between; align-items:flex-end; }
.coll-index{ font-family:var(--serif); font-style:italic; font-size:15px; color:var(--gold-deep); }
.coll-body h2{ font-family:var(--serif); font-weight:500; font-size:46px; line-height:1; margin:.1em 0 0; }
.coll-pos{ font-family:var(--serif); font-style:italic; font-size:17px; color:var(--on-light-mut); text-align:right; max-width:3in; }
.coll-desc{ font-size:11.5px; line-height:1.7; color:var(--on-light-mut); margin:18px 0 0; max-width:4.4in; }
.coll-feats{ list-style:none; padding:0; margin:18px 0 0; display:grid; grid-template-columns:1fr 1fr 1fr; gap:9px 24px; }
.coll-feats li{ font-size:10px; color:var(--on-light); display:flex; gap:9px; align-items:baseline; }
.coll-feats li::before{ content:"—"; color:var(--gold-deep); }

/* ============================================================
   KITCHEN feature (full bleed)
   ============================================================ */
.kitchen{ position:relative; height:100%; }
.kitchen-img{ position:absolute; inset:0; }
.kitchen-img img{ width:100%; height:100%; object-fit:cover; }
.kitchen .scrim{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(12,10,7,.2) 0%,rgba(12,10,7,.1) 40%,rgba(12,10,7,.8) 78%,rgba(12,10,7,.97) 100%); }
.kitchen .k-copy{ position:absolute; left:var(--pad); right:var(--pad); bottom:1in; color:var(--on-dark); }
.kitchen h2{ font-family:var(--serif); font-weight:500; font-size:50px; line-height:1; margin:.2em 0 0; }
.kitchen .k-lead{ font-family:var(--serif); font-size:17px; line-height:1.5; color:var(--on-dark); max-width:5in; margin-top:16px; }

/* ============================================================
   CONSTRUCTION SPEC
   ============================================================ */
.spec-layout{ display:grid; grid-template-columns:1.15fr 1fr; gap:.42in; margin-top:.34in; }
.spec-diagram{ background:var(--ink-2); border:1px solid var(--ink-line); display:flex; align-items:center; justify-content:center; padding:14px; }
.spec-diagram svg{ width:100%; height:auto; }
.spec-cols{ display:flex; flex-direction:column; gap:14px; }
.spec-box{ border:1px solid var(--ink-line); }
.dark .spec-box{ background:var(--ink-2); }
.spec-box.feat{ box-shadow:inset 0 2px 0 var(--gold-bright); background:linear-gradient(168deg,#241c12,#16100a); }
.spec-bar{ padding:8px 14px; border-bottom:1px solid var(--ink-line); background:var(--ink-3); }
.spec-bar h3{ font-family:var(--sans); font-weight:600; font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-bright); margin:0; }
.spec-body{ padding:12px 14px 14px; }
.spec-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:6px; }
.spec-list li{ font-size:9.5px; color:var(--on-dark); display:flex; gap:8px; align-items:flex-start; line-height:1.4; }
.spec-list li::before{ content:"✓"; color:var(--gold-bright); flex:none; font-size:9px; }
.spec-list li.neg{ color:var(--on-dark-mut); }
.spec-list li.neg::before{ content:"✕"; color:var(--copper); }
.spec-note{ font-family:var(--serif); font-size:11px; color:var(--on-dark); margin:0 0 9px; line-height:1.45; }
.spec-note strong{ color:var(--gold-bright); font-weight:600; }

/* construction features strip */
.cfeat-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--ink-line); border:1px solid var(--ink-line); margin-top:.32in; }
.cfeat{ background:var(--ink); padding:18px 18px 20px; }
.cfeat .cf-n{ font-family:var(--serif); font-style:italic; font-size:14px; color:var(--gold-bright); }
.cfeat h4{ font-family:var(--serif); font-weight:500; font-size:17px; margin:.3em 0 .3em; }
.cfeat p{ font-size:9px; line-height:1.6; color:var(--on-dark-mut); margin:0; }

/* ============================================================
   MATERIALS
   ============================================================ */
.mat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px 16px; margin-top:.42in; }
.mat{ }
.mat-swatch{ height:1.35in; border:1px solid rgba(42,36,28,.16); position:relative; overflow:hidden; }
.dark .mat-swatch{ border-color:var(--ink-line); }
.mat-name{ font-family:var(--serif); font-size:15px; margin:11px 0 2px; }
.mat-meta{ font-family:var(--sans); font-size:8px; letter-spacing:.16em; text-transform:uppercase; color:var(--on-light-mut); }
.dark .mat-meta{ color:var(--on-dark-mut); }
/* wood grain overlay */
.grain{ background-image:repeating-linear-gradient(96deg, rgba(0,0,0,.06) 0 2px, transparent 2px 7px); }

/* ============================================================
   DOOR STYLES
   ============================================================ */
.door-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px 20px; margin-top:.42in; }
.door{ }
.door-art{ height:2.1in; background:var(--ivory-2); border:1px solid rgba(42,36,28,.14); display:flex; align-items:center; justify-content:center; }
.dark .door-art{ background:var(--ink-2); border-color:var(--ink-line); }
.door-art svg{ width:72%; height:78%; }
.door-name{ font-family:var(--serif); font-size:17px; margin:12px 0 2px; }
.door-desc{ font-size:9.5px; line-height:1.55; color:var(--on-light-mut); }
.dark .door-desc{ color:var(--on-dark-mut); }

/* ============================================================
   HARDWARE
   ============================================================ */
.hw-feature{ display:grid; grid-template-columns:1fr 1fr; gap:.5in; align-items:center; margin-top:.34in; }
.hw-photo{ background:#efe7d6; border:1px solid rgba(42,36,28,.14); padding:18px; display:flex; align-items:center; justify-content:center; height:2.6in; }
.hw-photo img{ max-width:100%; max-height:100%; object-fit:contain; mix-blend-mode:multiply; }
.hw-list{ list-style:none; margin:14px 0 0; padding:0; }
.hw-list li{ padding:11px 0; border-top:1px solid rgba(42,36,28,.14); font-size:11px; display:flex; gap:12px; }
.dark .hw-list li{ border-color:var(--ink-line); color:var(--on-dark); }
.hw-list li:last-child{ border-bottom:1px solid rgba(42,36,28,.14); }
.hw-list .hk{ font-family:var(--serif); font-style:italic; color:var(--gold-deep); min-width:1.1in; }
.dark .hw-list .hk{ color:var(--gold-bright); }
.finish-row{ display:flex; gap:16px; margin-top:.4in; }
.finish{ text-align:center; }
.finish .chip{ width:54px; height:54px; border-radius:50%; margin:0 auto 9px; border:1px solid rgba(0,0,0,.12); }
.finish .fn{ font-family:var(--sans); font-size:8px; letter-spacing:.12em; text-transform:uppercase; color:var(--on-light-mut); }
.dark .finish .fn{ color:var(--on-dark-mut); }

/* ============================================================
   PROCESS
   ============================================================ */
.proc-grid{ display:grid; grid-template-columns:repeat(2,1fr); grid-template-rows:1fr 1fr; gap:1px; background:var(--ink-line); border:1px solid var(--ink-line); height:7.1in; margin-top:.34in; }
.proc-cell{ position:relative; overflow:hidden; }
.proc-cell img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.proc-cell .scrim{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(12,10,7,.15) 0%,rgba(12,10,7,.45) 55%,rgba(12,10,7,.94) 100%); }
.proc-cell .pc-copy{ position:absolute; left:26px; right:26px; bottom:24px; color:var(--on-dark); }
.proc-cell .pc-n{ font-family:var(--serif); font-style:italic; font-size:26px; color:var(--gold-bright); }
.proc-cell h3{ font-family:var(--sans); font-weight:600; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-bright); margin:.5em 0 .5em; }
.proc-cell p{ font-size:9.5px; line-height:1.6; color:var(--on-dark); margin:0; max-width:3in; }

/* ============================================================
   WARRANTY
   ============================================================ */
.warr-grid{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:1px; background:var(--ink-line); border:1px solid var(--ink-line); margin-top:.42in; }
.warr{ background:var(--ink); padding:26px 24px 30px; text-align:center; }
.warr .seal{ font-family:var(--serif); font-weight:500; font-size:40px; line-height:1; }
.warr h3{ font-family:var(--sans); font-weight:500; font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-bright); margin:1em 0 .7em; }
.warr p{ font-size:9.5px; line-height:1.65; color:var(--on-dark-mut); margin:0; }

/* ============================================================
   CONTACT / BACK
   ============================================================ */
.contact-page{ display:flex; flex-direction:column; justify-content:center; height:100%; text-align:center; }
.contact-page .c-mono{ height:1.15in; width:auto; margin:0 auto 30px; }
.contact-page h2{ font-family:var(--serif); font-weight:500; font-size:44px; margin:0; }
.contact-page .c-tag{ font-family:var(--serif); font-style:italic; font-size:18px; color:var(--on-dark-mut); margin-top:14px; }
.contact-rows{ display:flex; justify-content:center; gap:54px; margin-top:46px; }
.crow .ck{ font-family:var(--sans); font-size:8px; letter-spacing:.26em; text-transform:uppercase; color:var(--gold-bright); margin-bottom:8px; }
.crow .cv{ font-family:var(--serif); font-size:16px; color:var(--on-dark); line-height:1.4; }
.contact-page .signoff{ margin-top:54px; font-family:var(--sans); font-size:8.5px; letter-spacing:.32em; text-transform:uppercase; color:var(--on-dark-faint); }

/* ============================================================
   PROMISE / PROUDLY CANADIAN
   ============================================================ */
.promise-split{ display:grid; grid-template-rows:auto 1fr; height:100%; }
.promise-top{ padding:var(--pad) var(--pad) 0; }
.promise-top h2{ font-family:var(--serif); font-weight:500; font-size:40px; line-height:1.04; margin:.2em 0 0; }
.promise-top p{ font-size:11.5px; line-height:1.8; color:var(--on-dark-mut); max-width:5.4in; margin:18px 0 0; }
.canada-band{ margin-top:.4in; background:var(--ink-2); border-top:1px solid var(--ink-line); padding:.42in var(--pad); }
.canada-head{ display:flex; align-items:center; gap:14px; margin-bottom:26px; }
.maple{ width:26px; height:26px; flex:none; }
.canada-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--ink-line); border:1px solid var(--ink-line); }
.canada-cell{ background:var(--ink); padding:24px 22px 26px; }
.canada-cell h3{ font-family:var(--sans); font-weight:600; font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-bright); margin:0 0 10px; }
.canada-cell p{ font-size:9.5px; line-height:1.65; color:var(--on-dark-mut); margin:0; }

/* ============================================================
   SERIES (Executive vs Signature) feature lists
   ============================================================ */
.series-grid{ display:grid; grid-template-columns:1fr 1fr; gap:.4in; margin-top:.42in; }
.series-card{ border:1px solid var(--ink-line); padding:30px 30px 34px; display:flex; flex-direction:column; }
.dark .series-card{ background:var(--ink-2); }
.series-card.feat{ box-shadow:inset 0 2px 0 var(--gold-bright); background:linear-gradient(168deg,#241c12,#16100a); }
.series-tag{ display:flex; justify-content:space-between; align-items:baseline; }
.series-tag .st-k{ font-family:var(--sans); font-weight:600; font-size:9px; letter-spacing:.26em; text-transform:uppercase; color:var(--on-dark-mut); }
.series-card.feat .st-k{ color:var(--gold-bright); }
.series-flag{ font-family:var(--sans); font-size:7.5px; letter-spacing:.2em; text-transform:uppercase; padding:4px 9px; border:1px solid var(--ink-line); color:var(--on-dark-faint); }
.series-card.feat .series-flag{ background:var(--gold-grad-bright); color:#2a1c08; border:none; }
.series-card h3{ font-family:var(--serif); font-weight:500; font-size:30px; margin:.5em 0 .2em; line-height:1; }
.series-sub{ font-family:var(--serif); font-style:italic; font-size:14px; color:var(--on-dark-mut); margin-bottom:1em; }
.series-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px; }
.series-list li{ font-size:9.7px; color:var(--on-dark); display:flex; gap:9px; align-items:flex-start; line-height:1.45; }
.series-list li::before{ content:"—"; color:var(--gold-bright); flex:none; }
.series-foot{ margin-top:auto; padding-top:16px; font-family:var(--serif); font-style:italic; font-size:12px; color:var(--gold-bright); }

/* comparison table */
.cmp{ width:100%; border-collapse:collapse; margin-top:.42in; font-size:10px; }
.cmp th,.cmp td{ text-align:left; padding:13px 16px; border-bottom:1px solid var(--ink-line); vertical-align:top; }
.cmp thead th{ font-family:var(--sans); font-weight:600; font-size:9px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-bright); border-bottom:1px solid var(--gold-deep); }
.cmp thead th:first-child{ color:var(--on-dark-mut); }
.cmp .rk{ font-family:var(--serif); font-style:italic; font-size:13px; color:var(--gold-bright); width:1.7in; }
.cmp td{ color:var(--on-dark); line-height:1.5; }
.cmp tbody tr:nth-child(even){ background:rgba(227,190,115,.03); }

/* ============================================================
   STEP-BY-STEP ORDERING
   ============================================================ */
.step-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--ink-line); border:1px solid var(--ink-line); margin-top:.42in; }
.ostep{ background:var(--ink); padding:26px 24px 30px; min-height:1.5in; }
.ivory .step-grid{ background:rgba(42,36,28,.12); border-color:rgba(42,36,28,.12); }
.ivory .ostep{ background:var(--ivory); }
.ostep .os-n{ font-family:var(--serif); font-size:34px; line-height:1; }
.ostep h3{ font-family:var(--sans); font-weight:600; font-size:10px; letter-spacing:.16em; text-transform:uppercase; margin:.8em 0 .5em; }
.ivory .ostep h3{ color:var(--on-light); }
.ostep p{ font-size:9px; line-height:1.6; color:var(--on-light-mut); margin:0; }

/* ============================================================
   CONFIGURATIONS (front-elevation diagrams)
   ============================================================ */
.cfg-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px 26px; margin-top:.36in; }
.cfg{ display:grid; grid-template-columns:1.5in 1fr; gap:16px; align-items:center; }
.cfg-art{ height:1.35in; background:var(--ivory-2); border:1px solid rgba(42,36,28,.14); display:flex; align-items:center; justify-content:center; padding:10px; }
.dark .cfg-art{ background:var(--ink-2); border-color:var(--ink-line); }
.cfg-art svg{ width:100%; height:100%; }
.cfg-info .cfg-code{ font-family:var(--serif); font-style:italic; font-size:14px; color:var(--gold-deep); }
.dark .cfg-info .cfg-code{ color:var(--gold-bright); }
.cfg-info h4{ font-family:var(--serif); font-weight:500; font-size:19px; margin:.1em 0 .4em; line-height:1; }
.cfg-meta{ font-size:8.5px; line-height:1.55; color:var(--on-light-mut); }
.dark .cfg-meta{ color:var(--on-dark-mut); }
.cfg-meta b{ font-weight:400; color:var(--on-light); font-family:var(--sans); letter-spacing:.04em; }
.cfg-price{ font-family:var(--serif); font-size:16px; color:var(--gold-deep); margin-top:6px; }
.dark .cfg-price{ color:var(--gold-bright); }
.note-line{ font-size:9px; line-height:1.6; color:var(--on-light-mut); margin-top:.3in; padding-top:14px; border-top:1px solid rgba(42,36,28,.14); }
.dark .note-line{ color:var(--on-dark-mut); border-color:var(--ink-line); }

/* ============================================================
   FINISH / COLOUR SWATCHES (design page)
   ============================================================ */
.style-row{ display:flex; gap:26px; margin-top:.34in; }
.style{ text-align:center; }
.style-art{ width:1.25in; height:1.6in; background:var(--ivory-2); border:1px solid rgba(42,36,28,.14); display:flex; align-items:center; justify-content:center; }
.dark .style-art{ background:var(--ink-2); border-color:var(--ink-line); }
.style-art svg{ width:72%; height:80%; }
.style-name{ font-family:var(--sans); font-size:8.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--on-light-mut); margin-top:9px; }
.dark .style-name{ color:var(--on-dark-mut); }
.col-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:12px 12px; margin-top:.34in; }
.col-grid.q6{ grid-template-columns:repeat(6,1fr); }
.col{ text-align:center; }
.col-chip{ height:.95in; border:1px solid rgba(42,36,28,.14); }
.dark .col-chip{ border-color:var(--ink-line); }
.col-name{ font-family:var(--sans); font-size:7.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--on-light-mut); margin-top:7px; line-height:1.3; }
.dark .col-name{ color:var(--on-dark-mut); }

/* ============================================================
   HARDWARE GRID (pulls & knobs)
   ============================================================ */
.hw-cat{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px 18px; margin-top:.34in; }
.hwitem{ text-align:center; }
.hwitem-art{ height:1in; background:var(--ink-2); border:1px solid var(--ink-line); display:flex; align-items:center; justify-content:center; }
.ivory .hwitem-art{ background:var(--ivory-2); border-color:rgba(42,36,28,.14); }
.hwitem-art svg{ width:60%; height:50%; }
.hwitem .hi-name{ font-family:var(--serif); font-size:13px; margin-top:9px; }
.hwitem .hi-meta{ font-family:var(--sans); font-size:7.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--on-dark-mut); margin-top:2px; }
.ivory .hwitem .hi-meta{ color:var(--on-light-mut); }
.fin-list{ display:flex; flex-wrap:wrap; gap:14px 18px; margin-top:.34in; }
.fin{ display:flex; align-items:center; gap:9px; font-family:var(--sans); font-size:9px; letter-spacing:.08em; color:var(--on-dark); }
.ivory .fin{ color:var(--on-light); }
.fin .dot{ width:22px; height:22px; border-radius:50%; border:1px solid rgba(0,0,0,.15); flex:none; }

/* ============================================================
   QUARTZ
   ============================================================ */
.quartz-incl{ display:grid; grid-template-columns:1fr 1fr; gap:.5in; margin-top:.36in; align-items:start; }
.incl-list{ list-style:none; margin:14px 0 0; padding:0; }
.incl-list li{ padding:10px 0; border-top:1px solid rgba(42,36,28,.14); font-size:11px; display:flex; gap:11px; align-items:baseline; }
.dark .incl-list li{ border-color:var(--ink-line); color:var(--on-dark); }
.incl-list li::before{ content:"✓"; color:var(--gold-deep); }
.dark .incl-list li::before{ color:var(--gold-bright); }
.drill-row{ display:flex; gap:24px; margin-top:18px; }
.drill{ text-align:center; }
.drill svg{ width:1.1in; height:.5in; }
.drill .dn{ font-family:var(--sans); font-size:7.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--on-light-mut); margin-top:6px; }
.dark .drill .dn{ color:var(--on-dark-mut); }
.quartz-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px 18px; margin-top:.36in; }
.quartz{ }
.quartz-chip{ height:1.5in; border:1px solid rgba(42,36,28,.14); position:relative; overflow:hidden; }
.dark .quartz-chip{ border-color:var(--ink-line); }
.quartz-veins{ background-image:radial-gradient(120% 80% at 30% 20%, rgba(0,0,0,.05), transparent 40%), repeating-linear-gradient(125deg, rgba(150,150,150,.10) 0 1px, transparent 1px 22px), repeating-linear-gradient(60deg, rgba(120,120,120,.07) 0 1px, transparent 1px 30px); }
.quartz-name{ font-family:var(--serif); font-size:14px; margin-top:10px; }
.quartz-meta{ font-family:var(--sans); font-size:7.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--on-light-mut); margin-top:2px; }
.dark .quartz-meta{ color:var(--on-dark-mut); }

/* upgrades */
.upg-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--ink-line); border:1px solid var(--ink-line); margin-top:.42in; }
.upg{ background:var(--ink); padding:26px 26px 30px; display:flex; gap:18px; align-items:flex-start; }
.upg .un{ font-family:var(--serif); font-style:italic; font-size:26px; color:var(--gold-bright); line-height:1; flex:none; }
.upg h4{ font-family:var(--serif); font-weight:500; font-size:19px; margin:0 0 .3em; }
.upg p{ font-size:9.5px; line-height:1.6; color:var(--on-dark-mut); margin:0; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{ margin-top:.36in; column-count:1; }
.faq{ padding:15px 0; border-top:1px solid rgba(42,36,28,.14); break-inside:avoid; }
.dark .faq{ border-color:var(--ink-line); }
.faq:last-child{ border-bottom:1px solid rgba(42,36,28,.14); }
.dark .faq:last-child{ border-color:var(--ink-line); }
.faq .q{ font-family:var(--serif); font-weight:500; font-size:16px; margin:0 0 6px; color:var(--on-light); }
.dark .faq .q{ color:var(--on-dark); }
.faq .a{ font-size:10px; line-height:1.6; color:var(--on-light-mut); margin:0; }
.dark .faq .a{ color:var(--on-dark-mut); }
.faq .tip{ font-size:9px; line-height:1.55; color:var(--gold-deep); font-style:italic; font-family:var(--serif); margin:7px 0 0; padding-left:12px; border-left:2px solid var(--gold-deep); }
.dark .faq .tip{ color:var(--gold-bright); border-color:var(--gold-bright); }

/* ============================================================
   PRICING TABLES
   ============================================================ */
.price-table{ width:100%; border-collapse:collapse; margin-top:.32in; font-family:var(--sans); }
.price-table th,.price-table td{ padding:9px 10px; text-align:center; border-bottom:1px solid rgba(42,36,28,.12); font-size:9px; }
.dark .price-table th,.dark .price-table td{ border-color:var(--ink-line); }
.price-table thead th{ font-weight:600; font-size:8px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-deep); border-bottom:1px solid var(--gold-deep); line-height:1.3; }
.dark .price-table thead th{ color:var(--gold-bright); border-color:var(--gold-deep); }
.price-table td:first-child,.price-table th:first-child{ text-align:left; font-family:var(--serif); font-size:13px; }
.price-table .pv{ color:var(--on-light); font-size:10px; }
.dark .price-table .pv{ color:var(--on-dark); }
.price-table .px{ color:var(--on-light-faint); }
.dark .price-table .px{ color:var(--on-dark-faint); }
.price-table tbody tr:nth-child(even){ background:rgba(42,36,28,.03); }
.dark .price-table tbody tr:nth-child(even){ background:rgba(227,190,115,.03); }
.price-note{ font-size:8.5px; letter-spacing:.04em; color:var(--on-light-mut); margin-top:16px; }
.dark .price-note{ color:var(--on-dark-mut); }
.upg-cell{ font-size:8px; line-height:1.5; color:var(--on-light-mut); text-align:left; }
.dark .upg-cell{ color:var(--on-dark-mut); }
.upg-cell b{ color:var(--on-light); font-weight:400; }
.dark .upg-cell b{ color:var(--on-dark); }
