/* ============================================================
   Marble-Lite — Website (work in progress)
   Design: refined / editorial / material-forward
   ============================================================ */

:root{
  --charcoal:#2E2A27;
  --charcoal-90:rgba(46,42,39,.90);
  --charcoal-55:rgba(46,42,39,.55);
  --taupe:#7B6A58;
  --gold:#C4A053;
  --gold-dark:#A8853B;
  --cream:#F4EFEA;
  --stone:#D6CFCA;
  --paper:#FBF9F6;
  --line:rgba(46,42,39,.12);
  --ink:#2E2A27;
  --ink-soft:#5C534B;

  --font-display:"Playfair Display",Georgia,serif;
  --font-body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,sans-serif;

  --wrap:1200px;
  --gut:clamp(20px,5vw,64px);
  --radius:4px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gut)}
.eyebrow{
  font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;
  font-weight:600;color:var(--taupe);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold)}
h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.08;letter-spacing:-.01em}
.display{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4vw,3.1rem)}
h3{font-size:1.5rem}
p{color:var(--ink-soft)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 28px;border-radius:var(--radius);
  font-weight:600;font-size:15px;letter-spacing:.01em;
  border:1px solid transparent;transition:.25s ease;
}
.btn-gold{background:var(--gold);color:var(--charcoal)}
.btn-gold:hover{background:var(--gold-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--cream);border-color:rgba(244,239,234,.55)}
.btn-ghost:hover{background:rgba(244,239,234,.12);border-color:var(--cream)}
.btn-dark{background:var(--charcoal);color:var(--cream)}
.btn-dark:hover{background:#1d1a18;transform:translateY(-2px)}
.btn .ar{transition:transform .25s ease}
.btn:hover .ar{transform:translateX(4px)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .3s ease,box-shadow .3s ease,padding .3s ease;
  padding:18px 0;
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:52px;height:52px;transition:width .3s ease,height .3s ease}
.brand b{font-family:var(--font-display);font-size:1.35rem;color:var(--cream);font-weight:500;letter-spacing:.01em;transition:color .3s ease}
.nav{display:flex;align-items:center;gap:30px}
.nav a{color:rgba(244,239,234,.92);font-size:14.5px;font-weight:500;letter-spacing:.01em;transition:color .2s}
.nav a:hover{color:var(--gold)}
.header-cta{display:flex;align-items:center;gap:18px}
.header-phone{color:var(--cream);font-weight:600;font-size:15px;white-space:nowrap;transition:color .3s}
.header-phone .ti{color:var(--gold);margin-right:6px}
.header-cta .btn{padding:11px 20px}

/* scrolled state */
.site-header.scrolled{background:var(--charcoal);box-shadow:0 1px 0 rgba(255,255,255,.06);padding:10px 0}
.site-header.scrolled .brand img{width:42px;height:42px}

.menu-toggle{display:none;background:none;border:0;color:var(--cream);font-size:28px;line-height:1}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:flex-end;
  color:var(--cream);overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);animation:slowZoom 14s ease-out forwards}
.hero-bg video{width:100%;height:100%;object-fit:cover;display:block}
@keyframes slowZoom{to{transform:scale(1)}}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,var(--charcoal-55) 0%,rgba(46,42,39,.20) 38%,var(--charcoal-90) 100%);
}
.hero-inner{position:relative;z-index:1;width:100%;padding-bottom:clamp(48px,9vh,110px);padding-top:140px}
.hero .eyebrow{color:var(--cream)}
.hero .eyebrow::before{background:var(--gold)}
.hero h1{color:#fff;margin:20px 0 22px;max-width:14ch}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero p.lede{font-size:clamp(1.05rem,1.6vw,1.3rem);color:rgba(244,239,234,.9);max-width:48ch;margin-bottom:34px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:40px}
.hero-trust{display:flex;flex-wrap:wrap;gap:28px;align-items:center;font-size:14px;color:rgba(244,239,234,.85)}
.hero-trust span{display:inline-flex;align-items:center;gap:8px}
.hero-trust .ti{color:var(--gold);font-size:18px}
.scroll-hint{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:1;color:rgba(244,239,234,.6);font-size:22px;animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ---------- Section scaffolding ---------- */
.section{padding:clamp(64px,9vw,120px) 0}
.section-head{max-width:62ch}
.section-head h2{margin:16px 0 0}
.section-head p{margin-top:16px;font-size:1.08rem}
.center{text-align:center;margin-left:auto;margin-right:auto}
.center .eyebrow{justify-content:center}

/* ---------- Trust strip ---------- */
.trust-strip{background:var(--charcoal);color:var(--cream)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(244,239,234,.12)}
.trust-grid .cell{background:var(--charcoal);padding:34px 24px;text-align:center}
.trust-grid .num{font-family:var(--font-display);font-size:2.5rem;color:var(--gold);line-height:1}
.trust-grid .lbl{margin-top:8px;font-size:13.5px;letter-spacing:.04em;color:rgba(244,239,234,.8)}
.trust-grid .stars{color:var(--gold);font-size:1.5rem;letter-spacing:2px}

/* ---------- Audience split ---------- */
.audience-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:52px}
.aud-card{position:relative;border-radius:var(--radius);overflow:hidden;min-height:440px;display:flex;align-items:flex-end;color:var(--cream)}
.aud-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.aud-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(46,42,39,.05) 30%,var(--charcoal-90) 100%)}
.aud-card:hover img{transform:scale(1.06)}
.aud-body{position:relative;z-index:1;padding:36px}
.aud-body .tag{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600}
.aud-body h3{color:#fff;font-size:1.9rem;margin:8px 0 10px}
.aud-body p{color:rgba(244,239,234,.88);max-width:38ch;margin-bottom:18px}
.aud-link{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;color:var(--cream);border-bottom:1px solid var(--gold);padding-bottom:3px}
.aud-link .ar{transition:transform .25s}
.aud-card:hover .aud-link .ar{transform:translateX(5px)}

/* ---------- Product range ---------- */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:52px}
.prod{display:block;border-radius:var(--radius);overflow:hidden;background:#fff;border:1px solid var(--line);transition:transform .3s ease,box-shadow .3s ease}
.prod:hover{transform:translateY(-5px);box-shadow:0 18px 40px -22px rgba(46,42,39,.45)}
.prod .ph{aspect-ratio:4/3;overflow:hidden;background:var(--stone)}
.prod .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.prod:hover .ph img{transform:scale(1.07)}
.prod .meta{padding:20px 22px 24px}
.prod h3{font-size:1.25rem}
.prod p{font-size:14px;margin-top:6px}

/* ---------- Why us ---------- */
.why{background:var(--cream)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:34px;margin-top:54px}
.why-item{text-align:center}
.why-item .ic{width:84px;height:84px;margin:0 auto 18px;display:flex;align-items:center;justify-content:center}
.why-item .ic img{width:100%;height:100%;object-fit:contain}
.why-item h3{font-size:1.22rem;margin-bottom:8px}
.why-item p{font-size:14.5px}

/* ---------- Finishes ---------- */
.finishes{background:#fff}
.swatches{display:grid;grid-template-columns:repeat(9,1fr);gap:14px;margin-top:46px}
.swatch figure{margin:0}
.swatch .chip{aspect-ratio:1;border-radius:50%;overflow:hidden;border:1px solid var(--line);box-shadow:inset 0 0 0 4px #fff}
.swatch .chip img{width:100%;height:100%;object-fit:cover}
.swatch figcaption{margin-top:10px;text-align:center;font-size:12px;color:var(--ink-soft);letter-spacing:.01em}
.finishes .note{margin-top:30px;font-size:14px;color:var(--taupe)}

/* ---------- Social proof ---------- */
.proof{background:var(--charcoal);color:var(--cream)}
.proof .eyebrow{color:var(--cream)}
.clients{display:flex;flex-wrap:wrap;gap:14px 40px;align-items:center;margin:30px 0 56px}
.clients span{font-family:var(--font-display);font-size:1.35rem;color:rgba(244,239,234,.78)}
.review-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review{background:rgba(244,239,234,.05);border:1px solid rgba(244,239,234,.12);border-radius:var(--radius);padding:28px}
.review .stars{color:var(--gold);letter-spacing:3px;font-size:1.05rem}
.review blockquote{font-family:var(--font-display);font-size:1.18rem;line-height:1.45;color:var(--cream);margin:14px 0 16px;font-style:italic}
.review cite{font-style:normal;font-size:13.5px;color:rgba(244,239,234,.7);font-weight:600;letter-spacing:.02em}

/* ---------- CTA band ---------- */
.cta-band{background:var(--taupe);color:var(--cream);text-align:center}
.cta-band h2{color:#fff;max-width:18ch;margin:14px auto 18px}
.cta-band p{color:rgba(244,239,234,.92);max-width:52ch;margin:0 auto 32px;font-size:1.08rem}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;align-items:center}
.cta-phone{color:#fff;font-weight:600;font-size:1.15rem;display:inline-flex;align-items:center;gap:9px}
.cta-phone .ti{color:var(--gold)}

/* ---------- Footer ---------- */
.footer{background:var(--charcoal);color:rgba(244,239,234,.78);padding:72px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px}
.foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.foot-brand img{width:48px;height:48px}
.foot-brand b{font-family:var(--font-display);color:var(--cream);font-size:1.3rem;font-weight:500}
.footer p{font-size:14.5px;color:rgba(244,239,234,.66);max-width:34ch}
.foot-col h4{font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;font-weight:600;font-family:var(--font-body)}
.foot-col a{display:block;font-size:14.5px;color:rgba(244,239,234,.78);padding:6px 0;transition:color .2s}
.foot-col a:hover{color:var(--gold)}
.foot-contact .ti{color:var(--gold);width:20px;display:inline-block}
.foot-bottom{border-top:1px solid rgba(244,239,234,.12);margin-top:48px;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:rgba(244,239,234,.55)}

/* ---------- Quote form (placeholder) ---------- */
.quote{background:var(--paper)}
.quote-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(28px,4vw,48px);display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.quote-card form{display:grid;gap:14px}
.quote-card .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.quote label{font-size:13px;font-weight:600;color:var(--ink);display:block;margin-bottom:6px}
.quote input,.quote select,.quote textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius);
  font-family:inherit;font-size:15px;background:var(--paper);color:var(--ink);
}
.quote input:focus,.quote select:focus,.quote textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,160,83,.18)}
.quote .aside h3{margin-bottom:14px}
.quote .aside li{list-style:none;display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--line);font-size:15px;color:var(--ink-soft)}
.quote .aside .ti{color:var(--gold);font-size:20px;margin-top:2px}
.form-note{font-size:12.5px;color:var(--taupe);margin-top:4px}

/* ============================================================
   INTERIOR PAGES (vanity / showers / tubs)
   ============================================================ */
.page-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;color:var(--cream);overflow:hidden}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--charcoal-55),var(--charcoal-90))}
.page-hero .inner{position:relative;z-index:1;width:100%;padding:150px 0 56px}
.breadcrumb{font-size:13px;letter-spacing:.04em;color:rgba(244,239,234,.7);margin-bottom:14px}
.breadcrumb a{color:var(--gold)}
.page-hero h1{color:#fff;font-size:clamp(2.4rem,5vw,3.8rem);margin-bottom:16px;max-width:16ch}
.page-hero p{color:rgba(244,239,234,.9);max-width:50ch;font-size:1.12rem;margin-bottom:26px}

/* Alternating feature rows */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.feature + .feature{margin-top:clamp(48px,7vw,96px)}
.feature.flip .feat-media{order:2}
.feat-media{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:var(--stone)}
.feat-media img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.feature:hover .feat-media img{transform:scale(1.04)}
.feat-text h2{font-size:clamp(1.8rem,3vw,2.6rem);margin:14px 0 14px}
.feat-text p{font-size:1.05rem;margin-bottom:14px}
.feat-list{list-style:none;padding:0;margin:18px 0 0}
.feat-list li{display:flex;gap:12px;align-items:flex-start;padding:9px 0;font-size:15.5px;color:var(--ink-soft)}
.feat-list .ti{color:var(--gold);font-size:20px;margin-top:1px}

/* Bowl grid */
.bowl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
.bowl{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .3s,box-shadow .3s}
.bowl:hover{transform:translateY(-4px);box-shadow:0 16px 36px -22px rgba(46,42,39,.4)}
.bowl .ph{aspect-ratio:1;background:var(--paper);overflow:hidden}
.bowl .ph img{width:100%;height:100%;object-fit:cover}
.bowl span{display:block;text-align:center;padding:13px 8px;font-size:14px;font-weight:500;color:var(--ink)}
/* clickable bowl photo (opens drawing) */
.bowl .ph-btn{position:relative;display:block;width:100%;padding:0;border:0;background:var(--paper);cursor:pointer;font:inherit}
.bowl .ph-btn .ph-zoom{position:absolute;top:10px;right:10px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(46,42,39,.62);color:#fff;font-size:16px;opacity:.85;transition:opacity .25s,transform .25s;backdrop-filter:blur(2px)}
.bowl .ph-btn:hover .ph-zoom,.bowl .ph-btn:focus-visible .ph-zoom{opacity:1;transform:scale(1.08)}
.bowl .ph-btn:focus-visible{outline:2px solid var(--gold-dark);outline-offset:-2px}

/* Bowl drawing lightbox */
.dwg-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}
.dwg-modal[hidden]{display:none}
.dwg-backdrop{position:absolute;inset:0;background:rgba(46,42,39,.62);backdrop-filter:blur(3px);animation:dwgFade .2s ease}
.dwg-dialog{position:relative;background:#fff;border-radius:var(--radius);max-width:680px;width:100%;max-height:88vh;overflow:auto;padding:20px 20px 24px;box-shadow:0 30px 70px -30px rgba(46,42,39,.6);animation:dwgPop .22s ease}
.dwg-title{text-align:center;margin:6px 0 14px;font-size:20px;color:var(--charcoal)}
.dwg-img{display:flex;align-items:center;justify-content:center}
.dwg-img img{max-width:100%;max-height:70vh;object-fit:contain}
.dwg-close{position:absolute;top:12px;right:12px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:50%;background:#fff;color:var(--ink);font-size:19px;cursor:pointer;transition:background .2s,color .2s}
.dwg-close:hover{background:var(--charcoal);color:#fff}
@keyframes dwgFade{from{opacity:0}to{opacity:1}}
@keyframes dwgPop{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}

/* Edge / spec strip */
.spec{background:var(--cream)}
.edge-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.edge-chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:11px 22px;font-weight:500;font-size:15px;color:var(--charcoal)}
.edge-chip b{color:var(--gold-dark)}

/* Gallery grid */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.gallery figure{margin:0;position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:var(--stone)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;color:#fff;font-size:14px;font-weight:500;background:linear-gradient(180deg,transparent,rgba(46,42,39,.85))}

/* Technical drawings */
.drawings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px}
.drawings-subhead{margin:46px 0 0;font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-dark);display:flex;align-items:center;gap:12px}
.drawings-subhead::after{content:"";flex:1;height:1px;background:var(--line)}
.drawings-subhead + .drawings-grid{margin-top:20px}
.draw-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:box-shadow .3s,transform .3s}
.draw-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px -22px rgba(46,42,39,.4)}
.draw-card .img{aspect-ratio:4/3;background:#fff;display:flex;align-items:center;justify-content:center;padding:14px}
.draw-card .img img{max-width:100%;max-height:100%;object-fit:contain}
.draw-card span{display:block;text-align:center;padding:12px 10px;font-size:14px;font-weight:500;color:var(--ink);border-top:1px solid var(--line)}

/* Download row */
.downloads{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.dl{display:inline-flex;align-items:center;gap:12px;padding:14px 20px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;font-weight:500;font-size:15px;color:var(--charcoal);transition:.2s}
.dl:hover{border-color:var(--gold);background:var(--cream);transform:translateY(-2px)}
.dl .ti{color:var(--gold-dark);font-size:22px}
.dl small{display:block;color:var(--taupe);font-weight:400;font-size:12px;letter-spacing:.02em}

/* Contact layout */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:8px}
.contact-info li{list-style:none;display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line);font-size:16px;color:var(--ink)}
.contact-info .ti{color:var(--gold-dark);font-size:22px;margin-top:2px}
.contact-info a{color:var(--ink)}
.contact-info b{display:block;font-size:13px;color:var(--taupe);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}
.map-embed{border:0;width:100%;height:340px;border-radius:var(--radius);margin-top:8px}

/* Blog index */
.post-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}
.post-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .3s,box-shadow .3s}
.post-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px -22px rgba(46,42,39,.4)}
.post-card .ph{aspect-ratio:16/9;overflow:hidden;background:var(--stone)}
.post-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.post-card:hover .ph img{transform:scale(1.05)}
.post-card .meta{padding:22px 24px 26px}
.post-card .tag{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe);font-weight:600}
.post-card h3{font-size:1.4rem;margin:8px 0 8px}
.post-card p{font-size:15px}

/* Article */
.article{max-width:740px;margin:0 auto}
.article .lede2{font-size:1.2rem;color:var(--ink);line-height:1.6;margin-bottom:28px}
.article h2{font-size:1.7rem;margin:38px 0 12px}
.article p{font-size:1.06rem;margin-bottom:18px;color:var(--ink-soft);line-height:1.75}
.article blockquote{border-left:3px solid var(--gold);border-radius:0;padding:8px 0 8px 22px;margin:30px 0;font-family:var(--font-display);font-style:italic;font-size:1.3rem;color:var(--charcoal);line-height:1.4}
.article .meta-bar{display:flex;gap:14px;align-items:center;color:var(--taupe);font-size:14px;margin-bottom:12px}

/* FAQ accordion */
.faq{max-width:840px;margin:38px auto 0}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:18px 38px 18px 0;font-weight:500;font-size:1.08rem;color:var(--charcoal);position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:15px;font-size:1.5rem;color:var(--gold-dark)}
.faq details[open] summary::after{content:"\2212"}
.faq p{padding:0 0 20px;color:var(--ink-soft);font-size:1.02rem;margin:0;max-width:72ch;line-height:1.7}

/* Mini CTA band on interior pages */
.mini-cta{background:var(--charcoal);color:var(--cream);text-align:center}
.mini-cta h2{color:#fff;margin:0 auto 22px;max-width:20ch}
.mini-cta .cta-actions{margin-top:0}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .nav,.header-phone{display:none}
  .menu-toggle{display:block}
  .trust-grid,.prod-grid,.why-grid{grid-template-columns:repeat(2,1fr)}
  .audience-grid{grid-template-columns:1fr}
  .swatches{grid-template-columns:repeat(5,1fr)}
  .review-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .quote-card{grid-template-columns:1fr}
  .feature{grid-template-columns:1fr;gap:28px}
  .feature.flip .feat-media{order:0}
  .bowl-grid{grid-template-columns:repeat(3,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .drawings-grid{grid-template-columns:repeat(2,1fr)}
  .post-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .mobile-open .nav{
    display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--charcoal);padding:18px var(--gut) 26px;gap:6px;align-items:flex-start;
    border-top:1px solid rgba(244,239,234,.12);
  }
  .mobile-open .nav a{padding:8px 0;font-size:16px}
}
@media(max-width:560px){
  .trust-grid{grid-template-columns:1fr 1fr}
  .prod-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .swatches{grid-template-columns:repeat(3,1fr)}
  .bowl-grid{grid-template-columns:repeat(2,1fr)}
  .quote-card .row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .hero-actions .btn{flex:1}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   PRODUCT BUILDERS (vanity / shower / wall panel)
   ============================================================ */
.builder-section{padding:clamp(40px,6vw,72px) 0 clamp(56px,8vw,110px)}
.builder-layout{display:grid;grid-template-columns:minmax(320px,400px) 1fr;gap:clamp(24px,3vw,44px);align-items:start}

/* Controls column */
.builder-controls{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(20px,2.4vw,30px)}
.bc-group{padding:16px 0;border-bottom:1px solid var(--line)}
.bc-group:first-child{padding-top:0}
.bc-group:last-child{border-bottom:0;padding-bottom:0}
.bc-group > label,.bc-label{display:block;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--taupe);margin-bottom:10px}
.builder-controls select,.builder-controls input[type=number],.builder-controls input[type=text]{
  width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:var(--radius);
  font-family:inherit;font-size:15px;background:var(--paper);color:var(--ink);
}
.builder-controls select:focus,.builder-controls input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,160,83,.18)}
.bc-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.bc-row .bc-field{min-width:0}
.bc-field small{display:block;font-size:11px;color:var(--taupe);margin-bottom:5px;font-weight:500;letter-spacing:.02em;text-transform:none}

/* Segmented toggle */
.seg{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:var(--paper)}
.seg button{background:none;border:0;padding:9px 18px;font-size:14px;font-weight:500;color:var(--ink-soft);transition:.18s}
.seg button[aria-pressed=true]{background:var(--charcoal);color:var(--cream)}
.seg.full{display:flex;width:100%}
.seg.full button{flex:1}

/* Chip toggles (curb sides, etc.) */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip-toggle{border:1px solid var(--line);background:var(--paper);border-radius:999px;padding:8px 16px;font-size:13.5px;font-weight:500;color:var(--ink-soft);transition:.18s}
.chip-toggle[aria-pressed=true]{background:var(--gold);border-color:var(--gold);color:var(--charcoal)}

/* Preview column */
.builder-preview{position:sticky;top:90px}
.preview-frame{background:linear-gradient(180deg,#fff,var(--paper));border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;min-height:380px;display:flex;align-items:center;justify-content:center}
.preview-frame svg{width:100%;height:auto;max-height:60vh}
.preview-caption{margin-top:14px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.preview-caption .pc-name{font-family:var(--font-display);font-size:1.25rem}
.preview-note{font-size:12.5px;color:var(--taupe);margin-top:6px}

/* Request form under the builder */
.builder-request{margin-top:30px;background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,2.6vw,32px);position:relative}
.builder-request h3{margin-bottom:6px}
.builder-request p.sub{font-size:14.5px;margin-bottom:18px}
.builder-request form{display:grid;gap:14px}
.builder-request .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.builder-request label{font-size:13px;font-weight:600;color:var(--ink);display:block;margin-bottom:6px}
.builder-request input,.builder-request textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius);
  font-family:inherit;font-size:15px;background:#fff;color:var(--ink);
}
.builder-request input:focus,.builder-request textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,160,83,.18)}
.builder-request .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.builder-note{font-size:12.5px;color:var(--taupe);margin-top:4px;min-height:18px}

/* Builder CTA on product pages */
.builder-cta{display:inline-flex;align-items:center;gap:10px;margin-top:10px}

@media(max-width:900px){
  .builder-layout{grid-template-columns:1fr}
  .builder-preview{position:static;order:-1}
  .builder-request .row{grid-template-columns:1fr}
}

/* Hospitality — table-top shape & color showcase */
.tabletop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.tabletop-grid .bowl .ph{aspect-ratio:1;background:#fff}
.tabletop-grid .bowl .ph img{object-fit:cover}
.tabletop-grid .bowl small{display:block;font-size:12px;font-weight:400;color:var(--ink-soft);margin-top:2px}
/* Standard table size list */
.size-list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,3vw,38px)}
.size-list h4{font-family:var(--font-display);font-size:1.15rem;font-weight:500;margin:0 0 12px;color:var(--charcoal)}
.size-list ul{list-style:none;margin:0;padding:0;columns:1}
.size-list li{font-size:14.5px;color:var(--ink-soft);padding:3px 0;border-bottom:1px solid var(--line)}
.size-list li:last-child{border-bottom:0}
@media(max-width:860px){
  .tabletop-grid{grid-template-columns:repeat(2,1fr)}
  .size-list{grid-template-columns:1fr;gap:20px}
}
@media(max-width:540px){
  .tabletop-grid{grid-template-columns:repeat(2,1fr)}
}
/* Table edge-profile grid (5 across) */
.edge-grid{grid-template-columns:repeat(5,1fr)}
.draw-card span small{display:block;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--gold-dark);margin-top:3px}
@media(max-width:1080px){ .edge-grid{grid-template-columns:repeat(3,1fr)} }
@media(max-width:860px){ .edge-grid{grid-template-columns:repeat(2,1fr)} }
