/* ===== Lumen Interiors — editorial finish-package site ===== */
:root{
  --cream:#FAF7F2;
  --cream-2:#F2ECE2;
  --ink:#1B1916;
  --ink-soft:#4a443c;
  --muted:#867d6f;
  --gold:#A98A5C;
  --gold-deep:#8c6f44;
  --line:#e3dccf;
  --dark:#1A1815;
  --radius:3px;
  --wrap:1180px;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Inter",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 32px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---- typography ---- */
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.1;letter-spacing:.2px}
h1{font-size:clamp(2.1rem,4.2vw,3.15rem);font-weight:400}
h1 em{font-style:italic;color:var(--gold)}
h2{font-size:clamp(1.8rem,3.4vw,2.7rem)}
.eyebrow,.num,.pillar-label,.service-kicker,.quote-eyebrow,.brand-sub{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  font-weight:500;
  color:var(--gold-deep);
}

/* ===== HEADER ===== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,247,242,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s,background .3s;
}
.site-header.scrolled{border-color:var(--line);box-shadow:0 6px 30px -22px rgba(0,0,0,.5)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand-mark{display:flex;flex:0 0 auto;color:var(--ink)}
.mark-svg{width:34px;height:34px;display:block}
.brand-words{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--serif);font-size:1.32rem;letter-spacing:.34em;color:var(--ink)}
.brand-sub{font-family:var(--sans);font-size:.56rem;letter-spacing:.455em;color:var(--muted);margin-top:6px}
.nav{display:flex;align-items:center;gap:34px}
.nav a{font-size:.86rem;color:var(--ink-soft);transition:color .2s;position:relative}
.nav a:not(.nav-cta):after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .25s}
.nav a:not(.nav-cta):hover{color:var(--ink)}
.nav a:not(.nav-cta):hover:after{width:100%}
.nav-cta{
  border:1px solid var(--ink);padding:10px 20px;border-radius:var(--radius);
  font-size:.8rem;letter-spacing:.04em;transition:.25s;
}
.nav-cta:hover{background:var(--ink);color:var(--cream)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:24px;position:relative}
.nav-toggle span{position:absolute;left:0;height:2px;width:100%;background:var(--ink);transition:.3s}
.nav-toggle span:nth-child(1){top:2px}
.nav-toggle span:nth-child(2){top:11px}
.nav-toggle span:nth-child(3){top:20px}
.nav-toggle.open span:nth-child(1){top:11px;transform:rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){top:11px;transform:rotate(-45deg)}

/* ===== HERO ===== */
.hero{padding:70px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.eyebrow{display:block;margin-bottom:22px}
.hero h1{margin-bottom:26px;max-width:19ch}
.lede{font-size:1.06rem;color:var(--ink-soft);max-width:46ch;margin-bottom:32px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:42px}
.btn{
  display:inline-block;padding:14px 28px;border-radius:var(--radius);
  font-size:.85rem;font-weight:500;letter-spacing:.04em;transition:.25s;cursor:pointer;border:1px solid transparent;
}
.btn-primary{background:var(--ink);color:var(--cream)}
.btn-primary:hover{background:var(--gold-deep)}
.btn-ghost{border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-light{background:transparent;border-color:rgba(255,255,255,.5);color:#fff}
.btn-light:hover{background:rgba(255,255,255,.12)}
.hero-stats{list-style:none;display:flex;gap:30px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:26px}
.hero-stats strong{font-family:var(--serif);font-size:1.5rem;font-weight:500;display:block;color:var(--ink)}
.hero-stats span{font-size:.78rem;color:var(--muted);display:block;max-width:18ch;margin-top:2px}
.hero-media{position:relative}
.hero-media img{width:100%;height:560px;object-fit:cover;border-radius:var(--radius)}
.hero-tag{
  position:absolute;left:22px;bottom:22px;background:rgba(26,24,21,.82);color:var(--cream);
  font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;padding:9px 16px;border-radius:var(--radius);
  backdrop-filter:blur(4px);
}

/* ===== SECTIONS ===== */
.section{padding:92px 0}
.section-alt{background:var(--cream-2)}
.section-head{max-width:60ch;margin-bottom:54px}
.num{display:block;margin-bottom:18px}
.section-head h2{margin-bottom:18px}
.section-intro{color:var(--ink-soft);font-size:1.02rem;max-width:54ch}

/* ---- pillars ---- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.pillar{
  background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);
  padding:0 0 30px;overflow:hidden;transition:transform .35s,box-shadow .35s;
}
.section-alt .pillar{background:#fff}
.pillar:hover{transform:translateY(-6px);box-shadow:0 26px 50px -34px rgba(0,0,0,.45)}
.pillar-media{height:200px;overflow:hidden}
.pillar-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.pillar:hover .pillar-media img{transform:scale(1.06)}
.pillar-label{display:block;padding:26px 28px 0}
.pillar h3{font-size:1.7rem;padding:6px 28px 14px}
.pillar ul{list-style:none;padding:0 28px}
.pillar ul li{position:relative;padding:7px 0 7px 20px;font-size:.92rem;color:var(--ink-soft);border-bottom:1px solid var(--line)}
.pillar ul li:last-child{border-bottom:0}
.pillar ul li:before{content:"";position:absolute;left:0;top:14px;width:7px;height:7px;background:var(--gold);transform:rotate(45deg)}
.pillar-note{padding:16px 28px 0;font-size:.82rem;color:var(--muted)}
.pillar-note strong{color:var(--ink)}

/* ---- services ---- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.service{display:flex;flex-direction:column;background:var(--cream);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);transition:transform .35s,box-shadow .35s}
.section-alt .service{background:#fff}
.service:hover{transform:translateY(-6px);box-shadow:0 26px 50px -34px rgba(0,0,0,.45)}
.service-media{height:210px;overflow:hidden}
.service-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.service:hover .service-media img{transform:scale(1.06)}
.service-body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1}
.service-kicker{display:block;margin-bottom:10px}
.service-body h3{font-size:1.45rem;margin-bottom:12px}
.service-body p{font-size:.92rem;color:var(--ink-soft);margin-bottom:18px}
.tags{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}
.tags li{font-size:.7rem;letter-spacing:.04em;color:var(--gold-deep);border:1px solid var(--line);padding:5px 11px;border-radius:40px}

/* ---- process ---- */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line);border:1px solid var(--line)}
.process-item{background:var(--cream);padding:38px 34px;transition:background .3s}
.process-item:hover{background:#fff}
.diamond{display:block;width:13px;height:13px;background:var(--gold);transform:rotate(45deg);margin-bottom:22px}
.process-item h3{font-size:1.3rem;margin-bottom:10px}
.process-item p{font-size:.9rem;color:var(--ink-soft)}

/* ===== QUOTE BAND ===== */
.quote-band{background:var(--dark);color:var(--cream);padding:96px 0}
.quote-inner{max-width:920px}
.quote-eyebrow{color:var(--gold);display:block;margin-bottom:26px}
.quote-band blockquote{
  font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.2rem);line-height:1.4;font-weight:400;position:relative;
}
.quote-band blockquote .mark{font-size:3rem;color:var(--gold);display:inline-block;line-height:0;vertical-align:-.35em;margin-right:6px}
.quote-band strong{color:#fff;font-style:italic}

/* ===== SEGMENTS ===== */
.segments-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.sectors{list-style:none;margin:30px 0 26px;border-top:1px solid var(--line)}
.sectors li{padding:18px 0;border-bottom:1px solid var(--line);font-size:.95rem;color:var(--ink-soft)}
.sectors li span{display:block;font-family:var(--serif);font-size:1.3rem;color:var(--ink);margin-bottom:2px}
.compliance{list-style:none;display:flex;flex-wrap:wrap;gap:10px}
.compliance li{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);border:1px solid var(--line);padding:7px 14px;border-radius:40px}
.segments-media{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.segments-media img{width:100%;height:300px;object-fit:cover;border-radius:var(--radius)}
.segments-media img:first-child{margin-top:34px}

/* ===== CTA ===== */
.cta{position:relative;padding:120px 0;color:#fff;text-align:center;background:var(--dark)}
.cta:before{
  content:"";position:absolute;inset:0;background:var(--cta-bg) center/cover no-repeat;opacity:.30;
}
.cta:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,18,16,.6),rgba(20,18,16,.82))}
.cta-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;text-align:left}
.eyebrow.light{color:var(--gold)}
.cta h2{margin:18px 0 20px;color:#fff;font-weight:400}
.cta-lede{color:rgba(255,255,255,.82);font-size:1.05rem;margin:0 0 26px;max-width:46ch}
.cta-points{list-style:none;margin:0 0 28px;display:grid;gap:12px}
.cta-points li{position:relative;padding-left:24px;color:rgba(255,255,255,.85);font-size:.95rem}
.cta-points li:before{content:"";position:absolute;left:0;top:7px;width:9px;height:9px;background:var(--gold);transform:rotate(45deg)}
.cta-meta{font-size:.82rem;letter-spacing:.02em;color:rgba(255,255,255,.62)}
.cta-meta a{color:var(--gold);border-bottom:1px solid rgba(169,138,92,.5)}

/* form card */
.form-card{background:var(--cream);border-radius:6px;padding:30px;box-shadow:0 40px 80px -40px rgba(0,0,0,.7)}
.form-card .field{margin-bottom:16px}
.form-card .field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-card label{display:block;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:7px;font-weight:500}
.form-card label span{color:var(--gold-deep)}
.form-card input,.form-card select,.form-card textarea{
  width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:var(--radius);
  background:#fff;font-family:var(--sans);font-size:.92rem;color:var(--ink);transition:border-color .2s,box-shadow .2s;
}
.form-card input:focus,.form-card select:focus,.form-card textarea:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(169,138,92,.15);
}
.form-card textarea{resize:vertical;min-height:74px}
.form-submit{width:100%;margin-top:6px;text-align:center}
.form-status{font-size:.85rem;margin-top:12px;min-height:1.1em;color:var(--ink-soft)}
.form-status.is-success{color:var(--gold-deep)}
.form-status.is-error{color:#b3402f}

/* ===== FOOTER ===== */
.site-footer{background:var(--dark);color:rgba(255,255,255,.78);padding:72px 0 34px}
.footer-inner{display:grid;grid-template-columns:1.4fr 1.6fr;gap:50px;padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.12)}
.brand--footer{margin-bottom:18px}
.brand--footer .brand-mark{color:var(--cream)}
.footer-brand .brand-name{color:#fff;font-size:1.32rem}
.footer-brand .brand-sub{color:var(--gold)}
.footer-brand p{margin-top:18px;font-size:.9rem;max-width:34ch;color:rgba(255,255,255,.6)}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.footer-cols h4{font-family:var(--sans);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--gold);margin-bottom:16px;font-weight:600}
.footer-cols a,.footer-cols span{display:block;font-size:.9rem;color:rgba(255,255,255,.7);margin-bottom:10px;transition:color .2s}
.footer-cols a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;flex-wrap:wrap;gap:10px}
.footer-tagline{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.footer-legal{font-size:.78rem;color:rgba(255,255,255,.5)}

/* ===== NAV: products mega-menu ===== */
.nav-item{position:relative;display:flex;align-items:center}
.nav-trigger{display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.nav-trigger .caret{width:9px;height:9px;transition:transform .25s;opacity:.7}
.nav-item:hover .nav-trigger .caret{transform:rotate(180deg)}
.mega{
  position:absolute;top:calc(100% + 18px);left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--cream);border:1px solid var(--line);border-radius:6px;
  box-shadow:0 30px 60px -30px rgba(0,0,0,.5);padding:26px 30px;
  display:grid;grid-template-columns:repeat(3,minmax(190px,1fr));gap:24px 38px;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .22s,transform .22s;z-index:60;
}
.mega:before{content:"";position:absolute;top:-18px;left:0;right:0;height:18px}
.nav-item:hover .mega,.nav-item.open .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.mega-label{font-family:var(--sans);text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;color:var(--gold-deep);font-weight:600;margin-bottom:6px}
.mega-col a{display:block;padding:8px 0;font-size:.9rem;color:var(--ink-soft);border-bottom:1px solid var(--line)}
.mega-col a:last-child{border-bottom:0}
.mega-col a:after{display:none !important}
.mega-col a:hover{color:var(--gold-deep)}

/* ===== PRODUCT INDEX: clickable cards ===== */
a.service{color:inherit;text-decoration:none}
.service-view{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);font-weight:500}
.service:hover .service-view{gap:11px}
.service-view svg{width:14px;height:14px}

/* ===== PRODUCT PAGE ===== */
.product-hero{padding:54px 0 40px}
.breadcrumb{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:26px}
.breadcrumb a{color:var(--gold-deep)}
.breadcrumb span{margin:0 9px;opacity:.5}
.product-hero-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:center}
.product-hero-copy .eyebrow{display:block;margin-bottom:18px}
.product-hero-copy h1{font-size:clamp(2.2rem,4.4vw,3.3rem);margin-bottom:22px;font-weight:400}
.product-hero-copy .lede{font-size:1.06rem;color:var(--ink-soft);margin-bottom:30px;max-width:44ch}
.product-hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.product-hero-media{position:relative}
.product-hero-media img{width:100%;height:520px;object-fit:cover;border-radius:4px}

.product-section{padding:70px 0;border-top:1px solid var(--line)}
.product-section.alt{background:var(--cream-2)}
.product-lead{max-width:62ch;margin-bottom:46px}
.product-lead h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:16px}
.product-lead p{color:var(--ink-soft);font-size:1.02rem;margin-bottom:14px}
.product-lead p:last-child{margin-bottom:0}

/* gallery */
.gallery{display:grid;grid-template-columns:1.4fr 1fr;grid-template-rows:1fr 1fr;gap:18px;height:560px}
.gallery img{width:100%;height:100%;object-fit:cover;border-radius:4px}
.gallery img:first-child{grid-row:1 / span 2}

/* specs + features */
.product-cols{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.spec-list{list-style:none}
.spec-list li{display:flex;justify-content:space-between;gap:20px;padding:14px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.spec-list li span:first-child{color:var(--muted)}
.spec-list li span:last-child{color:var(--ink);text-align:right;font-weight:500}
.feature{padding:22px 0;border-bottom:1px solid var(--line)}
.feature:last-child{border-bottom:0}
.feature h3{font-size:1.3rem;margin-bottom:8px}
.feature p{color:var(--ink-soft);font-size:.95rem}
.finish-tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:18px}
.finish-tags li{list-style:none;font-size:.74rem;letter-spacing:.04em;color:var(--gold-deep);border:1px solid var(--line);padding:7px 14px;border-radius:40px}

/* related */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.related-card{border:1px solid var(--line);border-radius:4px;overflow:hidden;background:var(--cream);transition:transform .35s,box-shadow .35s;color:inherit;text-decoration:none;display:block}
.related-card:hover{transform:translateY(-5px);box-shadow:0 24px 46px -32px rgba(0,0,0,.45)}
.related-card .rc-media{height:170px;overflow:hidden}
.related-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.related-card:hover img{transform:scale(1.06)}
.related-card .rc-body{padding:18px 20px}
.related-card .rc-kicker{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);display:block;margin-bottom:7px}
.related-card h3{font-size:1.25rem}

/* ===== TESTIMONIALS ===== */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.testimonial{background:var(--cream);border:1px solid var(--line);border-radius:4px;padding:32px 30px;display:flex;flex-direction:column;gap:18px}
.section-alt .testimonial{background:#fff}
.testimonial blockquote{font-family:var(--serif);font-size:1.3rem;line-height:1.46;color:var(--ink);font-style:italic}
.testimonial figcaption{margin-top:auto;border-top:1px solid var(--line);padding-top:16px;font-size:.82rem;color:var(--muted);line-height:1.55}
.testimonial .t-role{display:block;color:var(--gold-deep);letter-spacing:.02em}

/* ===== FAQ ===== */
.faq{max-width:840px;margin:0 auto;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;padding:24px 48px 24px 0;position:relative;font-family:var(--serif);font-size:1.32rem;color:var(--ink);transition:color .2s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-family:var(--sans);font-weight:300;font-size:1.6rem;color:var(--gold);transition:.25s}
.faq-item[open] summary:after{content:"–"}
.faq-item summary:hover{color:var(--gold-deep)}
.faq-answer{padding:0 48px 24px 0;color:var(--ink-soft);font-size:.98rem;max-width:72ch;animation:faqIn .3s ease}
@keyframes faqIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* ===== PROJECTS ===== */
.page-head{max-width:62ch}
.page-head .eyebrow{display:block;margin-bottom:18px}
.page-head h1{font-size:clamp(2.2rem,4.4vw,3.2rem);font-weight:400;margin-bottom:20px}
.page-head .lede{font-size:1.06rem;color:var(--ink-soft);max-width:58ch}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.project-card{background:var(--cream);border:1px solid var(--line);border-radius:4px;overflow:hidden;display:flex;flex-direction:column;transition:transform .35s,box-shadow .35s}
.section-alt .project-card{background:#fff}
.project-card:hover{transform:translateY(-6px);box-shadow:0 26px 50px -34px rgba(0,0,0,.45)}
.project-media{position:relative;height:230px;overflow:hidden}
.project-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.project-card:hover .project-media img{transform:scale(1.06)}
.project-sector{position:absolute;left:16px;top:16px;background:rgba(26,24,21,.82);color:var(--cream);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;padding:7px 13px;border-radius:40px;backdrop-filter:blur(4px)}
.project-body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1}
.project-body h3{font-size:1.5rem;margin-bottom:5px}
.project-meta{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:14px}
.project-blurb{font-size:.92rem;color:var(--ink-soft);margin-bottom:18px}
.project-supplied{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}
.project-supplied li{font-size:.7rem;letter-spacing:.03em;color:var(--gold-deep);border:1px solid var(--line);padding:5px 11px;border-radius:40px}
.projects-note{margin-top:42px;font-size:.85rem;color:var(--muted);font-style:italic;text-align:center}

/* ===== PROCESS TIMELINE ===== */
.timeline{max-width:780px;margin:0 auto;position:relative}
.timeline:before{content:"";position:absolute;left:28px;top:14px;bottom:18px;width:1px;background:var(--line)}
.timeline-step{position:relative;padding:0 0 46px 84px}
.timeline-step:last-child{padding-bottom:0}
.timeline-num{position:absolute;left:0;top:0;width:57px;height:57px;border:1px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.28rem;color:var(--gold-deep);background:var(--cream);z-index:1}
.section-alt .timeline-num{background:var(--cream-2)}
.timeline-step h3{font-size:1.5rem;margin-bottom:9px;padding-top:13px}
.timeline-step p{color:var(--ink-soft);font-size:.98rem;max-width:62ch}

/* ===== mega menu footer link ===== */
.mega-foot{grid-column:1 / -1;border-top:1px solid var(--line);margin-top:6px;padding-top:14px}
.mega-foot a{font-size:.86rem;color:var(--gold-deep);border-bottom:0}
.mega-foot a:after{display:none !important}
.mega-foot a:hover{color:var(--ink)}

/* ===== FINISHES / SWATCHES ===== */
.finish-family{margin-bottom:56px}
.finish-family:last-child{margin-bottom:0}
.finish-family-head{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:26px;gap:18px;flex-wrap:wrap}
.finish-family-head h3{font-size:1.75rem}
.finish-family-head p{font-size:.9rem;color:var(--muted);max-width:48ch}
.swatch-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.swatch-chip{aspect-ratio:1/1;border-radius:4px;border:1px solid rgba(0,0,0,.09);position:relative;overflow:hidden;box-shadow:0 10px 22px -18px rgba(0,0,0,.55)}
.swatch.gloss .swatch-chip:after{content:"";position:absolute;inset:0;background:linear-gradient(118deg,rgba(255,255,255,.5),rgba(255,255,255,0) 44%)}
.swatch-name{font-size:.85rem;margin-top:11px;color:var(--ink)}
.swatch-sheen{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:2px}

/* ===== STAT BAND (about) ===== */
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:40px 0}
.stat-band .stat strong{font-family:var(--serif);font-size:2.4rem;font-weight:500;color:var(--ink);display:block;line-height:1}
.stat-band .stat span{font-size:.85rem;color:var(--muted);display:block;margin-top:8px;max-width:22ch}

/* ===== reveal animation ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-media img{height:420px}
  .pillars,.services,.projects-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .swatch-grid{grid-template-columns:repeat(4,1fr)}
  .stat-band{grid-template-columns:repeat(2,1fr);gap:26px}
  .segments-grid{grid-template-columns:1fr;gap:36px}
  .segments-media img:first-child{margin-top:0}
  .footer-inner{grid-template-columns:1fr;gap:34px}
  .cta-grid{grid-template-columns:1fr;gap:38px}
  .product-hero-grid{grid-template-columns:1fr;gap:34px}
  .product-hero-media img{height:400px}
  .product-cols{grid-template-columns:1fr;gap:34px}
  .related-grid{grid-template-columns:repeat(3,1fr)}
  .testimonials{grid-template-columns:1fr}
}
@media(max-width:720px){
  .nav{
    position:fixed;inset:78px 0 auto 0;background:var(--cream);flex-direction:column;align-items:flex-start;
    gap:0;padding:10px 0;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .35s;box-shadow:0 20px 40px -28px rgba(0,0,0,.5);
  }
  .nav.open{transform:translateY(0)}
  .nav a{width:100%;padding:14px 32px;font-size:.95rem}
  .nav a:not(.nav-cta):after{display:none}
  .nav-cta{border:0;border-top:1px solid var(--line);border-radius:0;margin-top:4px}
  .nav-cta:hover{background:transparent;color:var(--gold-deep)}
  .nav-toggle{display:block}
  /* mega menu -> accordion */
  .nav-item{display:block;width:100%}
  .nav-trigger{width:100%;padding:14px 32px;justify-content:space-between}
  .mega{
    position:static;transform:none;opacity:1;visibility:visible;pointer-events:none;
    box-shadow:none;border:0;border-radius:0;background:transparent;padding:0;
    display:none;grid-template-columns:1fr;gap:0;
  }
  .nav-item.open .mega{display:grid;pointer-events:auto;transform:none}
  .mega:before{display:none}
  .mega-label{padding:14px 32px 4px}
  .mega-col a{padding:9px 32px 9px 44px;border-bottom:0}
  .pillars,.services,.process-grid,.projects-grid{grid-template-columns:1fr}
  .segments-media{grid-template-columns:1fr}
  .swatch-grid{grid-template-columns:repeat(3,1fr)}
  .form-card .field-row{grid-template-columns:1fr}
  .form-card{padding:24px}
  .product-hero-media img{height:300px}
  .gallery{grid-template-columns:1fr;grid-template-rows:none;height:auto}
  .gallery img{height:240px}
  .gallery img:first-child{grid-row:auto;height:300px}
  .related-grid{grid-template-columns:1fr}
  .section{padding:64px 0}
  .wrap{padding:0 22px}
}
