/* ============================================================
   MGB CABINETRY — shared design system
   Premium dark + brushed-metal. Cabinetry & casework, Nevada.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,300..800;1,400&display=swap');

:root{
  /* Charcoal scale (sampled from the brand card: #2c2e35) */
  --ink-900:#191b20;
  --ink-850:#1e2026;
  --ink-800:#24262d;
  --ink-700:#2c2e35;   /* brand charcoal */
  --ink-600:#363943;
  --ink-500:#454953;

  /* Brushed metal */
  --silver-50:#f3f4f6;
  --silver-100:#e7e9ec;
  --silver-200:#cfd2d8;
  --silver-300:#b3b7bf;
  --silver-400:#9498a1;
  --silver-500:#777b84;

  /* Light "paper" sections */
  --paper:#f4f4f3;
  --paper-2:#ececeb;

  /* Text */
  --text:#f1f2f4;
  --text-dim:#a7abb3;
  --text-faint:#787c85;
  --ink-text:#24262d;
  --ink-text-dim:#5b5f68;

  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.16);
  --line-ink:rgba(36,38,45,.12);

  --maxw:1240px;
  --pad:clamp(20px,5vw,72px);

  --metal:linear-gradient(168deg,#fbfcfd 0%,#dfe2e6 22%,#b6bac1 46%,#8c9099 60%,#c3c7cd 80%,#e9ebee 100%);
  --metal-line:linear-gradient(90deg,transparent,var(--silver-400),transparent);

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:'Archivo',system-ui,sans-serif;
  background:var(--ink-800);
  color:var(--text);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  letter-spacing:-.005em;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{margin:0;line-height:1.04;font-weight:700;letter-spacing:-.02em;}
p{margin:0;}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);}
.section{padding-block:clamp(64px,9vw,128px);}
.section--tight{padding-block:clamp(48px,6vw,80px);}
.paper{background:var(--paper);color:var(--ink-text);}
.dark{background:var(--ink-800);color:var(--text);}
.darker{background:var(--ink-900);color:var(--text);}

/* ---------- type ---------- */
.eyebrow{
  font-size:13px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--silver-400);display:inline-flex;align-items:center;gap:.7em;margin:0;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--silver-400);display:inline-block;opacity:.7;}
.paper .eyebrow{color:var(--ink-text-dim);}
.paper .eyebrow::before{background:var(--ink-text-dim);}

.display{
  font-size:clamp(2.6rem,6.2vw,5.1rem);
  line-height:.98;font-weight:700;letter-spacing:-.03em;
}
.h2{font-size:clamp(1.9rem,3.6vw,3.05rem);letter-spacing:-.025em;}
.h3{font-size:clamp(1.25rem,1.9vw,1.6rem);letter-spacing:-.02em;}
.lead{font-size:clamp(1.06rem,1.5vw,1.28rem);line-height:1.55;color:var(--text-dim);font-weight:400;}
.paper .lead{color:var(--ink-text-dim);}
.metal-text{
  background:var(--metal);-webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
}
.measure{max-width:62ch;}
.measure-sm{max-width:46ch;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:15px 26px;border-radius:2px;border:1px solid transparent;
  cursor:pointer;transition:.25s var(--ease);white-space:nowrap;
}
.btn .arr{transition:transform .25s var(--ease);}
.btn:hover .arr{transform:translateX(4px);}
.btn--metal{background:var(--metal);color:var(--ink-900);box-shadow:0 1px 0 rgba(255,255,255,.4) inset;}
.btn--metal:hover{filter:brightness(1.06);transform:translateY(-1px);}
.btn--ghost{border-color:var(--line-2);color:var(--text);background:transparent;}
.btn--ghost:hover{border-color:var(--silver-300);background:rgba(255,255,255,.04);}
.paper .btn--ghost{border-color:var(--line-ink);color:var(--ink-text);}
.paper .btn--ghost:hover{border-color:var(--ink-500);background:rgba(0,0,0,.03);}
.btn--ink{background:var(--ink-800);color:var(--text);}
.btn--ink:hover{background:var(--ink-700);transform:translateY(-1px);}

/* ---------- header ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(25,27,32,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);}
.nav__in{display:flex;align-items:center;justify-content:space-between;gap:24px;height:78px;}
.brand{display:flex;align-items:center;gap:13px;}
.brand img{height:42px;width:auto;}
.brand__txt{display:flex;flex-direction:column;line-height:1;}
.brand__txt b{font-size:16px;font-weight:700;letter-spacing:.02em;}
.brand__txt span{font-size:10px;letter-spacing:.34em;color:var(--silver-400);text-transform:uppercase;margin-top:3px;}
.nav__links{display:flex;align-items:center;gap:34px;}
.nav__links a{font-size:14.5px;font-weight:500;color:var(--text-dim);transition:color .2s;position:relative;padding:6px 0;}
.nav__links a:hover,.nav__links a.active{color:var(--text);}
.nav__links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--metal);}
.nav__cta{display:flex;align-items:center;gap:18px;}
.nav__phone{font-size:14.5px;font-weight:600;color:var(--text);white-space:nowrap;}
.nav__phone span{color:var(--silver-400);font-weight:500;}
.burger{display:none;background:none;border:0;color:var(--text);cursor:pointer;padding:8px;}
.menu-extra{display:none;}
@media(max-width:920px){
  .nav__links,.nav__phone{display:none;}
  .burger{display:block;}
  .nav__links.open{display:flex;position:absolute;top:78px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--ink-850);border-bottom:1px solid var(--line);padding:8px var(--pad) 20px;}
  .nav__links.open a{padding:15px 0;border-bottom:1px solid var(--line);font-size:16px;}
  .nav__links.open .menu-extra{display:block;}
  .nav__links.open .menu-extra--phone{color:var(--silver-300);font-weight:600;}
  .nav__links.open .menu-extra--cta{display:block;width:100%;box-sizing:border-box;border-bottom:0;margin-top:14px;padding:15px 0;text-align:center;
    background:var(--metal);color:var(--ink-900);font-weight:700;border-radius:2px;letter-spacing:.01em;}
}
@media(max-width:560px){
  .hero__btns{flex-direction:column;align-items:stretch;}
  .hero__btns .btn{width:100%;justify-content:center;}
}
@media(max-width:600px){
  .nav__cta .btn--metal{display:none;}
  .brand img{height:38px;}
  .brand__txt b{font-size:15px;}
  .brand__txt span{font-size:9px;letter-spacing:.26em;}
}

/* ---------- placeholder imagery ---------- */
.ph{
  position:relative;overflow:hidden;background:var(--ink-700);
  background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.035) 0 2px,transparent 2px 11px);
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
}
.ph::after{
  content:attr(data-label);position:absolute;bottom:12px;left:12px;
  font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:11px;letter-spacing:.04em;
  color:var(--silver-400);background:rgba(0,0,0,.35);padding:4px 8px;border-radius:2px;
  text-transform:uppercase;
}
.ph__ic{width:38px;height:38px;opacity:.32;}
.paper .ph{background:var(--paper-2);border-color:var(--line-ink);
  background-image:repeating-linear-gradient(135deg,rgba(0,0,0,.03) 0 2px,transparent 2px 11px);}
.paper .ph::after{color:var(--ink-text-dim);background:rgba(255,255,255,.6);}

/* real photos in placeholder frames */
.ph--photo{background:var(--ink-850);background-image:none;}
.ph--photo::after{display:none;}
.ph--photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}

/* captioned work shots */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:230px;gap:14px;grid-auto-flow:dense;}
.shot{position:relative;overflow:hidden;border-radius:3px;border:1px solid var(--line);margin:0;
  background:var(--ink-850);}
.shot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s var(--ease);}
.shot:hover img{transform:scale(1.04);}
.shot figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:34px 16px 14px;display:flex;flex-direction:column;gap:3px;
  background:linear-gradient(to top,rgba(20,22,27,.94),rgba(20,22,27,.5) 58%,transparent);}
.shot figcaption b{font-size:13.5px;font-weight:700;letter-spacing:.01em;color:#fff;}
.shot figcaption span{font-size:11.5px;color:var(--silver-300);letter-spacing:.03em;}
.shot__seg{font-size:9.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;white-space:nowrap;
  color:var(--ink-900);background:var(--metal);padding:3px 8px;border-radius:2px;align-self:flex-start;margin-bottom:8px;}
.shot--wide{grid-column:span 2;}
.shot--tall{grid-row:span 2;}
@media(max-width:820px){.work-grid{grid-template-columns:1fr 1fr;grid-auto-rows:200px;}}
@media(max-width:520px){.work-grid{grid-template-columns:1fr;grid-auto-rows:220px;}.shot--wide{grid-column:auto;}.shot--tall{grid-row:auto;}}

/* ---------- footer ---------- */
.foot{background:var(--ink-900);border-top:1px solid var(--line);padding-block:clamp(48px,6vw,72px) 32px;}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;}
.foot__brand img{height:46px;margin-bottom:18px;}
.foot__brand p{color:var(--text-dim);font-size:15px;max-width:32ch;}
.foot h4{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--silver-400);margin-bottom:18px;font-weight:600;}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;}
.foot a{color:var(--text-dim);font-size:15px;transition:color .2s;}
.foot a:hover{color:var(--text);}
.foot__bar{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  margin-top:48px;padding-top:24px;border-top:1px solid var(--line);color:var(--text-faint);font-size:13px;}
.foot__lic{display:flex;gap:22px;flex-wrap:wrap;}
.foot__lic b{color:var(--text-dim);font-weight:600;}
@media(max-width:760px){.foot__top{grid-template-columns:1fr 1fr;gap:36px;}.foot__brand{grid-column:1/-1;}}

/* ---------- misc ---------- */
.hr{height:1px;background:var(--line);border:0;}
.chip{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;letter-spacing:.02em;
  color:var(--silver-300);border:1px solid var(--line-2);border-radius:999px;padding:7px 15px;}
.chip .dot{width:6px;height:6px;border-radius:50%;background:var(--silver-300);}

/* USA chip — red/white/blue metallic text */
.chip--usa{border-color:rgba(255,255,255,.22);}
.chip--usa .dot{background:linear-gradient(180deg,#e4344c,#fff 50%,#3b5fb0);}
.chip--usa{
  font-weight:700;letter-spacing:.01em;
  background-image:linear-gradient(112deg,
    #8f1a2a 0%, #c81e36 9%, #ef4257 16%, #ffd9de 23%,
    #b22234 31%, #ffffff 46%, #f2f5f9 52%, #9cc0ee 60%,
    #2f55a8 70%, #5f86d6 80%, #21306f 90%, #4a6cc4 100%);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* ============================================================
   PAGE COMPONENTS
   ============================================================ */

/* ---- hero ---- */
.hero{position:relative;overflow:hidden;padding-top:clamp(48px,7vw,96px);padding-bottom:clamp(56px,7vw,104px);
  background:radial-gradient(120% 90% at 78% 0%,var(--ink-700),var(--ink-800) 55%,var(--ink-900));}
.hero__star{position:absolute;top:-8%;right:-12%;width:min(720px,62vw);opacity:.05;pointer-events:none;filter:grayscale(1);}
.hero__star img{width:100%;}
.hero__in{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center;}
.hero__copy .eyebrow{margin-bottom:24px;}
.hero h1{margin-bottom:26px;}
.hero__btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px;}
.hero__chips{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px;}
.hero__media{aspect-ratio:4/5;border-radius:3px;}
@media(max-width:900px){
  .hero__in{grid-template-columns:1fr;}
  .hero__media{aspect-ratio:16/11;order:-1;}
}

/* ---- stat strip ---- */
.strip{padding-block:clamp(34px,4vw,52px);border-bottom:1px solid var(--line);}
.strip__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.stat{display:flex;flex-direction:column;gap:6px;align-items:center;text-align:center;}
.stat b{font-size:clamp(2rem,3.6vw,3rem);font-weight:700;letter-spacing:-.03em;line-height:1;}
.stat span{font-size:14px;color:var(--text-dim);letter-spacing:.01em;}
@media(max-width:680px){.strip__grid{grid-template-columns:1fr 1fr;gap:28px 24px;}}

/* ---- section head ---- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:clamp(40px,5vw,64px);}
.sec-head .eyebrow{margin-bottom:18px;}
@media(max-width:760px){.sec-head{flex-direction:column;align-items:flex-start;gap:22px;}}

/* ---- services grid ---- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-ink);border:1px solid var(--line-ink);}
.svc{background:var(--paper);padding:36px 34px 30px;display:flex;flex-direction:column;gap:12px;
  transition:background .25s var(--ease),transform .25s var(--ease);position:relative;min-height:230px;}
.svc:hover{background:#fff;}
.svc__no{font-family:ui-monospace,Menlo,monospace;font-size:13px;color:var(--silver-500);letter-spacing:.05em;}
.svc h3{margin-top:2px;}
.svc p{color:var(--ink-text-dim);font-size:15.5px;line-height:1.55;}
.svc__go{margin-top:auto;padding-top:14px;font-size:14px;font-weight:600;color:var(--ink-text);opacity:0;transform:translateY(6px);transition:.25s var(--ease);}
.svc:hover .svc__go{opacity:1;transform:none;}
@media(max-width:860px){.svc-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr;}.svc__go{opacity:1;transform:none;}}

/* ---- gallery grid ---- */
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:14px;}
.gal-grid .ph{border-radius:3px;}
.gal--tall{grid-row:span 2;}
.gal--wide{grid-column:span 2;}
@media(max-width:760px){.gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px;}.gal--wide{grid-column:span 2;}}

/* ---- credentials ---- */
.creds__in{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center;}
.creds__cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.cred{border:1px solid var(--line-2);border-radius:3px;padding:24px 22px;background:rgba(255,255,255,.02);
  display:flex;flex-direction:column;gap:7px;}
.cred__k{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--silver-400);font-weight:600;}
.cred__v{font-size:clamp(1.3rem,2.2vw,1.7rem);font-weight:700;letter-spacing:-.01em;}
.cred__d{font-size:13.5px;color:var(--text-dim);}
.creds__certs{grid-column:1/-1;margin-top:6px;padding-top:26px;border-top:1px solid var(--line);}
.creds__certs-k{display:block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--silver-400);font-weight:600;margin-bottom:18px;}
.cert-row{display:flex;flex-wrap:wrap;gap:16px 0;}
.cert{display:inline-flex;align-items:center;gap:12px;font-size:15px;font-weight:600;color:var(--text);
  padding:0 24px;border-left:1px solid var(--line-2);white-space:nowrap;}
.cert:first-child{padding-left:0;border-left:0;}
.cert::before{content:"";flex:none;width:8px;height:8px;background:var(--metal);transform:rotate(45deg);}
@media(max-width:560px){.cert{width:100%;padding:0;border-left:0;}}
@media(max-width:860px){.creds__in{grid-template-columns:1fr;}}
@media(max-width:420px){.creds__cards{grid-template-columns:1fr;}}

/* ---- CTA band ---- */
.cta{background:var(--metal);color:var(--ink-900);}
.cta__in{display:flex;justify-content:space-between;align-items:center;gap:40px;padding-block:clamp(48px,6vw,76px);}
.cta .eyebrow::before{background:rgba(25,27,32,.5);}
.cta__act{display:flex;flex-direction:column;align-items:flex-start;gap:20px;max-width:360px;}
@media(max-width:760px){.cta__in{flex-direction:column;align-items:flex-start;gap:28px;}}

/* ---- inner page header ---- */
.page-head{position:relative;overflow:hidden;padding-top:clamp(56px,8vw,104px);padding-bottom:clamp(48px,6vw,80px);
  background:radial-gradient(120% 120% at 85% -10%,var(--ink-700),var(--ink-800) 60%,var(--ink-900));}
.page-head__star{position:absolute;top:-30%;right:-8%;width:min(560px,52vw);opacity:.045;filter:grayscale(1);pointer-events:none;}
.page-head__star img{width:100%;}
.page-head .eyebrow{margin-bottom:22px;}
.page-head h1{font-size:clamp(2.4rem,5.4vw,4.2rem);line-height:1;letter-spacing:-.03em;margin-bottom:22px;}
.page-head .lead{max-width:60ch;}
.crumb{font-size:13px;color:var(--text-faint);letter-spacing:.04em;margin-bottom:30px;}
.crumb a:hover{color:var(--text-dim);}

/* ---- service detail rows ---- */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center;padding-block:clamp(44px,6vw,80px);border-top:1px solid var(--line);scroll-margin-top:96px;}
.svc-row:first-of-type{border-top:0;}
.svc-row__media{aspect-ratio:5/4;border-radius:3px;}
.svc-row:nth-child(even) .svc-row__media{order:2;}
.svc-row__no{font-family:ui-monospace,Menlo,monospace;font-size:14px;color:var(--silver-400);letter-spacing:.06em;margin-bottom:16px;display:block;}
.svc-row h2{font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:16px;}
.svc-row p{color:var(--text-dim);margin-bottom:24px;}
.svc-list{list-style:none;margin:0;padding:0;display:grid;gap:12px;}
.svc-list li{display:flex;gap:13px;align-items:flex-start;font-size:15.5px;color:var(--text);}
.svc-list li::before{content:"";flex:none;width:7px;height:7px;margin-top:8px;background:var(--metal);transform:rotate(45deg);}
@media(max-width:780px){.svc-row{grid-template-columns:1fr;gap:26px;}.svc-row:nth-child(even) .svc-row__media{order:0;}}

/* service metallic icons */
.svc-icon{display:flex;align-items:center;justify-content:center;
  background:radial-gradient(125% 125% at 30% 18%,var(--ink-700),var(--ink-850) 70%);
  border:1px solid var(--line);border-radius:3px;}
.svc-ico{width:42%;max-width:188px;height:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35));}

/* ---- process ---- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.step{background:var(--ink-800);padding:32px 26px;display:flex;flex-direction:column;gap:10px;min-height:180px;}
.step__no{font-family:ui-monospace,Menlo,monospace;font-size:13px;color:var(--silver-400);}
.step h3{font-size:1.2rem;}
.step p{font-size:14.5px;color:var(--text-dim);line-height:1.5;}
@media(max-width:820px){.process{grid-template-columns:1fr 1fr;}}
@media(max-width:460px){.process{grid-template-columns:1fr;}}

/* ---- gallery page ---- */
.gal-cat{margin-bottom:clamp(40px,5vw,64px);}
.gal-cat__head{display:flex;align-items:baseline;gap:16px;margin-bottom:22px;}
.gal-cat__head h2{font-size:clamp(1.4rem,2.4vw,1.9rem);}
.gal-cat__head span{font-size:13px;color:var(--text-faint);font-family:ui-monospace,Menlo,monospace;letter-spacing:.04em;}
.gal-3{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:240px;gap:14px;}
.gal-3 .ph{border-radius:3px;}
.gal-3 .span2{grid-column:span 2;}
@media(max-width:780px){.gal-3{grid-template-columns:1fr 1fr;grid-auto-rows:180px;}.gal-3 .span2{grid-column:span 2;}}

/* ============================================================
   DOOR STYLES & FINISHES GUIDE
   ============================================================ */
.guide{background:var(--ink-900);border-bottom:1px solid var(--line);}
.guide__head{max-width:64ch;margin-bottom:36px;}
.guide__head .eyebrow{margin-bottom:18px;}
.guide__head h2{font-size:clamp(1.9rem,3.4vw,2.7rem);letter-spacing:-.025em;margin-bottom:16px;}
.guide__head p{color:var(--text-dim);font-size:1.05rem;line-height:1.6;}

.guide__tabs{display:inline-flex;padding:4px;border:1px solid var(--line-2);border-radius:3px;background:var(--ink-850);margin-bottom:8px;}
.guide__tab{appearance:none;border:0;background:transparent;color:var(--text-dim);font:inherit;font-weight:600;font-size:14.5px;
  letter-spacing:.01em;padding:11px 22px;border-radius:2px;cursor:pointer;transition:.2s var(--ease);white-space:nowrap;}
.guide__tab[aria-selected="true"]{background:var(--metal);color:var(--ink-900);box-shadow:0 1px 0 rgba(255,255,255,.4) inset;}
.guide__tab:not([aria-selected="true"]):hover{color:var(--text);}

.guide__panel{display:none;padding-top:36px;}
.guide__panel.active{display:block;}
.guide__sub{display:flex;align-items:center;gap:14px;margin-bottom:34px;color:var(--text-dim);font-size:14.5px;}
.guide__sub::before{content:"";width:34px;height:1px;background:var(--silver-400);flex:none;}

.matgroup{padding-block:34px;border-top:1px solid var(--line);}
.matgroup:first-of-type{border-top:0;padding-top:0;}
.matgroup__title{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:22px;}
.matgroup__title h3{font-size:1.12rem;letter-spacing:.02em;text-transform:uppercase;font-weight:700;}
.matgroup__title .count{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--silver-400);letter-spacing:.04em;}

.style-chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px;}

/* door illustration cards */
.door-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:20px 16px;margin-bottom:30px;}
.door-card{display:flex;flex-direction:column;gap:11px;}
.door-art{aspect-ratio:100/152;border:1px solid var(--line);border-radius:3px;
  background:linear-gradient(162deg,var(--ink-700),var(--ink-850));
  color:var(--silver-300);padding:14px 16px;display:flex;align-items:center;justify-content:center;
  transition:border-color .25s var(--ease),color .25s var(--ease);}
.door-card:hover .door-art{border-color:var(--silver-500);color:var(--silver-100);}
.door-card:hover .door-img{filter:brightness(1.12);}
.door-svg{width:100%;height:100%;display:block;}
.door-img{width:100%;height:100%;object-fit:contain;display:block;transition:filter .25s var(--ease);}
.door-name{font-size:13px;font-weight:600;color:var(--text);letter-spacing:.01em;display:flex;align-items:center;gap:7px;flex-wrap:wrap;}
.door-name .new{font-size:8.5px;font-weight:700;letter-spacing:.12em;color:var(--ink-900);background:var(--metal);padding:2px 6px;border-radius:2px;}
.matgroup__sub{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--silver-400);font-weight:600;margin:0 0 16px;}
@media(max-width:520px){.door-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:16px 12px;}}
.style-chip{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line-2);border-radius:3px;
  padding:9px 15px 9px 11px;font-size:14px;font-weight:600;color:var(--text);background:rgba(255,255,255,.02);}
.style-chip svg{flex:none;width:16px;height:20px;color:var(--silver-400);}
.style-chip .new{font-size:9px;font-weight:700;letter-spacing:.12em;color:var(--ink-900);background:var(--metal);
  padding:2px 6px;border-radius:2px;margin-left:2px;}

.swatch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:16px 14px;}
.swatch{display:flex;flex-direction:column;gap:9px;}
.swatch__chip{aspect-ratio:1/1;border-radius:3px;border:1px solid rgba(255,255,255,.14);
  box-shadow:0 1px 3px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.07);position:relative;overflow:hidden;}
.swatch__chip::before{content:"";position:absolute;inset:0;
  background:linear-gradient(150deg,rgba(255,255,255,.10),transparent 38%,transparent 62%,rgba(0,0,0,.14));}
.swatch__chip[data-grain]::after{content:"";position:absolute;inset:0;opacity:.55;
  background:
    repeating-linear-gradient(91deg,rgba(0,0,0,.16) 0 .5px,transparent .5px 2.5px),
    repeating-linear-gradient(90deg,rgba(255,255,255,.07) 0 1px,transparent 1px 3.5px,rgba(0,0,0,.09) 3.5px 4px,transparent 4px 8px);
  mix-blend-mode:overlay;}
.swatch__chip[data-grain]{background-blend-mode:multiply;}
.swatch__name{font-size:12.5px;color:var(--text-dim);letter-spacing:.01em;line-height:1.25;}
.swatch__name .new{display:inline-block;font-size:8.5px;font-weight:700;letter-spacing:.1em;color:var(--silver-300);
  border:1px solid var(--line-2);padding:1px 5px;border-radius:2px;margin-left:5px;vertical-align:middle;}
.matgroup__note{margin-top:18px;font-size:13px;color:var(--text-faint);font-style:italic;}

.guide__extras{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(30px,4vw,56px);margin-top:44px;padding-top:40px;border-top:1px solid var(--line);}
.upgrades--full{margin-top:44px;padding-top:40px;border-top:1px solid var(--line);}
.upgrades h4,.certs h4{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--silver-400);font-weight:600;margin-bottom:20px;}
.upgrades ul{list-style:none;margin:0;padding:0;columns:2;column-gap:30px;}
.upgrades li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:var(--text);margin-bottom:13px;break-inside:avoid;}
.upgrades li::before{content:"";flex:none;width:7px;height:7px;margin-top:7px;background:var(--metal);transform:rotate(45deg);}
.certs__list{display:flex;flex-direction:column;gap:22px;}
.cert-item .cert-item__k{font-size:15px;font-weight:700;letter-spacing:.01em;margin-bottom:5px;}
.cert-item p{font-size:13.5px;color:var(--text-dim);line-height:1.5;}
.guide__disclaimer{margin-top:34px;font-size:12.5px;color:var(--text-faint);line-height:1.55;max-width:90ch;}
@media(max-width:820px){.guide__extras{grid-template-columns:1fr;}}
@media(max-width:520px){.upgrades ul{columns:1;}.swatch-grid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr));}}

/* ---- about ---- */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(36px,5vw,72px);align-items:start;}
.about-grid .ph{aspect-ratio:4/5;border-radius:3px;position:sticky;top:104px;}
.about-body p{color:var(--text-dim);margin-bottom:20px;font-size:1.06rem;line-height:1.65;}
.about-body p.lead{color:var(--text);}
.values{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-ink);border:1px solid var(--line-ink);}
.value{background:var(--paper);padding:30px 28px;}
.value h3{font-size:1.2rem;margin-bottom:9px;}
.value p{color:var(--ink-text-dim);font-size:15px;line-height:1.55;}
@media(max-width:820px){.about-grid{grid-template-columns:1fr;}.about-grid .ph{position:relative;top:0;aspect-ratio:16/10;}.values{grid-template-columns:1fr;}}

/* ---- partners / team ---- */
.about-lede{max-width:64ch;}
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,34px);}
.member__photo{aspect-ratio:4/5;border-radius:3px;margin-bottom:20px;}
.member__photo--filled{overflow:hidden;border:1px solid var(--line);}
.member__photo--filled img{width:100%;height:100%;object-fit:cover;object-position:center 28%;display:block;}
.member h3{font-size:1.3rem;letter-spacing:-.01em;margin-bottom:5px;}
.member .role{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--silver-400);font-weight:600;margin-bottom:12px;}
.member p{color:var(--text-dim);font-size:14.5px;line-height:1.55;}
@media(max-width:760px){.team{grid-template-columns:1fr;max-width:420px;}}

/* about full-bleed image band */
.about-band{padding:0;}
.about-band__media{margin:0;height:clamp(280px,42vw,520px);overflow:hidden;border-block:1px solid var(--line);}
.about-band__media img{width:100%;height:100%;object-fit:cover;display:block;}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,5vw,64px);align-items:start;}
.cinfo{display:flex;flex-direction:column;gap:28px;}
.cinfo__item .k{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--silver-400);font-weight:600;margin-bottom:8px;}
.cinfo__item .v{font-size:1.15rem;font-weight:600;}
.cinfo__item .v a:hover{color:var(--silver-200);}
.cinfo__item .sub{color:var(--text-dim);font-size:14.5px;margin-top:4px;}
.cform{background:var(--ink-850);border:1px solid var(--line);border-radius:4px;padding:clamp(24px,3vw,40px);}
.field{margin-bottom:18px;}
.field label{display:block;font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--text-dim);margin-bottom:8px;}
.field input,.field select,.field textarea{width:100%;background:var(--ink-900);border:1px solid var(--line-2);border-radius:3px;
  color:var(--text);font:inherit;font-size:15px;padding:13px 15px;transition:border-color .2s,box-shadow .2s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--silver-400);box-shadow:0 0 0 3px rgba(180,184,191,.12);}
.field textarea{resize:vertical;min-height:120px;}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.cform__note{font-size:13px;color:var(--text-faint);margin-top:6px;}
.form-msg{display:none;background:rgba(180,184,191,.1);border:1px solid var(--line-2);border-radius:3px;padding:16px 18px;color:var(--text);font-size:15px;margin-bottom:18px;}
.form-msg.show{display:block;}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;}.field--row{grid-template-columns:1fr;}}
