/* ============================================================
   FIREPLACE MART — design system, APPLE EDITION
   Same structure and selectors as the Harvey edition, reskinned:
   all-Inter type, white + #F5F5F7 surfaces, generous corner
   radii, pill buttons, soft depth. apple.com-calibre restraint.
   NOTE: --serif intentionally resolves to Inter — every
   "serif" reference in the pages inherits the clean look.
   ============================================================ */

@import url('../assets/fonts/fonts.css');

:root{
  --paper:      #FFFFFF;
  --paper-2:    #F5F5F7;
  --paper-3:    #E8E8ED;
  --ink:        #1D1D1F;
  --ink-2:      #424245;
  --mut:        #6E6E73;
  --mut-2:      #86868B;
  --line:       #E8E8ED;
  --line-2:     #D2D2D7;
  --coal:       #0B0B0C;
  --coal-2:     #1D1D1F;
  --cream:      #F5F5F7;
  --ember:      #E4572E;   /* the flame — logo + rare accents only */
  --ember-2:    #C74722;
  --blue:       #0071E3;   /* primary action */
  --blue-2:     #0077ED;
  --ok:         #34845C;

  --serif: 'Inter', -apple-system, 'Helvetica Neue', Arial, sans-serif;
  --sans:  'Inter', -apple-system, 'Helvetica Neue', Arial, sans-serif;

  --max: 1680px;
  --gutter: clamp(20px, 4vw, 64px);
  --r: 18px;          /* cards & media */
  --r-sm: 12px;       /* inputs, small chrome */
  --r-pill: 980px;    /* buttons */
  --shadow-pop: 0 24px 60px -24px rgba(0,0,0,.25);
  --shadow-card: 0 2px 12px rgba(0,0,0,.04);
  --ease: cubic-bezier(.28,.11,.32,1);
}

*,
*::before,
*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
ul,ol{ list-style:none; }
::selection{ background:var(--ink); color:#fff; }

/* ---------------- type ---------------- */

h1,h2,h3,h4{ font-weight:600; }

.display-1,.display-2,.display-3,.display-4{
  font-family:var(--sans);
  font-weight:600;
  letter-spacing:-.02em;
  line-height:1.1;
  color:var(--ink);
  text-wrap:balance;
}
.display-1{ font-size:clamp(2rem, 3.8vw, 3rem); }
.display-2{ font-size:clamp(1.55rem, 2.7vw, 2.2rem); line-height:1.14; }
.display-3{ font-size:clamp(1.25rem, 1.9vw, 1.6rem); line-height:1.22; }
.display-4{ font-size:1.15rem; line-height:1.32; }

/* headings breathe before body copy — Inter needs the air the serif didn't */
.display-1 + .lead, .display-2 + .lead, .display-3 + .lead,
.display-1 + p, .display-2 + p, .display-3 + p{ margin-top:14px; }

.eyebrow{
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--mut-2);
  display:block;
}

.lead{
  font-size:clamp(1rem, 1.2vw, 1.15rem);
  line-height:1.6;
  color:var(--ink-2);
  max-width:56ch;
  font-weight:400;
}
.small{ font-size:.85rem; line-height:1.55; color:var(--mut); }
.serif-i{ font-style:normal; font-weight:600; }

/* ---------------- layout ---------------- */

.container{ max-width:var(--max); margin:0 auto; padding:0 var(--gutter); }
.section{ padding:clamp(64px, 9vw, 120px) 0; }
.section-tight{ padding:clamp(40px, 6vw, 72px) 0; }
.section-flush-top{ padding-top:0; }

.section-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:24px; margin-bottom:clamp(32px, 4vw, 56px);
}
.section-head .eyebrow{ margin-bottom:14px; }
.section-head p{ margin-top:14px; }

.rule{ border:0; border-top:1px solid var(--line); }

.band-dark{ background:var(--coal); color:#F5F5F7; }
.band-dark .display-1,.band-dark .display-2,.band-dark .display-3,.band-dark .display-4{ color:#F5F5F7; }
.band-dark .eyebrow{ color:#86868B; }
.band-dark .lead{ color:#A1A1A6; }
.band-dark .rule{ border-color:#2D2D2F; }
.band-alt{ background:var(--paper-2); }

/* ---------------- buttons & links ---------------- */

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-size:.88rem; font-weight:500; letter-spacing:0;
  padding:12px 24px; border-radius:var(--r-pill);
  background:var(--blue); color:#fff;
  border:1px solid var(--blue);
  transition:background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease), transform .25s var(--ease);
  white-space:nowrap;
}
.btn:hover{ background:var(--blue-2); border-color:var(--blue-2); transform:translateY(-1px); }
.btn:active{ transform:translateY(0); }

.btn-outline{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-outline:hover{ background:var(--paper-2); border-color:var(--ink); color:var(--ink); }
.band-dark .btn{ background:#F5F5F7; color:var(--ink); border-color:#F5F5F7; }
.band-dark .btn:hover{ background:#fff; border-color:#fff; }
.band-dark .btn-outline{ background:transparent; color:#F5F5F7; border-color:#3A3A3C; }
.band-dark .btn-outline:hover{ background:transparent; border-color:#F5F5F7; color:#F5F5F7; }

.btn-lg{ padding:14px 28px; font-size:.95rem; }
.btn-sm{ padding:8px 18px; font-size:.8rem; }
.btn-block{ width:100%; }
.btn-ember{ background:var(--ember); border-color:var(--ember); color:#fff; }
.btn-ember:hover{ background:var(--ember-2); border-color:var(--ember-2); }

.link-arrow{
  display:inline-flex; align-items:center; gap:7px;
  font-size:.9rem; font-weight:500; color:var(--blue);
  border-bottom:0; padding-bottom:0;
  transition:gap .25s var(--ease);
  white-space:nowrap;
}
.link-arrow:hover{ gap:11px; text-decoration:underline; }
.link-arrow svg{ width:14px; height:14px; flex:none; }

/* ---------------- header ---------------- */

.topbar{
  background:var(--coal-2); color:#A1A1A6;
  font-size:.74rem; letter-spacing:.01em;
  text-align:center; padding:8px var(--gutter);
}
.topbar b{ color:#F5F5F7; font-weight:500; }
.topbar a{ color:#F5F5F7; border-bottom:1px solid #48484A; }

.site-header{
  position:sticky; top:0; z-index:80;
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--line);
}
.site-header .container{
  display:flex; align-items:center; gap:36px;
  height:60px;
}
.brand{
  font-family:var(--sans); font-size:1.18rem; font-weight:700; letter-spacing:-.02em;
  color:var(--ink); display:flex; align-items:baseline; gap:2px;
  flex:none;
}
.brand em{ font-style:normal; font-weight:700; }
.brand .brand-dot{ color:var(--ember); }

.nav-links{ display:flex; gap:26px; align-items:center; }
.nav-links a{
  font-size:.86rem; color:var(--ink-2); padding:6px 0;
  border-bottom:1px solid transparent;
  transition:color .2s;
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a.active{ color:var(--ink); font-weight:600; }

.header-actions{ margin-left:auto; display:flex; align-items:center; gap:16px; }
.header-actions .btn{ padding:9px 18px; font-size:.82rem; }
.cart-link{ position:relative; display:flex; align-items:center; padding:6px; }
.cart-link svg{ width:19px; height:19px; }
.cart-count{
  position:absolute; top:-2px; right:-5px;
  min-width:16px; height:16px; padding:0 4px;
  background:var(--ember); color:#fff;
  font-size:.62rem; font-weight:600; line-height:16px; text-align:center;
  border-radius:99px;
}
.cart-count[data-n="0"]{ display:none; }

.nav-toggle{ display:none; padding:8px; }
.nav-toggle svg{ width:22px; height:22px; }

/* ---- shop mega-menu ---- */
.nav-item{ position:relative; display:inline-flex; align-items:center; gap:5px; }
.nav-chev{ display:flex; padding:3px; color:var(--mut); }
.nav-chev svg{ width:11px; height:11px; transition:transform .25s var(--ease); }
.nav-item.open .nav-chev svg{ transform:rotate(180deg); }
.mega{
  position:absolute; top:100%; left:0; right:0; z-index:78;
  background:#fff;
  border-bottom:1px solid var(--line);
  border-radius:0 0 var(--r) var(--r);
  box-shadow:0 32px 64px -28px rgba(0,0,0,.22);
  opacity:0; visibility:hidden; transform:translateY(-8px);
  transition:opacity .28s var(--ease), transform .28s var(--ease), visibility .28s;
}
.mega.open{ opacity:1; visibility:visible; transform:none; }
.mega .container{ display:block; height:auto; }  /* undo the header's fixed flex row */
.mega-flex{ display:flex; gap:clamp(28px,3vw,56px); padding:26px 0 32px; }
.mega-cats{
  flex:0 0 250px; display:flex; flex-direction:column; gap:2px;
  border-right:1px solid var(--line); padding-right:clamp(16px,2vw,32px);
}
.mega-cat{
  display:flex; align-items:center; gap:8px;
  padding:11px 14px; font-size:.92rem; font-weight:500; color:var(--ink-2);
  border-radius:var(--r-sm);
  transition:background .15s, color .15s;
}
.mega-cat span:first-child{ letter-spacing:-.01em; }
.mega-cat-n{ color:var(--mut-2); font-size:.74rem; }
.mega-cat svg{ width:11px; height:11px; margin-left:auto; opacity:0; transition:opacity .15s; flex:none; }
.mega-cat.on, .mega-cat:hover{ background:var(--paper-2); color:var(--ink); font-weight:600; }
.mega-cat.on svg, .mega-cat:hover svg{ opacity:1; }
.mega-cat-all{ margin-top:8px; border-top:1px solid var(--line); border-radius:0 0 var(--r-sm) var(--r-sm); padding-top:16px; }
.mega-panes{ flex:1; min-width:0; }
.mega-pane{ display:none; grid-template-columns:repeat(4,1fr); gap:16px; }
.mega-pane.on{ display:grid; }
@media (max-width: 1100px){ .mega-pane{ grid-template-columns:repeat(2,1fr); } .mega-cats{ flex-basis:200px; } }
.mega-tile{ display:flex; flex-direction:column; gap:8px; min-width:0; }
.mega-thumb{
  display:block; aspect-ratio:4/3; overflow:hidden;
  border-radius:var(--r-sm); background:var(--paper-2);
  box-shadow:var(--shadow-card);
}
.mega-thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.mega-tile:hover .mega-thumb img{ transform:scale(1.05); }
.mega-label{ font-weight:600; letter-spacing:-.01em; font-size:.9rem; line-height:1.25; color:var(--ink); }
.mega-tile:hover .mega-label{ color:var(--blue); }
.mega-count{ font-size:.72rem; color:var(--mut); }
.mega-thumb-all{ display:grid; place-content:center; color:var(--mut); }
.mega-thumb-all svg{ width:20px; height:20px; }
@media (max-width: 920px){
  .nav-chev, .mega{ display:none; }
  .nav-links .nav-item{ width:100%; }
  .nav-links .nav-item a{ width:100%; }
}

@media (max-width: 920px){
  .nav-links{
    display:none;
    position:fixed; inset:60px 0 auto 0; z-index:79;
    flex-direction:column; align-items:flex-start; gap:0;
    background:var(--paper); border-bottom:1px solid var(--line);
    padding:12px var(--gutter) 28px;
  }
  .nav-links.open{ display:flex; }
  .nav-links a{ font-size:1.05rem; padding:12px 0; width:100%; border-bottom:1px solid var(--line); }
  .nav-toggle{ display:block; }
  .header-actions .btn-consult{ display:none; }
}

/* ---------------- hero ---------------- */

.hero{ padding:clamp(40px, 5vw, 72px) 0 clamp(36px, 4vw, 56px); }
.hero .eyebrow{ margin-bottom:0; }
.hero .display-1{ font-size:clamp(1.7rem, 2.5vw, 2.3rem); margin:14px 0 0; }
.hero .lead{ max-width:none; font-size:clamp(.98rem, 1.15vw, 1.08rem); margin-top:14px; }
.hero-row{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:24px 56px; flex-wrap:wrap; margin-top:30px;
}
.hero-head{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:24px 64px; flex-wrap:wrap;
}
.hero-head > div:first-child{ flex:1 1 560px; min-width:0; }
.hero-quote{ max-width:400px; text-align:right; }
/* CTA rows everywhere get air above; inside .hero-row the row itself carries it */
.hero-ctas{ display:flex; gap:12px; flex-wrap:wrap; margin-top:28px; }
.hero-row .hero-ctas{ margin-top:0; }
@media (max-width: 860px){ .hero-quote{ text-align:left; } }

/* compact page heroes everywhere */
.page-hero{ padding:clamp(40px, 5vw, 64px) 0 clamp(28px, 3.5vw, 44px); }
.page-hero .display-1{ font-size:clamp(1.65rem, 2.4vw, 2.25rem); margin:14px 0 0; }
.page-hero .lead{ font-size:clamp(.98rem, 1.15vw, 1.08rem); max-width:none; margin-top:14px; }

.hero-media{
  position:relative; overflow:hidden; border-radius:calc(var(--r) + 6px);
  aspect-ratio:21/9; background:var(--paper-2);
}
.hero-media img, .hero-media video{ width:100%; height:100%; object-fit:cover; display:block; }
.hero-media .media-tag{
  position:absolute; left:18px; bottom:16px;
  background:rgba(29,29,31,.62); color:#F5F5F7;
  backdrop-filter:blur(10px);
  font-size:.74rem; letter-spacing:.01em;
  padding:8px 16px; border-radius:var(--r-pill);
}

.trust-row{
  display:flex; flex-wrap:wrap; gap:12px 40px;
  padding:22px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.trust-row li{ font-size:.82rem; color:var(--mut); display:flex; align-items:center; gap:9px; }
.trust-row svg{ width:15px; height:15px; color:var(--ink-2); flex:none; }

/* ---------------- stats / numerals ---------------- */

.stat-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:14px; background:transparent; border:0; }
.stat-grid > div{ background:var(--paper-2); padding:28px 26px; border-radius:var(--r); }
.band-dark .stat-grid{ background:transparent; border:0; }
.band-dark .stat-grid > div{ background:#161617; }
.stat-num{ font-family:var(--sans); font-weight:600; font-size:1.9rem; line-height:1; letter-spacing:-.02em; }
.stat-lbl{ font-size:.8rem; color:var(--mut); margin-top:10px; }
.band-dark .stat-lbl{ color:#86868B; }
@media (max-width: 780px){ .stat-grid{ grid-template-columns:repeat(2,1fr); } }

/* ---------------- product cards ---------------- */

.grid{ display:grid; gap:clamp(20px, 2.5vw, 32px); }
.grid-2{ grid-template-columns:repeat(2, 1fr); }
.grid-3{ grid-template-columns:repeat(3, 1fr); }
.grid-4{ grid-template-columns:repeat(4, 1fr); }
@media (max-width: 1020px){ .grid-4{ grid-template-columns:repeat(2,1fr); } .grid-3{ grid-template-columns:repeat(2,1fr); } }
@media (max-width: 640px){ .grid-4,.grid-3,.grid-2{ grid-template-columns:1fr; } }

.pcard{ display:flex; flex-direction:column; min-width:0; }
.pcard-media{
  position:relative; overflow:hidden; border-radius:var(--r);
  aspect-ratio:4/3; background:var(--paper-2);
  border:0; box-shadow:var(--shadow-card);
  transition:box-shadow .35s var(--ease), transform .35s var(--ease);
}
.pcard:hover .pcard-media{ box-shadow:0 12px 32px rgba(0,0,0,.12); transform:translateY(-2px); }
.pcard-media img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .8s var(--ease);
}
.pcard-media img.contain{ object-fit:contain; padding:8%; background:#fff; }
.pcard:hover .pcard-media img{ transform:scale(1.03); }
.pcard:hover .pcard-media img.contain{ transform:scale(1.015); }
.pcard-badges{ position:absolute; top:12px; left:12px; display:flex; gap:6px; z-index:2; }
.badge{
  font-size:.66rem; font-weight:600; letter-spacing:.04em; text-transform:none;
  background:rgba(255,255,255,.92); color:var(--ink);
  border:0; backdrop-filter:blur(6px);
  padding:6px 12px; border-radius:var(--r-pill);
  box-shadow:0 1px 4px rgba(0,0,0,.08);
}
.badge-dark{ background:var(--ink); color:#fff; }
.badge-ember{ background:var(--ember); color:#fff; }

.pcard-body{ padding:16px 4px 0; display:flex; flex-direction:column; gap:5px; flex:1; }
.pcard-brand{ font-size:.7rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--mut); }
.pcard-name{ font-family:var(--sans); font-size:1.05rem; font-weight:600; letter-spacing:-.01em; line-height:1.35; }
.pcard-sub{ font-size:.85rem; color:var(--mut); line-height:1.5; }
.pcard-price-row{
  margin-top:10px; padding-top:12px; border-top:1px solid var(--line);
  display:flex; align-items:baseline; justify-content:space-between; gap:10px; flex-wrap:wrap;
}
.pcard-price{ font-size:1rem; font-weight:600; }
.pcard-price .was{ font-weight:400; color:var(--mut-2); text-decoration:line-through; margin-right:8px; font-size:.86rem; }
.pcard-installed{ font-size:.76rem; color:var(--mut); }
.pcard-rating{ display:flex; align-items:center; gap:6px; font-size:.78rem; color:var(--mut); margin-top:2px; }
.pcard-rating svg{ width:13px; height:13px; color:var(--ember); }

/* ---------------- category tiles ---------------- */

.cat-tile{ position:relative; overflow:hidden; border-radius:var(--r); aspect-ratio:4/5; display:block; box-shadow:var(--shadow-card); }
.cat-tile img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); }
.cat-tile:hover img{ transform:scale(1.04); }
.cat-tile::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.62) 0%, rgba(0,0,0,.1) 45%, transparent 70%);
}
.cat-tile-label{
  position:absolute; left:20px; right:20px; bottom:18px; z-index:2;
  color:#fff;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
}
.cat-tile-label .t{ font-family:var(--sans); font-weight:600; letter-spacing:-.01em; font-size:1.16rem; }
.cat-tile-label .n{ font-size:.74rem; opacity:.8; }

/* ---------------- category scroll row ---------------- */

.cat-row{
  display:grid; grid-auto-flow:column;
  grid-auto-columns:clamp(240px, 24vw, 330px);
  gap:16px;
  overflow-x:auto; overflow-y:hidden; /* y-hidden: reveal transforms must not steal vertical scroll */
  overscroll-behavior-x:contain;
  scroll-snap-type:x proximity;
  padding-bottom:6px;
  scrollbar-width:none;
  /* full-bleed: the row spans the viewport, but the first tile aligns
     with the container's content edge (sits outside .container) */
  padding-inline:max(var(--gutter), calc((100% - var(--max)) / 2 + var(--gutter)));
  scroll-padding-inline:max(var(--gutter), calc((100% - var(--max)) / 2 + var(--gutter)));
}
.cat-row::-webkit-scrollbar{ display:none; }
.cat-row .cat-tile{ scroll-snap-align:start; }

.row-nav{ display:flex; gap:8px; }
.row-nav button{
  width:34px; height:34px; border-radius:999px;
  border:0; background:var(--paper-2); color:var(--ink);
  display:grid; place-content:center;
  transition:background .2s;
}
.row-nav button:hover{ background:var(--paper-3); }
.row-nav svg{ width:14px; height:14px; }

/* ---------------- feature rows / editorial ---------------- */

.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px, 6vw, 96px); align-items:center; }
.split-media{ overflow:hidden; border-radius:var(--r); aspect-ratio:4/3; background:var(--paper-2); box-shadow:var(--shadow-card); }
.split-media img{ width:100%; height:100%; object-fit:cover; }
.split-media-tall{ aspect-ratio:3/4; }
.split-media-fill{ aspect-ratio:auto; flex:1; min-height:280px; position:relative; }
.split-media-fill img{ position:absolute; inset:0; } /* image never dictates the row height */
@media (max-width: 860px){ .split{ grid-template-columns:1fr; } }

.step-list{ counter-reset:step; display:flex; flex-direction:column; }
.step-list li{
  counter-increment:step;
  display:grid; grid-template-columns:64px 1fr; gap:20px;
  padding:26px 0; border-top:1px solid var(--line);
}
.step-list li:last-child{ border-bottom:1px solid var(--line); }
.step-list li::before{
  content:counter(step, decimal-leading-zero);
  font-family:var(--sans); font-weight:600; font-size:1.05rem; color:var(--mut-2); line-height:1.7;
}
.step-list h4{ font-size:1rem; font-weight:600; margin-bottom:6px; }
.step-list p{ font-size:.9rem; color:var(--mut); max-width:60ch; }
.band-dark .step-list li{ border-color:#2D2D2F; }
.band-dark .step-list p{ color:#86868B; }

/* ---------------- quote / review ---------------- */

.quote-card{
  border:0; border-radius:var(--r);
  padding:30px 28px; background:var(--paper-2);
  display:flex; flex-direction:column; gap:16px;
}
.band-alt .quote-card{ background:#fff; box-shadow:var(--shadow-card); }
.quote-card blockquote{
  font-family:var(--sans); font-size:1.05rem; line-height:1.55; color:var(--ink-2); font-weight:400;
}
.quote-card cite{ font-style:normal; font-size:.8rem; color:var(--mut); }
.quote-card cite b{ display:block; color:var(--ink); font-weight:600; margin-bottom:2px; }
.stars{ display:flex; gap:2px; color:var(--ember); }
.stars svg{ width:13px; height:13px; }

/* ---------------- forms ---------------- */

.field{ display:flex; flex-direction:column; gap:7px; }
.field label{ font-size:.78rem; font-weight:600; letter-spacing:.02em; color:var(--ink-2); }
.field .hint{ font-size:.75rem; color:var(--mut-2); }
input[type=text], input[type=email], input[type=tel], input[type=number], input[type=date], select, textarea{
  font:inherit; font-size:.92rem; color:var(--ink);
  background:var(--paper-2); border:1px solid transparent; border-radius:var(--r-sm);
  padding:12px 14px; width:100%;
  transition:border-color .2s, background .2s;
}
input:focus, select:focus, textarea:focus{ outline:none; border-color:var(--blue); background:#fff; box-shadow:0 0 0 3px rgba(0,113,227,.12); }
select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%231D1D1F' fill='none'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width: 640px){ .form-row{ grid-template-columns:1fr; } }

.choice-pills{ display:flex; flex-wrap:wrap; gap:8px; }
.choice-pill{
  font-size:.82rem; padding:9px 18px;
  border:1px solid var(--line-2); border-radius:var(--r-pill);
  color:var(--ink-2); background:transparent;
  transition:all .2s;
}
.choice-pill:hover{ border-color:var(--ink); }
.choice-pill.on{ background:var(--ink); color:#fff; border-color:var(--ink); }

/* ---------------- accordion ---------------- */

.faq details{ border-top:1px solid var(--line); }
.faq details:last-child{ border-bottom:1px solid var(--line); }
.faq summary{
  cursor:pointer; list-style:none;
  display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding:22px 0;
  font-family:var(--sans); font-size:1.02rem; font-weight:600; letter-spacing:-.01em;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:'+'; font-family:var(--sans); font-size:1.2rem; font-weight:400; color:var(--mut);
  transition:transform .25s var(--ease);
}
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ padding:0 0 24px; color:var(--mut); max-width:68ch; font-size:.92rem; }

/* ---------------- footer ---------------- */

.site-footer{ background:var(--paper-2); color:var(--mut); }
.site-footer .footer-cta{ background:var(--coal); color:#F5F5F7; border-bottom:0; }
.site-footer .footer-cta .display-3{ color:#F5F5F7; }
.site-footer .footer-cta .lead{ color:#A1A1A6; }
.site-footer .footer-cta .btn{ background:#F5F5F7; color:var(--ink); border-color:#F5F5F7; }
.site-footer .footer-cta .btn:hover{ background:#fff; }
.site-footer .footer-cta .btn-outline{ background:transparent; color:#F5F5F7; border-color:#3A3A3C; }
.site-footer .footer-cta .btn-outline:hover{ border-color:#F5F5F7; }
.footer-main{ padding:clamp(48px,6vw,80px) 0 36px; }
.footer-grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; }
@media (max-width: 860px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
.footer-brand{ font-family:var(--sans); font-weight:700; letter-spacing:-.02em; font-size:1.3rem; color:var(--ink); }
.footer-brand em{ font-style:normal; }
.footer-brand .brand-dot{ color:var(--ember); }
.footer-grid h5{
  font-size:.7rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--mut-2); margin-bottom:16px;
}
.footer-grid ul{ display:flex; flex-direction:column; gap:10px; }
.footer-grid a{ font-size:.86rem; color:var(--ink-2); transition:color .2s; }
.footer-grid a:hover{ color:var(--ink); text-decoration:underline; }
.footer-note{ font-size:.8rem; max-width:44ch; line-height:1.6; margin-top:14px; }
.footer-legal{
  border-top:1px solid var(--line-2); padding:22px 0 28px;
  display:flex; flex-wrap:wrap; gap:10px 28px; justify-content:space-between;
  font-size:.74rem; color:var(--mut-2);
}
.footer-legal a{ color:var(--mut); }

/* ---------------- shop layout ---------------- */

.shop-layout{ display:grid; grid-template-columns:248px 1fr; gap:clamp(28px,4vw,64px); align-items:start; }
@media (max-width: 920px){ .shop-layout{ grid-template-columns:1fr; } }
.filters{ position:sticky; top:90px; display:flex; flex-direction:column; gap:28px; }
@media (max-width: 920px){ .filters{ position:static; } }
.filter-group h5{ font-size:.72rem; font-weight:600; letter-spacing:.09em; text-transform:uppercase; color:var(--mut); margin-bottom:12px; }
.filter-group label{
  display:flex; align-items:center; gap:10px;
  font-size:.88rem; color:var(--ink-2); padding:6px 0; cursor:pointer;
}
.filter-group input[type=checkbox], .filter-group input[type=radio]{
  appearance:none; width:16px; height:16px; flex:none;
  border:1px solid var(--line-2); border-radius:5px; background:#fff;
  display:grid; place-content:center; cursor:pointer;
  transition:background .15s, border-color .15s;
}
.filter-group input:checked{ background:var(--ink); border-color:var(--ink); }
.filter-group input:checked::after{ content:''; width:8px; height:8px; background:#fff; clip-path:polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%); }
.filter-group input[type=radio]{ border-radius:50%; }
.filter-group input[type=radio]:checked::after{ clip-path:none; border-radius:50%; width:7px; height:7px; }
.shop-toolbar{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding-bottom:18px; margin-bottom:26px; border-bottom:1px solid var(--line);
}
.shop-toolbar .count{ font-size:.85rem; color:var(--mut); }
.shop-toolbar select{ width:auto; padding:9px 36px 9px 12px; font-size:.84rem; background-color:transparent; border-color:transparent; }
.shop-toolbar select:hover{ background-color:var(--paper-2); }

/* ---------------- product page ---------------- */

.pdp-grid{ display:grid; grid-template-columns:minmax(0,7fr) minmax(0,5fr); gap:clamp(32px,5vw,80px); align-items:start; }
@media (max-width: 920px){ .pdp-grid{ grid-template-columns:1fr; } }
.pdp-media{ position:sticky; top:90px; }
@media (max-width: 920px){ .pdp-media{ position:static; } }
.pdp-hero-img{ border:0; border-radius:var(--r); overflow:hidden; aspect-ratio:4/3; background:var(--paper-2); box-shadow:var(--shadow-card); }
.pdp-hero-img img{ width:100%; height:100%; object-fit:cover; }
.pdp-hero-img img.contain{ object-fit:contain; padding:6%; background:#fff; }
.pdp-thumbs{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:12px; }
.pdp-thumbs button{ border:2px solid transparent; border-radius:var(--r-sm); overflow:hidden; aspect-ratio:4/3; opacity:.75; transition:opacity .2s, border-color .2s; background:var(--paper-2); }
.pdp-thumbs button.on{ opacity:1; border-color:var(--blue); }
.pdp-thumbs img{ width:100%; height:100%; object-fit:cover; }

.price-panel{
  border:0; border-radius:var(--r);
  background:var(--paper-2); padding:24px; margin-top:26px;
}
/* on gray bands the panel needs to read as a card, not vanish */
.band-alt .price-panel{ background:#fff; box-shadow:var(--shadow-card); }
.band-alt .notice{ background:#fff; }
.price-line{ display:flex; justify-content:space-between; align-items:baseline; padding:9px 0; font-size:.9rem; }
.price-line + .price-line{ border-top:1px solid rgba(0,0,0,.06); }
.price-line .lbl{ color:var(--mut); }
.price-line .val{ font-weight:600; }
.price-line.total .val{ font-size:1.24rem; font-weight:700; letter-spacing:-.01em; }
.finance-note{ font-size:.8rem; color:var(--mut); display:flex; gap:8px; align-items:center; margin-top:12px; }
.finance-note b{ color:var(--ink); }
.finance-note svg{ width:15px; height:15px; flex:none; }
.finance-note a{ color:var(--blue); }

.spec-table{ width:100%; border-collapse:collapse; font-size:.88rem; }
.spec-table th, .spec-table td{ text-align:left; padding:12px 0; border-top:1px solid var(--line); vertical-align:top; }
.spec-table th{ font-weight:500; color:var(--mut); width:42%; padding-right:16px; }
.spec-table tr:last-child th, .spec-table tr:last-child td{ border-bottom:1px solid var(--line); }

.tick-list{ display:flex; flex-direction:column; gap:10px; }
.tick-list li{ display:flex; gap:11px; font-size:.9rem; color:var(--ink-2); }
.tick-list svg{ width:15px; height:15px; flex:none; margin-top:4px; color:var(--ok); }

/* ---------------- cart / checkout ---------------- */

.cart-row{
  display:grid; grid-template-columns:110px 1fr auto; gap:20px;
  padding:22px 0; border-top:1px solid var(--line); align-items:center;
}
.cart-row:last-of-type{ border-bottom:1px solid var(--line); }
.cart-row img{ border-radius:var(--r-sm); border:0; aspect-ratio:4/3; object-fit:cover; width:100%; background:var(--paper-2); }
.qty{ display:inline-flex; border:1px solid var(--line-2); border-radius:var(--r-pill); overflow:hidden; }
.qty button{ width:32px; height:34px; font-size:1rem; color:var(--mut); }
.qty button:hover{ color:var(--ink); background:var(--paper-2); }
.qty span{ min-width:34px; display:grid; place-content:center; font-size:.9rem; border-inline:1px solid var(--line-2); }

.summary-card{ border:0; border-radius:var(--r); background:var(--paper-2); padding:26px; position:sticky; top:90px; }
@media (max-width: 920px){ .summary-card{ position:static; } }

.steps-nav{ display:flex; gap:8px; align-items:center; font-size:.8rem; color:var(--mut-2); margin-bottom:34px; flex-wrap:wrap; }
.steps-nav .on{ color:var(--ink); font-weight:600; }
.steps-nav svg{ width:12px; height:12px; }

/* ---------------- quiz ---------------- */

.quiz-shell{ max-width:720px; margin:0 auto; }
.quiz-progress{ height:4px; background:var(--paper-3); border-radius:99px; margin-bottom:48px; overflow:hidden; }
.quiz-progress i{ display:block; height:100%; background:var(--blue); border-radius:99px; transition:width .4s var(--ease); }
.quiz-options{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:36px; }
@media (max-width:640px){ .quiz-options{ grid-template-columns:1fr; } }
.quiz-opt{
  text-align:left; border:1px solid transparent; border-radius:var(--r-sm);
  padding:20px 22px; background:var(--paper-2);
  transition:border-color .2s, background .2s, box-shadow .2s;
}
.quiz-opt:hover{ border-color:var(--line-2); background:#fff; box-shadow:var(--shadow-card); }
.quiz-opt.on{ border-color:var(--blue); background:#fff; box-shadow:0 0 0 3px rgba(0,113,227,.12); }
.quiz-opt h4{ font-family:var(--sans); font-weight:600; letter-spacing:-.01em; font-size:1.05rem; margin-bottom:5px; }
.quiz-opt p{ font-size:.82rem; color:var(--mut); }
.quiz-opt-img{
  display:block; aspect-ratio:16/9; overflow:hidden;
  border-radius:var(--r-sm) var(--r-sm) 0 0;
  margin:-20px -22px 16px;   /* bleed to the card edges (cancels .quiz-opt padding) */
  background:var(--paper-3);
}
.quiz-opt-img img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.quiz-opt:hover .quiz-opt-img img{ transform:scale(1.04); }

/* budget slider step */
.quiz-slider{ display:flex; flex-direction:column; gap:20px; margin-top:36px; }
.quiz-slider-img{
  aspect-ratio:2/1; overflow:hidden; border-radius:var(--r);
  background:var(--paper-2); box-shadow:var(--shadow-card);
}
.quiz-slider-img img{ width:100%; height:100%; object-fit:cover; }
.quiz-slider-info{ display:flex; justify-content:space-between; align-items:flex-end; gap:20px; }
.quiz-slider-price{ font-weight:700; font-size:1.8rem; line-height:1; letter-spacing:-.02em; white-space:nowrap; }
.quiz-slider input[type=range]{
  appearance:none; -webkit-appearance:none; width:100%; height:4px; padding:0;
  background:var(--paper-3); border-radius:99px; outline:none; cursor:pointer; border:0;
}
.quiz-slider input[type=range]:focus{ box-shadow:none; background:var(--paper-3); }
.quiz-slider input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none; width:28px; height:28px; border-radius:50%;
  background:var(--blue); border:4px solid #fff; box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.quiz-slider input[type=range]::-moz-range-thumb{
  width:20px; height:20px; border-radius:50%;
  background:var(--blue); border:4px solid #fff; box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.quiz-slider-scale{ display:flex; justify-content:space-between; margin-top:-12px; color:var(--mut-2); }

/* ---------------- misc ---------------- */

.toast{
  position:fixed; bottom:26px; left:50%; transform:translate(-50%, 20px);
  background:var(--coal-2); color:#F5F5F7;
  font-size:.86rem; padding:13px 24px; border-radius:var(--r-sm);
  opacity:0; pointer-events:none; z-index:120;
  transition:opacity .3s var(--ease), transform .3s var(--ease);
  box-shadow:var(--shadow-pop);
  display:flex; gap:16px; align-items:center;
}
.toast.show{ opacity:1; transform:translate(-50%,0); pointer-events:auto; }
.toast a{ color:#fff; border-bottom:1px solid #6E6E73; white-space:nowrap; }

.breadcrumbs{ display:flex; gap:8px; align-items:center; font-size:.78rem; color:var(--mut-2); flex-wrap:wrap; }
.breadcrumbs a:hover{ color:var(--blue); }
.breadcrumbs svg{ width:10px; height:10px; }

.notice{
  border:0; border-left:0;
  background:var(--paper-2); border-radius:var(--r-sm);
  padding:16px 18px; font-size:.86rem; color:var(--ink-2);
}
.notice a{ color:var(--blue); }

.reveal{ opacity:0; transform:translateY(18px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  *{ scroll-behavior:auto !important; }
}

.marquee{ overflow:hidden; border-block:1px solid var(--line); padding:18px 0; }
.marquee-track{ display:flex; width:max-content; animation:marq 42s linear infinite; }
.marquee-track span{
  font-family:var(--sans); font-weight:500; font-size:.95rem; color:var(--mut); white-space:nowrap;
  display:inline-flex; align-items:center;
}
.marquee-track span::after{ content:'·'; color:var(--line-2); margin:0 32px; }
@keyframes marq{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .marquee-track{ animation:none; } }

.img-frame{ overflow:hidden; border-radius:var(--r); border:0; background:var(--paper-2); box-shadow:var(--shadow-card); }
.img-frame img{ width:100%; height:100%; object-fit:cover; }
