/* ============================================================
   THE JOINERY — Custom Cabinetmakers
   Shared design system. Premium, warm, readable.
   Native scroll only. No scroll libraries.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* palette */
  --espresso:#241a13;
  --espresso-2:#2e2118;
  --walnut:#3b2a1d;
  --bark:#5a4632;
  --honey:#c79a5c;
  --brass:#b8893b;
  --brass-deep:#7d5a20;
  --cream:#f6f1e7;
  --parchment:#efe7d8;
  --ink:#241a13;
  --bone:#ece2d2;
  --bone-muted:#cbbca4;
  --muted:#6b5d4c;
  --line:rgba(58,42,29,.14);
  --line-strong:rgba(58,42,29,.28);
  --line-dark:rgba(236,226,210,.16);

  /* type */
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --fs-hero:clamp(2.5rem,1.5rem + 3.4vw,4.2rem);
  --fs-h2:clamp(1.95rem,1.2rem + 2.5vw,3.1rem);
  --fs-h3:clamp(1.28rem,1.05rem + .8vw,1.65rem);
  --fs-lead:clamp(1.08rem,1rem + .45vw,1.32rem);
  --fs-body:1.0625rem;
  --fs-small:.92rem;
  --fs-eyebrow:.8rem;

  /* layout */
  --maxw:1200px;
  --maxw-narrow:820px;
  --gutter:clamp(1.15rem,4vw,2.6rem);
  --section-y:clamp(3.75rem,3rem + 5vw,7.5rem);
  --header-h:74px;

  /* form */
  --radius:13px;
  --radius-sm:8px;
  --radius-lg:22px;
  --radius-pill:50px;
  --shadow-sm:0 1px 2px rgba(36,26,19,.06),0 6px 18px rgba(36,26,19,.07);
  --shadow-md:0 10px 34px rgba(36,26,19,.13);
  --shadow-lg:0 28px 64px rgba(36,26,19,.24);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:1.7;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,picture,svg,video{max-width:100%;display:block;height:auto}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.08;margin:0;color:var(--ink);letter-spacing:-.01em}
p{margin:0 0 1rem}
a{color:var(--brass-deep);text-decoration:none;transition:color .25s var(--ease)}
a:hover{color:var(--brass);text-decoration:underline}
ul{margin:0;padding:0}
button{font-family:inherit}
strong{font-weight:600}
:focus-visible{outline:3px solid var(--brass);outline-offset:3px;border-radius:3px}
::selection{background:var(--brass);color:#fff}

.skip-link{position:absolute;left:50%;top:-60px;transform:translateX(-50%);background:var(--brass);color:#241a13;
  padding:.7em 1.2em;border-radius:0 0 8px 8px;font-weight:600;z-index:300;transition:top .2s}
.skip-link:focus{top:0;color:#241a13}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.container-narrow{max-width:var(--maxw-narrow)}
.section{padding-block:var(--section-y)}
.section--cream{background:var(--cream)}
.section--parchment{background:var(--parchment)}
.section--dark{background:var(--espresso);color:var(--bone);
  background-image:radial-gradient(120% 80% at 80% 0%,rgba(184,137,59,.10),transparent 60%),
                   linear-gradient(180deg,#241a13,#1d140d);}
.section--walnut{background:var(--walnut);color:var(--bone)}
.section--dark h1,.section--dark h2,.section--dark h3,
.section--walnut h1,.section--walnut h2,.section--walnut h3{color:#fbf6ec}
.section--tight{padding-block:clamp(2.5rem,2rem + 3vw,4rem)}

/* ---------- Typography helpers ---------- */
.eyebrow{font-family:var(--font-body);font-weight:600;font-size:var(--fs-eyebrow);letter-spacing:.2em;
  text-transform:uppercase;color:var(--brass-deep);display:inline-flex;align-items:center;gap:.7em;margin-bottom:1.15rem}
.eyebrow::before{content:"";width:30px;height:1.5px;background:var(--brass);display:inline-block}
.section--dark .eyebrow,.section--walnut .eyebrow{color:var(--honey)}
.eyebrow.center{justify-content:center}

.section-head{margin-bottom:clamp(2rem,1.4rem + 2vw,3.4rem)}
.section-head.center{text-align:center;max-width:760px;margin-inline:auto}
.section-title{font-size:var(--fs-h2)}
.section-intro{font-size:var(--fs-lead);color:var(--muted);margin-top:1.1rem;line-height:1.65}
.section--dark .section-intro,.section--walnut .section-intro{color:var(--bone-muted)}
.lead{font-size:var(--fs-lead);line-height:1.65}
.text-muted{color:var(--muted)}
.section--dark .text-muted{color:var(--bone-muted)}
.display-script{font-style:italic;color:var(--brass-deep)}
.section--dark .display-script{color:var(--honey)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--font-body);font-weight:600;font-size:1rem;line-height:1;letter-spacing:.01em;
  padding:1.02em 1.65em;border-radius:var(--radius-sm);border:1.6px solid transparent;cursor:pointer;
  text-decoration:none;white-space:nowrap;
  transition:transform .28s var(--ease),background .28s var(--ease),box-shadow .28s var(--ease),border-color .28s var(--ease),color .28s var(--ease)}
.btn svg{width:1.05em;height:1.05em;flex:none}
.btn-primary{background:var(--brass);color:#26190c;box-shadow:0 8px 22px rgba(156,111,43,.32)}
.btn-primary:hover{background:var(--honey);color:#26190c;transform:translateY(-2px);box-shadow:0 12px 28px rgba(156,111,43,.4)}
.btn-secondary{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-secondary:hover{border-color:var(--brass);color:var(--brass-deep);transform:translateY(-2px)}
.section--dark .btn-secondary,.section--walnut .btn-secondary,.hero--home .btn-secondary{color:var(--bone);border-color:rgba(236,226,210,.34)}
.section--dark .btn-secondary:hover,.section--walnut .btn-secondary:hover,.hero--home .btn-secondary:hover{border-color:var(--honey);color:#fff}
.btn-lg{padding:1.15em 2em;font-size:1.05rem}
.btn-block{width:100%}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(36,26,19,.96);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid rgba(236,226,210,.10);
  transition:box-shadow .35s var(--ease),background .35s var(--ease)}
.site-header.scrolled{box-shadow:0 10px 30px rgba(20,14,9,.35);background:rgba(31,22,15,.99)}
.header-inner{display:flex;align-items:center;gap:1.5rem;min-height:var(--header-h);
  max-width:1280px;margin-inline:auto;padding-inline:var(--gutter)}
.brand{display:inline-flex;align-items:center;flex:none;line-height:0}
.brand-logo{height:46px;width:auto}
.primary-nav{margin-left:auto}
.primary-nav ul{display:flex;align-items:center;gap:clamp(1rem,2vw,2.1rem);list-style:none}
.primary-nav a{font-family:var(--font-body);font-weight:500;font-size:.97rem;color:var(--bone);
  letter-spacing:.01em;padding:.5em 0;position:relative}
.primary-nav a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1.5px;
  background:var(--honey);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.primary-nav a:hover{color:#fff}
.primary-nav a:hover::after,.primary-nav a[aria-current="page"]::after{transform:scaleX(1)}
.primary-nav a[aria-current="page"]{color:#fff}
.header-cta{flex:none}
.btn-call{background:transparent;color:var(--bone);border:1.6px solid rgba(236,226,210,.32);
  padding:.72em 1.15em;border-radius:var(--radius-pill);font-size:.96rem;font-weight:600}
.btn-call svg{color:var(--honey)}
.btn-call:hover{border-color:var(--honey);background:rgba(199,154,92,.12);color:#fff;transform:translateY(-1px)}
.btn-call .label-num{font-variant-numeric:tabular-nums}

/* hamburger */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;
  border:1px solid rgba(236,226,210,.28);border-radius:10px;background:transparent;cursor:pointer;flex:none}
.nav-toggle-bar{display:block;width:22px;height:2px;background:var(--bone);margin-inline:auto;
  transition:transform .3s var(--ease),opacity .2s var(--ease)}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav-backdrop{position:fixed;inset:0;background:rgba(20,14,9,.55);opacity:0;visibility:hidden;
  transition:opacity .3s var(--ease);z-index:98}
.nav-backdrop.open{opacity:1;visibility:visible}

/* ---------- Hero (home, with 3D) ---------- */
.hero--home{position:relative;background:#1e150e;color:var(--bone);overflow:hidden;isolation:isolate;
  min-height:calc(100svh - var(--header-h));display:flex;align-items:center}
.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(102deg,rgba(18,12,8,.95) 0%,rgba(18,12,8,.82) 26%,rgba(18,12,8,.5) 50%,rgba(18,12,8,.2) 72%,rgba(20,14,9,.45) 100%),
    radial-gradient(74% 60% at 80% 16%,rgba(199,154,92,.20),transparent 62%),
    linear-gradient(0deg,rgba(18,12,8,.55),transparent 36%)}
.hero--home .hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:2;display:block;pointer-events:none}
.hero--home .container{position:relative;z-index:3;width:100%}
.hero-copy{max-width:40rem;padding-block:clamp(3rem,8vh,6rem)}
.hero-badge{display:inline-flex;align-items:center;gap:.6em;font-size:.82rem;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--honey);border:1px solid rgba(199,154,92,.4);
  padding:.5em 1em;border-radius:var(--radius-pill);margin-bottom:1.6rem;background:rgba(199,154,92,.07)}
.hero--home h1{font-size:var(--fs-hero);color:#fbf6ec;font-weight:500;letter-spacing:-.015em}
.hero--home h1 em{font-style:italic;color:var(--honey)}
.hero-sub{font-size:var(--fs-lead);color:var(--bone-muted);margin-top:1.4rem;max-width:34rem;line-height:1.6}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.1rem}
.hero-trust{margin-top:2.4rem;display:flex;flex-wrap:wrap;gap:.5rem 1.6rem;font-size:.9rem;color:var(--bone-muted)}
.hero-trust span{display:inline-flex;align-items:center;gap:.5em}
.hero-trust svg{width:1.05em;height:1.05em;color:var(--honey);flex:none}
/* hero photo is the background now — if WebGL fails we just hide the canvas, no poster needed */
.scroll-cue{position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);z-index:2;color:var(--bone-muted);
  display:flex;flex-direction:column;align-items:center;gap:.4em;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase}
.scroll-cue svg{width:20px;height:20px;animation:bob 2s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* ---------- Inner page hero ---------- */
.hero--page{position:relative;background:linear-gradient(165deg,#2c2017,#1d140d);color:var(--bone);
  padding-top:clamp(3.5rem,4vw,5.5rem);padding-bottom:clamp(3.5rem,4vw,5.5rem);overflow:hidden}
.hero--page::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(80% 120% at 100% 0%,rgba(199,154,92,.13),transparent 55%)}
.hero--page .container{position:relative;z-index:1}
.hero--page h1{font-size:clamp(2.3rem,1.5rem + 3vw,3.9rem);color:#fbf6ec;max-width:18ch}
.hero--page .hero-sub{color:var(--bone-muted);max-width:46ch}
.breadcrumb{font-size:.84rem;color:var(--bone-muted);margin-bottom:1.2rem;letter-spacing:.02em}
.breadcrumb a{color:var(--bone-muted)}.breadcrumb a:hover{color:var(--honey)}
.breadcrumb span{margin-inline:.5em;opacity:.5}

/* ---------- Trust bar ---------- */
.trust-bar{background:var(--espresso);color:var(--bone);border-block:1px solid rgba(236,226,210,.10)}
.trust-bar .container{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:1rem clamp(1.5rem,4vw,3.5rem);padding-block:1.5rem}
.trust-item{display:flex;align-items:center;gap:.7em;font-size:.95rem;color:var(--bone-muted)}
.trust-item strong{color:#fbf6ec;font-weight:600}
.trust-item svg{width:1.4em;height:1.4em;color:var(--honey);flex:none}
.trust-sep{width:1px;height:26px;background:rgba(236,226,210,.18)}
@media (max-width:640px){.trust-sep{display:none}}

/* ---------- Generic grids ---------- */
.grid{display:grid;gap:clamp(1.1rem,2vw,1.8rem)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split.reverse>.split-media{order:2}

/* ---------- Cards (services / values) ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,1rem + 1.4vw,2.2rem);
  box-shadow:var(--shadow-sm);transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);height:100%}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(184,137,59,.45)}
.card-icon{width:54px;height:54px;border-radius:12px;display:grid;place-items:center;margin-bottom:1.25rem;
  background:linear-gradient(140deg,var(--parchment),#e3d6bf);color:var(--brass-deep);border:1px solid var(--line)}
.card-icon svg{width:26px;height:26px}
.card h3{font-size:var(--fs-h3);margin-bottom:.6rem}
.card p{color:var(--muted);margin-bottom:0;font-size:1rem}
.card-link{display:inline-flex;align-items:center;gap:.4em;margin-top:1.1rem;font-weight:600;font-size:.95rem;color:var(--brass-deep)}
.card-link svg{width:1em;height:1em;transition:transform .3s var(--ease)}
.card:hover .card-link svg{transform:translateX(4px)}
.section--dark .card{background:rgba(255,255,255,.04);border-color:rgba(236,226,210,.14)}
.section--dark .card h3{color:#fbf6ec}
.section--dark .card p{color:var(--bone-muted)}
.section--dark .card-icon{background:rgba(199,154,92,.14);border-color:rgba(199,154,92,.3);color:var(--honey)}

/* ---------- Work cards / featured gallery ---------- */
.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(.8rem,1.4vw,1.3rem)}
.work-card{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--walnut);
  box-shadow:var(--shadow-sm);text-decoration:none;display:block;aspect-ratio:4/3}
.work-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.work-card:hover img,.work-card:focus-visible img{transform:scale(1.07)}
.work-card figcaption{position:absolute;inset:auto 0 0 0;padding:1.4rem 1.3rem 1.15rem;
  background:linear-gradient(to top,rgba(20,14,9,.86),rgba(20,14,9,.35) 55%,transparent);
  color:#fff;display:flex;flex-direction:column;gap:.15rem;transform:translateY(0)}
.work-card .wc-cat{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--honey);font-weight:600}
.work-card .wc-title{font-family:var(--font-display);font-size:1.12rem;line-height:1.25}
.work-card.tall{aspect-ratio:3/4}
.work-card.wide{aspect-ratio:16/10}
/* spans for featured collage on desktop */
.span-6{grid-column:span 6}.span-4{grid-column:span 4}.span-3{grid-column:span 3}.span-8{grid-column:span 8}.span-12{grid-column:span 12}

/* ---------- Portfolio masonry ---------- */
.gallery-filters{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:clamp(1.8rem,3vw,2.8rem)}
.filter-btn{font-family:var(--font-body);font-weight:600;font-size:.9rem;color:var(--muted);background:transparent;
  border:1.5px solid var(--line-strong);border-radius:var(--radius-pill);padding:.6em 1.2em;cursor:pointer;
  transition:all .25s var(--ease)}
.filter-btn:hover{border-color:var(--brass);color:var(--brass-deep)}
.filter-btn.active{background:var(--espresso);color:var(--bone);border-color:var(--espresso)}
.masonry{column-count:3;column-gap:clamp(.8rem,1.4vw,1.3rem)}
.masonry .tile{break-inside:avoid;margin-bottom:clamp(.8rem,1.4vw,1.3rem);position:relative;overflow:hidden;
  border-radius:var(--radius);background:var(--walnut);cursor:pointer;display:block;width:100%;border:0;padding:0;text-align:left}
.masonry .tile img{width:100%;height:auto;transition:transform .7s var(--ease),filter .4s}
.masonry .tile:hover img,.masonry .tile:focus-visible img{transform:scale(1.05)}
.masonry .tile figcaption{position:absolute;inset:auto 0 0 0;padding:1.3rem 1.1rem 1rem;opacity:0;transition:opacity .35s var(--ease);
  background:linear-gradient(to top,rgba(20,14,9,.85),transparent);color:#fff;pointer-events:none}
.masonry .tile:hover figcaption,.masonry .tile:focus-visible figcaption{opacity:1}
.masonry .tile .t-cat{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--honey);font-weight:600}
.masonry .tile .t-title{font-family:var(--font-display);font-size:1.05rem;display:block;margin-top:.1rem}
.tile.is-hidden{display:none}
.tile-zoom{position:absolute;top:.7rem;right:.7rem;width:34px;height:34px;border-radius:50%;background:rgba(20,14,9,.5);
  display:grid;place-items:center;opacity:0;transform:scale(.8);transition:all .3s var(--ease)}
.tile:hover .tile-zoom,.tile:focus-visible .tile-zoom{opacity:1;transform:scale(1)}
.tile-zoom svg{width:16px;height:16px;color:#fff}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  background:rgba(18,12,8,.94);opacity:0;visibility:hidden;transition:opacity .3s var(--ease)}
.lightbox.open{opacity:1;visibility:visible}
.lightbox-figure{margin:0;max-width:92vw;max-height:88vh;display:flex;flex-direction:column;align-items:center;gap:.9rem}
.lightbox img{max-width:92vw;max-height:80vh;width:auto;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox figcaption{color:var(--bone);font-size:.95rem;text-align:center;max-width:60ch}
.lightbox figcaption b{color:var(--honey);font-weight:600;display:block;font-family:var(--font-display);font-size:1.05rem;margin-bottom:.15rem}
.lb-btn{position:absolute;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);color:#fff;
  width:50px;height:50px;border-radius:50%;display:grid;place-items:center;cursor:pointer;transition:all .25s var(--ease)}
.lb-btn:hover{background:rgba(199,154,92,.3);border-color:var(--honey)}
.lb-btn svg{width:22px;height:22px}
.lb-close{top:1.3rem;right:1.3rem}
.lb-prev{left:1.3rem;top:50%;transform:translateY(-50%)}
.lb-next{right:1.3rem;top:50%;transform:translateY(-50%)}
@media (max-width:640px){.lb-prev{left:.6rem}.lb-next{right:.6rem}.lb-btn{width:44px;height:44px}}

/* ---------- Process steps ---------- */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.2rem,2.5vw,2.2rem);counter-reset:step}
.process-step{position:relative}
.process-step .step-num{font-family:var(--font-display);font-size:2.4rem;color:var(--honey);line-height:1;
  display:block;margin-bottom:.7rem;font-weight:500}
.process-step h3{font-size:1.2rem;margin-bottom:.5rem;color:#fbf6ec}
.process-step p{color:var(--bone-muted);font-size:.97rem;margin:0}
.process-step::after{content:"";position:absolute;top:1.1rem;right:-1.1rem;width:2.2rem;height:1px;
  background:rgba(199,154,92,.4)}
.process-step:last-child::after{display:none}

/* ---------- Stats ---------- */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.stat .stat-num{font-family:var(--font-display);font-size:clamp(2.2rem,1.5rem + 2vw,3.2rem);color:var(--brass-deep);
  line-height:1;font-weight:500}
.section--dark .stat .stat-num{color:var(--honey)}
.stat .stat-label{font-size:.92rem;color:var(--muted);margin-top:.5rem;letter-spacing:.02em}
.section--dark .stat .stat-label{color:var(--bone-muted)}

/* ---------- Testimonials ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.2rem,2.5vw,2rem)}
.testi{background:rgba(255,255,255,.04);border:1px solid rgba(236,226,210,.14);border-radius:var(--radius);
  padding:clamp(1.6rem,1rem + 1.6vw,2.4rem);position:relative}
.section--cream .testi,.section--parchment .testi{background:#fff;border-color:var(--line)}
.testi .quote-mark{font-family:var(--font-display);font-size:3.6rem;line-height:.6;color:var(--brass);opacity:.55;
  display:block;height:.6em}
.testi blockquote{margin:0;font-size:1.08rem;line-height:1.65;color:var(--bone);font-family:var(--font-display);
  font-style:italic;font-weight:400}
.section--cream .testi blockquote,.section--parchment .testi blockquote{color:#33271c}
.testi .cite{margin-top:1.2rem;font-style:normal;font-family:var(--font-body);font-weight:600;color:var(--honey);font-size:.97rem}
.section--cream .testi .cite,.section--parchment .testi .cite{color:var(--brass-deep)}
.testi .cite span{display:block;font-weight:400;color:var(--bone-muted);font-size:.86rem;margin-top:.15rem}
.section--cream .testi .cite span,.section--parchment .testi .cite span{color:var(--muted)}

/* ---------- Media + figure ---------- */
.media-framed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);position:relative}
.media-framed img{width:100%;height:100%;object-fit:cover}
.media-tag{position:absolute;left:1rem;bottom:1rem;background:rgba(36,26,19,.82);color:var(--bone);
  font-size:.8rem;padding:.45em .9em;border-radius:var(--radius-pill);backdrop-filter:blur(4px)}
.media-stack{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.media-stack .tall{grid-row:span 2}

.checklist{list-style:none;display:grid;gap:.85rem;margin:1.5rem 0 0}
.checklist li{display:flex;gap:.8em;align-items:flex-start;line-height:1.55}
.checklist svg{width:1.35em;height:1.35em;color:var(--brass);flex:none;margin-top:.12em}
.section--dark .checklist svg{color:var(--honey)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(150deg,#2d2118,#1c130c);color:var(--bone);
  text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 80% at 50% -10%,rgba(199,154,92,.18),transparent 60%)}
.cta-band .container{position:relative;z-index:1}
.cta-band h2{font-size:var(--fs-h2);color:#fbf6ec;max-width:20ch;margin-inline:auto}
.cta-band p{color:var(--bone-muted);font-size:var(--fs-lead);max-width:50ch;margin:1.1rem auto 0}
.cta-actions{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;margin-top:2.1rem}
.cta-phone{margin-top:1.5rem;font-size:.95rem;color:var(--bone-muted)}
.cta-phone a{color:var(--honey);font-weight:600;font-family:var(--font-display);font-size:1.2rem}

/* ---------- Forms ---------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(1.6rem,1rem + 2vw,2.8rem);box-shadow:var(--shadow-md)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.1rem}
.form-field{display:flex;flex-direction:column;gap:.4rem}
.form-field.full{grid-column:1/-1}
.form-field label{font-size:.88rem;font-weight:600;color:var(--ink);letter-spacing:.01em}
.form-field label .req{color:var(--brass-deep)}
.form-field input,.form-field select,.form-field textarea{
  font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--cream);
  border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);padding:.85em .95em;width:100%;
  transition:border-color .25s var(--ease),box-shadow .25s var(--ease)}
.form-field textarea{resize:vertical;min-height:130px}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(184,137,59,.16)}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--muted)}
.form-note{font-size:.84rem;color:var(--muted);margin-top:1rem;line-height:1.5}
.form-status{margin-top:1rem;padding:.9em 1.1em;border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;display:none}
.form-status.show{display:block}
.form-status.ok{background:#e8f0e4;color:#2f5026;border:1px solid #bcd4b0}
.form-status.err{background:#f6e4df;color:#7a2f22;border:1px solid #e0b6ac}
.honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ---------- Contact info blocks ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.info-list{display:grid;gap:1.5rem;margin-top:1.5rem}
.info-item{display:flex;gap:1rem;align-items:flex-start}
.info-item .info-ic{width:46px;height:46px;border-radius:12px;flex:none;display:grid;place-items:center;
  background:rgba(199,154,92,.14);border:1px solid rgba(199,154,92,.3);color:var(--honey)}
.info-item .info-ic svg{width:22px;height:22px}
.info-item h3{font-size:1.05rem;margin-bottom:.2rem;color:#fbf6ec}
.info-item a,.info-item p{color:var(--bone-muted);margin:0}
.info-item a:hover{color:var(--honey)}
.map-frame{border-radius:var(--radius);overflow:hidden;border:1px solid rgba(236,226,210,.16);margin-top:1.8rem}
.map-frame iframe{display:block;width:100%;height:260px;border:0;filter:saturate(.9) brightness(.95)}

/* ---------- Footer ---------- */
.site-footer{background:#1c130c;color:var(--bone-muted);padding-top:clamp(3rem,4vw,4.5rem)}
.footer-inner{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.5rem;
  max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);padding-bottom:2.8rem}
.footer-brand .brand-logo{height:50px;margin-bottom:1.1rem}
.footer-brand p{font-size:.95rem;line-height:1.6;max-width:32ch}
.footer-social{display:flex;gap:.7rem;margin-top:1.2rem}
.footer-social a{width:44px;height:44px;border-radius:10px;border:1px solid rgba(236,226,210,.18);
  display:grid;place-items:center;color:var(--bone-muted)}
.footer-social a:hover{color:var(--honey);border-color:var(--honey);background:rgba(199,154,92,.1)}
.footer-social svg{width:19px;height:19px}
.footer-col h4{font-family:var(--font-body);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--honey);margin-bottom:1.1rem;font-weight:600}
.footer-col ul{list-style:none;display:grid;gap:.7rem}
.footer-col a{color:var(--bone-muted);font-size:.95rem}
.footer-col a:hover{color:#fff}
.footer-col p{font-size:.95rem;margin:0 0 .5rem;line-height:1.5}
.footer-bottom{border-top:1px solid rgba(236,226,210,.12);padding-block:1.5rem;
  max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:.8rem;font-size:.85rem;color:#8a7c68}
.footer-bottom a{color:#8a7c68}.footer-bottom a:hover{color:var(--honey)}

/* ---------- Mobile sticky call bar ---------- */
.mobile-cta{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;gap:.6rem;padding:.6rem .8rem
  calc(.6rem + env(safe-area-inset-bottom));background:rgba(28,19,12,.97);backdrop-filter:blur(8px);
  border-top:1px solid rgba(236,226,210,.14);box-shadow:0 -8px 24px rgba(20,14,9,.3)}
.mobile-cta .btn{flex:1;padding:.95em 1em;font-size:.97rem}

/* ---------- Reveal animation ---------- */
.reveal{transition:opacity .85s var(--ease),transform .85s var(--ease)}
.js .reveal{opacity:0;transform:translateY(26px)}        /* only hide when JS is active (no-JS shows content) */
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.09s}
.reveal[data-delay="2"]{transition-delay:.18s}
.reveal[data-delay="3"]{transition-delay:.27s}
.reveal[data-delay="4"]{transition-delay:.36s}
.reveal[data-delay="5"]{transition-delay:.45s}

/* ---------- Misc utilities ---------- */
.text-center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.divider-rule{width:100%;height:1px;background:var(--line);border:0;margin:0}
.pill-tag{display:inline-block;font-size:.78rem;font-weight:600;letter-spacing:.05em;color:var(--brass-deep);
  background:var(--parchment);border:1px solid var(--line);padding:.35em .8em;border-radius:var(--radius-pill)}
.anchor-offset{scroll-margin-top:calc(var(--header-h) + 16px)}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1024px){
  .footer-inner{grid-template-columns:1fr 1fr;gap:2rem}
  .process-grid{grid-template-columns:repeat(2,1fr);gap:2rem}
  .process-step:nth-child(2)::after{display:none}
  .masonry{column-count:2}
}
@media (max-width:900px){
  .hero--home{min-height:auto}
  .hero-copy{max-width:none;padding-block:clamp(2.5rem,7vh,4rem)}
}
@media (max-width:820px){
  .primary-nav,.header-cta{display:none}
  .nav-toggle{display:flex}
  .primary-nav{position:fixed;top:0;right:0;bottom:0;width:min(82vw,340px);margin:0;z-index:99;
    background:#1f160e;border-left:1px solid rgba(236,226,210,.12);padding:calc(var(--header-h) + 1.5rem) 1.8rem 2rem;
    transform:translateX(100%);transition:transform .38s var(--ease);overflow-y:auto;box-shadow:-20px 0 50px rgba(20,14,9,.4)}
  .primary-nav.open{transform:translateX(0)}
  .primary-nav ul{flex-direction:column;align-items:stretch;gap:.3rem}
  .primary-nav li{border-bottom:1px solid rgba(236,226,210,.08)}
  .primary-nav a{display:block;padding:.95em 0;font-size:1.1rem}
  .primary-nav a::after{display:none}
  .nav-drawer-cta{margin-top:1.6rem;display:grid;gap:.7rem}
  .nav-drawer-cta .btn{width:100%}
  .grid-3,.grid-4,.testi-grid,.contact-grid{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:2rem}
  .split.reverse>.split-media{order:0}
  .stat-row{grid-template-columns:repeat(2,1fr);gap:2rem}
  .work-grid{grid-template-columns:repeat(2,1fr)}
  .work-grid .work-card{grid-column:span 1 !important}
  .mobile-cta{display:flex}
  body{padding-bottom:calc(72px + env(safe-area-inset-bottom))}
}
@media (max-width:560px){
  .grid-2{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .masonry{column-count:1}
  .process-grid{grid-template-columns:1fr}
  .process-step::after{display:none}
  .work-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;gap:2rem}
  .hero-actions .btn,.cta-actions .btn{flex:1 1 100%}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1 !important;transform:none !important}
  .scroll-cue svg{animation:none}
  .work-card img,.masonry .tile img{transition:none}
}
