/* ============================================================
   A KAREN BLACK COMPANY
   Kitchen, Bath & Home Remodeling, Oklahoma City
   Design system: warm ivory, espresso, brushed gold, petrol.
   Type: Fraunces (display serif) + Source Sans 3 (text).
   Built for clarity, legibility, and a quiet, established luxury.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,340;9..144,420;9..144,500;9..144,600&family=Source+Sans+3:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root{
  /* surfaces */
  --ivory:#FAF6EF;
  --ivory-2:#F4EDDF;
  --cream:#EFE6D5;
  --paper:#FFFFFF;
  --espresso:#1E1B16;
  --espresso-2:#272219;

  /* ink */
  --ink:#211E18;
  --ink-soft:#3E382F;
  --muted:#857B6B;
  --muted-2:#9A9082;

  /* accents */
  --gold:#9C7C36;
  --gold-bright:#C2A052;
  --gold-soft:#E3D2A0;
  --gold-line:#D8C49A;
  --petrol:#2C4750;
  --petrol-2:#22383F;
  --slate:#3B4A55;
  --terra:#A2643F;

  /* lines */
  --line:#E7DCC9;
  --line-2:#DCCFB6;
  --line-dk:#3A352C;

  /* effects */
  --shadow-sm:0 4px 18px rgba(40,32,18,.06);
  --shadow:0 18px 50px rgba(40,32,18,.10);
  --shadow-lg:0 40px 90px rgba(28,22,12,.20);
  --radius:4px;
  --radius-lg:8px;

  --container:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --font-display:"Fraunces","Hoefler Text",Georgia,"Times New Roman",serif;
  --font-text:"Source Sans 3",system-ui,-apple-system,"Segoe UI",Helvetica,Arial,sans-serif;
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--font-text);
  font-size:1.0625rem;            /* 17px base, generous for all ages */
  line-height:1.72;
  color:var(--ink-soft);
  background:var(--ivory);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body.no-scroll{ overflow:hidden; }

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
ul{ list-style:none; }

/* subtle paper warmth */
body::before{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(120% 80% at 12% 0%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(120% 90% at 100% 100%, rgba(216,196,154,.10), transparent 55%);
}

/* ---------- typography ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); color:var(--ink); font-weight:420; line-height:1.08; letter-spacing:-.012em; }
.display-1{ font-size:clamp(2.7rem,6.2vw,5rem); font-weight:340; line-height:1.02; letter-spacing:-.02em; }
h1{ font-size:clamp(2.4rem,5vw,4rem); }
h2{ font-size:clamp(1.95rem,3.6vw,3rem); }
h3{ font-size:clamp(1.3rem,2vw,1.65rem); font-weight:500; }
h4{ font-size:1.15rem; font-weight:500; }
p{ margin:0 0 1.1em; }
p:last-child{ margin-bottom:0; }
strong,b{ font-weight:600; color:var(--ink); }
em{ font-style:italic; }

.lead{ font-size:clamp(1.18rem,1.7vw,1.4rem); line-height:1.62; color:var(--ink-soft); font-weight:400; }

.eyebrow{
  display:inline-block; font-size:.78rem; letter-spacing:.26em; text-transform:uppercase;
  font-weight:600; color:var(--gold); font-family:var(--font-text);
}
.eyebrow.on-dark{ color:var(--gold-bright); }
.eyebrow-line{ display:inline-flex; align-items:center; gap:.85rem; }
.eyebrow-line::before{ content:""; width:34px; height:1px; background:var(--gold-line); }

.script-accent{ font-style:italic; font-weight:340; color:var(--gold); }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 clamp(1.4rem,4vw,3rem); }
.container-wide{ max-width:1440px; }
.container-narrow{ max-width:880px; }
section{ position:relative; }
.section{ padding:clamp(4.5rem,9vw,8rem) 0; }
.section-sm{ padding:clamp(3.2rem,6vw,5rem) 0; }
.bg-ivory{ background:var(--ivory); }
.bg-ivory-2{ background:var(--ivory-2); }
.bg-cream{ background:var(--cream); }
.bg-paper{ background:var(--paper); }
.bg-espresso{ background:var(--espresso); color:#E9E1D2; }
.bg-petrol{ background:var(--petrol); color:#E9EBE6; }
.bg-espresso h1,.bg-espresso h2,.bg-espresso h3,.bg-espresso h4,
.bg-petrol h1,.bg-petrol h2,.bg-petrol h3,.bg-petrol h4{ color:#FBF7EE; }

.grid{ display:grid; gap:clamp(1.4rem,3vw,2.4rem); }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
.items-center{ align-items:center; }
.gap-lg{ gap:clamp(2rem,5vw,4.5rem); }

.section-head{ max-width:720px; }
.section-head.center{ margin:0 auto; text-align:center; }
.section-head .eyebrow{ margin-bottom:1.1rem; }
.section-head h2 + p{ margin-top:1.1rem; color:var(--ink-soft); }
.center{ text-align:center; }

.rule-gold{ width:58px; height:2px; background:linear-gradient(90deg,var(--gold),var(--gold-bright)); border-radius:2px; }
.rule-gold.center{ margin-inline:auto; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6rem; font-family:var(--font-text);
  font-size:.86rem; letter-spacing:.13em; text-transform:uppercase; font-weight:600;
  padding:1.02rem 1.9rem; border:1px solid transparent; border-radius:var(--radius);
  transition:transform .4s var(--ease), background .35s ease, color .35s ease, box-shadow .4s ease, border-color .35s ease;
  position:relative; will-change:transform; white-space:nowrap; text-align:center;
}
.btn .arr{ transition:transform .4s var(--ease); }
.btn:hover .arr{ transform:translateX(5px); }
.btn-primary{ background:var(--espresso); color:#F6F0E4; box-shadow:0 12px 30px rgba(30,27,22,.22); }
.btn-primary:hover{ background:#100E0A; transform:translateY(-2px); box-shadow:0 18px 40px rgba(30,27,22,.30); }
.btn-gold{ background:linear-gradient(135deg,var(--gold-bright),var(--gold)); color:#231d10; box-shadow:0 12px 30px rgba(156,124,54,.30); }
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 18px 44px rgba(156,124,54,.42); }
.btn-outline{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-outline:hover{ border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }
.btn-outline.on-dark{ color:#F2ECDE; border-color:rgba(226,210,170,.35); }
.btn-outline.on-dark:hover{ border-color:var(--gold-bright); color:var(--gold-bright); }
.btn-lg{ padding:1.15rem 2.3rem; font-size:.9rem; }

.text-link{
  display:inline-flex; align-items:center; gap:.5rem; font-weight:600; color:var(--ink);
  font-size:.92rem; letter-spacing:.04em; padding-bottom:3px; position:relative;
}
.text-link::after{ content:""; position:absolute; left:0; bottom:0; height:1.5px; width:100%;
  background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease-out); }
.text-link:hover::after{ transform:scaleX(1); }
.text-link .arr{ color:var(--gold); transition:transform .4s var(--ease); }
.text-link:hover .arr{ transform:translateX(4px); }
.text-link.on-dark{ color:#F4EEDF; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:120;
  transition:background .5s var(--ease), box-shadow .5s ease, border-color .5s ease, padding .4s ease;
  border-bottom:1px solid transparent;
}
.site-header .bar{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem;
  height:88px; transition:height .4s ease; }
.site-header.scrolled{ background:rgba(250,246,239,.92); backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2); border-color:var(--line); box-shadow:0 8px 30px rgba(40,32,18,.07); }
.site-header.scrolled .bar{ height:72px; }

.brand{ display:flex; align-items:center; gap:.7rem; flex:none; }
.brand img{ height:46px; width:auto; transition:height .4s ease; }
.site-header.scrolled .brand img{ height:40px; }
.brand .wordmark{ display:flex; flex-direction:column; line-height:1; }
.brand .wordmark .n{ font-family:var(--font-display); font-size:1.12rem; letter-spacing:.02em; color:var(--ink); font-weight:500; }
.brand .wordmark .s{ font-size:.6rem; letter-spacing:.32em; text-transform:uppercase; color:var(--gold); margin-top:5px; font-weight:600; }

/* top-of-page (hero) light header variant */
.site-header.on-hero:not(.scrolled){ }
.site-header.on-hero:not(.scrolled) .nav-link,
.site-header.on-hero:not(.scrolled) .brand .wordmark .n{ color:#F6F0E4; }
.site-header.on-hero:not(.scrolled) .brand .wordmark .s{ color:var(--gold-bright); }
.site-header.on-hero:not(.scrolled) .nav-link::after{ background:var(--gold-bright); }
.site-header.on-hero:not(.scrolled) .brand img.logo-dark{ display:none; }
.site-header:not(.on-hero) .brand img.logo-light,
.site-header.scrolled .brand img.logo-light{ display:none; }
.site-header.on-hero:not(.scrolled) .brand img.logo-light{ display:block; }
.site-header.on-hero:not(.scrolled) .header-phone{ color:#EAE2D2; }
.site-header.on-hero:not(.scrolled) .header-phone .ph-ico{ border-color:rgba(226,210,170,.4); color:var(--gold-bright); }

.nav{ display:flex; align-items:center; gap:clamp(.85rem,1.5vw,1.5rem); }
.nav-list{ display:flex; align-items:center; gap:clamp(.7rem,1.35vw,1.55rem); }
.nav-item{ position:relative; }
.nav-link{ display:inline-flex; align-items:center; gap:.3rem; font-size:.82rem; letter-spacing:.07em;
  text-transform:uppercase; font-weight:600; color:var(--ink-soft); padding:.4rem 0; position:relative; transition:color .3s ease; }
.nav-link .caret{ width:9px; height:9px; transition:transform .35s ease; opacity:.7; }
.nav-link::after{ content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:100%;
  background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease-out); }
.nav-item:hover .nav-link, .nav-link.active{ color:var(--gold); }
.nav-item:hover .nav-link::after, .nav-link.active::after{ transform:scaleX(1); }
.nav-item:hover .caret{ transform:rotate(180deg); }

/* dropdown */
.dropdown{
  position:absolute; top:calc(100% + 14px); left:50%; transform:translateX(-50%) translateY(10px);
  min-width:286px; background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow); padding:.7rem; opacity:0; visibility:hidden; transition:opacity .32s var(--ease), transform .32s var(--ease);
}
.dropdown::before{ content:""; position:absolute; top:-16px; left:0; right:0; height:16px; }
.nav-item:hover .dropdown{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.dropdown a{ display:block; padding:.72rem .9rem; border-radius:var(--radius); transition:background .25s ease, color .25s ease; }
.dropdown a .dt{ display:block; font-weight:600; font-size:.95rem; color:var(--ink); text-transform:none; letter-spacing:0; }
.dropdown a .dd{ display:block; font-size:.78rem; color:var(--muted); margin-top:1px; }
.dropdown a:hover{ background:var(--ivory-2); }
.dropdown a:hover .dt{ color:var(--gold); }

.header-phone{ display:none; align-items:center; gap:.55rem; font-weight:600; font-size:.9rem;
  color:var(--ink); letter-spacing:.02em; transition:color .3s ease; white-space:nowrap; }
@media (min-width:1330px){ .header-phone{ display:inline-flex; } }
.header-phone .ph-ico{ width:34px; height:34px; border-radius:50%; border:1px solid var(--line-2);
  display:grid; place-items:center; color:var(--gold); transition:.3s ease; }
.header-phone:hover .ph-ico{ background:var(--gold); color:#fff; border-color:var(--gold); }

.header-actions{ display:flex; align-items:center; gap:.85rem; }
.header-actions .btn{ padding:.82rem 1.45rem; font-size:.8rem; letter-spacing:.1em; }

/* burger */
.burger{ display:none; width:46px; height:46px; border:1px solid var(--line-2); border-radius:var(--radius);
  background:transparent; position:relative; flex:none; }
.burger span{ position:absolute; left:12px; right:12px; height:1.6px; background:var(--ink); transition:.35s var(--ease); }
.burger span:nth-child(1){ top:16px; } .burger span:nth-child(2){ top:22px; } .burger span:nth-child(3){ top:28px; }
.site-header.on-hero:not(.scrolled) .burger{ border-color:rgba(255,255,255,.35); }
.site-header.on-hero:not(.scrolled) .burger span{ background:#F6F0E4; }
body.menu-open .burger span:nth-child(1){ top:22px; transform:rotate(45deg); }
body.menu-open .burger span:nth-child(2){ opacity:0; }
body.menu-open .burger span:nth-child(3){ top:22px; transform:rotate(-45deg); }

/* mobile drawer */
.mobile-nav{ position:fixed; inset:0 0 0 auto; width:min(420px,86vw); background:var(--ivory); z-index:115;
  transform:translateX(100%); transition:transform .5s var(--ease); padding:7rem 2rem 2.5rem; overflow-y:auto;
  box-shadow:var(--shadow-lg); border-left:1px solid var(--line); }
body.menu-open .mobile-nav{ transform:translateX(0); }
.mobile-nav a{ display:block; font-family:var(--font-display); font-size:1.45rem; color:var(--ink); padding:.7rem 0;
  border-bottom:1px solid var(--line); }
.mobile-nav .m-group-label{ font-size:.72rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold);
  font-family:var(--font-text); font-weight:600; margin:1.6rem 0 .3rem; }
.mobile-nav .m-sub a{ font-family:var(--font-text); font-size:1.02rem; padding:.55rem 0 .55rem 1rem; color:var(--ink-soft); }
.mobile-nav .m-cta{ margin-top:1.8rem; }
.mobile-nav .m-cta .btn{ width:100%; justify-content:center; }
.scrim{ position:fixed; inset:0; background:rgba(25,20,12,.5); z-index:114; opacity:0; visibility:hidden;
  transition:opacity .5s ease; backdrop-filter:blur(2px); }
body.menu-open .scrim{ opacity:1; visibility:visible; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:center;
  color:#F6F0E4; overflow:hidden; }
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media img{ width:100%; height:120%; object-fit:cover; will-change:transform; }
.hero-scrim{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(102deg, rgba(20,17,12,.86) 0%, rgba(22,18,12,.72) 38%, rgba(24,19,12,.40) 66%, rgba(24,19,12,.18) 100%),
             linear-gradient(0deg, rgba(18,15,10,.55), transparent 45%); }
.hero .container{ position:relative; z-index:2; padding-top:96px; padding-bottom:60px; }
.hero-inner{ max-width:830px; }
.hero .eyebrow{ color:var(--gold-bright); }
.hero h1{ color:#FCF8F0; margin:1.3rem 0 0; }
.hero .tagline{ font-family:var(--font-display); font-style:italic; font-weight:340;
  font-size:clamp(2.6rem,6.5vw,5.2rem); line-height:1.02; color:#FCF8F0; letter-spacing:-.01em; }
.hero .tagline .dot{ color:var(--gold-bright); }
.hero p.hero-sub{ max-width:600px; margin-top:1.6rem; color:#E4DBCB; font-size:1.18rem; line-height:1.66; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.3rem; }
.hero-meta{ display:flex; flex-wrap:wrap; gap:2.2rem; margin-top:3rem; padding-top:2rem;
  border-top:1px solid rgba(231,217,184,.22); }
.hero-meta .hm{ }
.hero-meta .hm .v{ font-family:var(--font-display); font-size:1.85rem; color:#FBF6EC; line-height:1; }
.hero-meta .hm .v .star{ color:var(--gold-bright); }
.hero-meta .hm .l{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:#C4BAA6; margin-top:.5rem; }
.hero-scroll{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.6rem; color:#D8CEBB; font-size:.68rem;
  letter-spacing:.22em; text-transform:uppercase; }
.hero-scroll .mouse{ width:24px; height:38px; border:1.5px solid rgba(231,217,184,.5); border-radius:14px; position:relative; }
.hero-scroll .mouse::after{ content:""; position:absolute; left:50%; top:7px; width:3px; height:7px; border-radius:3px;
  background:var(--gold-bright); transform:translateX(-50%); animation:scrollDot 1.9s var(--ease) infinite; }
@keyframes scrollDot{ 0%{ opacity:0; transform:translate(-50%,0);} 30%{opacity:1;} 70%{opacity:1; transform:translate(-50%,11px);} 100%{opacity:0; transform:translate(-50%,14px);} }

/* page hero (interior pages) */
.page-hero{ position:relative; padding:clamp(8rem,16vw,12rem) 0 clamp(3.5rem,7vw,6rem); color:#F6F0E4; overflow:hidden; }
.page-hero .hero-media img{ height:128%; }
.page-hero-inner{ position:relative; z-index:2; max-width:820px; }
.page-hero h1{ color:#FCF8F0; margin-top:1.1rem; }
.page-hero p{ color:#E4DBCB; max-width:620px; margin-top:1.2rem; font-size:1.15rem; }
.breadcrumb{ display:flex; flex-wrap:wrap; gap:.5rem; align-items:center; font-size:.78rem; letter-spacing:.12em;
  text-transform:uppercase; color:#C8BEA9; }
.breadcrumb a:hover{ color:var(--gold-bright); }
.breadcrumb .sep{ opacity:.5; }

/* ============================================================
   CARDS / FEATURES
   ============================================================ */
.card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm); transition:transform .5s var(--ease), box-shadow .5s ease, border-color .4s ease; }
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--line-2); }

.feature{ padding:2.2rem 2rem; }
.feature .ico{ width:54px; height:54px; border-radius:50%; display:grid; place-items:center; margin-bottom:1.3rem;
  background:var(--ivory-2); border:1px solid var(--gold-line); color:var(--gold); }
.feature .ico svg{ width:24px; height:24px; }
.feature h3{ margin-bottom:.6rem; }
.feature p{ color:var(--ink-soft); font-size:1rem; }

/* numbered service list */
.svc-row{ display:grid; grid-template-columns:auto 1fr; gap:1.6rem; padding:2rem 0; border-top:1px solid var(--line); align-items:start; }
.svc-row:last-child{ border-bottom:1px solid var(--line); }
.svc-row .num{ font-family:var(--font-display); font-size:1.4rem; color:var(--gold); width:3rem; }
.svc-row h3{ margin-bottom:.5rem; }
.svc-row .meta-pill{ display:inline-block; font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--gold-line); border-radius:999px; padding:.28rem .8rem; margin-top:.9rem; font-weight:600; }

/* stat band */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden; }
.stat{ background:var(--paper); padding:2.2rem 1.4rem; text-align:center; }
.bg-espresso .stat, .bg-petrol .stat{ background:transparent; }
.stat .v{ font-family:var(--font-display); font-size:clamp(2.2rem,4vw,3rem); color:var(--ink); line-height:1; font-weight:420; }
.bg-espresso .stat .v,.bg-petrol .stat .v{ color:#FBF6EC; }
.stat .v .accent{ color:var(--gold); } .bg-espresso .stat .v .accent,.bg-petrol .stat .v .accent{ color:var(--gold-bright); }
.stat .l{ font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-top:.7rem; }
.bg-espresso .stat .l,.bg-petrol .stat .l{ color:#BDB3A0; }
.bg-espresso .stats,.bg-petrol .stats{ background:rgba(231,217,184,.16); border-color:rgba(231,217,184,.2); }

/* checklist */
.check-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:.6rem 2rem; }
.check{ display:flex; gap:.85rem; align-items:flex-start; padding:.55rem 0; }
.check .tick{ flex:none; width:22px; height:22px; border-radius:50%; background:var(--gold);
  display:grid; place-items:center; margin-top:3px; }
.check .tick svg{ width:12px; height:12px; color:#fff; }
.check span{ font-weight:500; color:var(--ink); }

/* split feature (image + text) */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.split.reverse .split-media{ order:2; }
.split-media{ position:relative; }
.split-media .frame{ position:relative; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); }
.split-media .frame img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease); }
.split-media:hover .frame img{ transform:scale(1.05); }
.split-media .accent-frame{ position:absolute; border:1px solid var(--gold-line); border-radius:var(--radius-lg);
  inset:18px -18px -18px 18px; z-index:-1; }
.split-media .tag-badge{ position:absolute; bottom:18px; left:18px; background:rgba(20,17,12,.78);
  backdrop-filter:blur(6px); color:#F4EEDF; padding:.7rem 1.1rem; border-radius:var(--radius); font-size:.8rem;
  letter-spacing:.1em; text-transform:uppercase; border:1px solid rgba(231,217,184,.2); }

/* pill chips */
.chips{ display:flex; flex-wrap:wrap; gap:.6rem; }
.chip{ display:inline-block; font-size:.86rem; font-weight:600; color:var(--ink); background:var(--paper);
  border:1px solid var(--line-2); border-radius:999px; padding:.55rem 1.05rem; transition:.3s ease; }
.chip:hover{ border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }
.chip.gold{ background:var(--ivory-2); border-color:var(--gold-line); color:var(--gold); }

/* ============================================================
   PORTFOLIO GALLERY
   ============================================================ */
.gallery-filter{ display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center; margin-bottom:2.8rem; }
.filter-btn{ font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; font-weight:600; color:var(--muted);
  background:transparent; border:1px solid var(--line-2); border-radius:999px; padding:.6rem 1.3rem; transition:.3s ease; }
.filter-btn:hover{ color:var(--ink); border-color:var(--gold-line); }
.filter-btn.active{ background:var(--espresso); color:#F4EEDF; border-color:var(--espresso); }

.masonry{ columns:3; column-gap:1.4rem; }
.masonry .tile{ break-inside:avoid; margin-bottom:1.4rem; }
.tile{ position:relative; border-radius:var(--radius-lg); overflow:hidden; cursor:pointer; box-shadow:var(--shadow-sm);
  transition:opacity .5s ease, transform .5s ease; }
.tile img{ width:100%; transition:transform 1.1s var(--ease); }
.tile::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(20,16,10,.72), rgba(20,16,10,.05) 55%);
  opacity:0; transition:opacity .45s ease; }
.tile:hover img{ transform:scale(1.06); }
.tile:hover::after{ opacity:1; }
.tile .cap{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1.4rem; color:#fff;
  transform:translateY(12px); opacity:0; transition:.45s var(--ease); }
.tile:hover .cap{ transform:translateY(0); opacity:1; }
.tile .cap .t{ font-family:var(--font-display); font-size:1.18rem; line-height:1.2; }
.tile .cap .s{ font-size:.76rem; letter-spacing:.13em; text-transform:uppercase; color:var(--gold-bright); margin-top:.35rem; }
.tile .view-ico{ position:absolute; top:14px; right:14px; z-index:2; width:40px; height:40px; border-radius:50%;
  background:rgba(250,246,239,.92); display:grid; place-items:center; color:var(--ink); opacity:0; transform:scale(.7);
  transition:.4s var(--ease); }
.tile:hover .view-ico{ opacity:1; transform:scale(1); }
.tile.hide{ display:none; }

/* lightbox */
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(16,13,8,.95); display:flex; align-items:center;
  justify-content:center; opacity:0; visibility:hidden; transition:opacity .4s ease; padding:4vw; }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox img{ max-width:92vw; max-height:86vh; object-fit:contain; border-radius:var(--radius);
  box-shadow:0 30px 80px rgba(0,0,0,.6); transform:scale(.96); transition:transform .4s var(--ease); }
.lightbox.open img{ transform:scale(1); }
.lightbox .lb-cap{ position:absolute; bottom:4vh; left:0; right:0; text-align:center; color:#EAE0CC;
  font-size:.9rem; letter-spacing:.05em; }
.lightbox .lb-cap .t{ font-family:var(--font-display); font-size:1.3rem; color:#fff; }
.lb-close,.lb-nav{ position:absolute; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2);
  color:#fff; width:52px; height:52px; border-radius:50%; display:grid; place-items:center; transition:.3s ease; }
.lb-close{ top:4vh; right:4vw; } .lb-close:hover,.lb-nav:hover{ background:var(--gold); border-color:var(--gold); }
.lb-nav{ top:50%; transform:translateY(-50%); } .lb-prev{ left:3vw; } .lb-next{ right:3vw; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quote-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:2.6rem 2.3rem; box-shadow:var(--shadow-sm); position:relative; height:100%;
  transition:transform .5s var(--ease), box-shadow .5s ease; }
.quote-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.quote-card .mark{ font-family:var(--font-display); font-size:4.5rem; line-height:.7; color:var(--gold-soft);
  height:2.2rem; display:block; }
.quote-card .stars{ color:var(--gold-bright); letter-spacing:.18em; margin-bottom:1rem; font-size:1rem; }
.quote-card p{ font-size:1.06rem; color:var(--ink-soft); line-height:1.66; }
.quote-card .by{ margin-top:1.4rem; font-weight:600; color:var(--ink); font-size:.92rem; letter-spacing:.04em; }
.quote-card .by small{ display:block; color:var(--muted); font-weight:400; letter-spacing:.1em; text-transform:uppercase;
  font-size:.72rem; margin-top:.25rem; }

.feature-quote{ font-family:var(--font-display); font-weight:340; font-size:clamp(1.6rem,3.2vw,2.5rem);
  line-height:1.32; color:var(--ink); letter-spacing:-.01em; }
.feature-quote .hl{ color:var(--gold); font-style:italic; }

/* ============================================================
   PROCESS STEPS
   ============================================================ */
.steps{ display:grid; gap:0; }
.step{ display:grid; grid-template-columns:auto 1fr; gap:1.8rem; padding:2.1rem 0; position:relative; }
.step:not(:last-child){ border-bottom:1px solid var(--line); }
.step .s-num{ width:60px; height:60px; border-radius:50%; border:1px solid var(--gold-line); display:grid; place-items:center;
  font-family:var(--font-display); font-size:1.4rem; color:var(--gold); flex:none; background:var(--paper); }
.step h3{ margin-bottom:.5rem; }
.step p{ color:var(--ink-soft); }

/* ============================================================
   FORMS
   ============================================================ */
.form-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.8rem,4vw,3rem);
  box-shadow:var(--shadow); }
.field{ margin-bottom:1.3rem; }
.field label{ display:block; font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; font-weight:600;
  color:var(--ink-soft); margin-bottom:.5rem; }
.field input,.field select,.field textarea{ width:100%; font-family:var(--font-text); font-size:1rem; color:var(--ink);
  background:var(--ivory); border:1px solid var(--line-2); border-radius:var(--radius); padding:.95rem 1.05rem;
  transition:border-color .3s ease, box-shadow .3s ease; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(194,160,82,.16); background:var(--paper); }
.field textarea{ min-height:140px; resize:vertical; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.form-note{ font-size:.85rem; color:var(--muted); margin-top:.5rem; }

/* info list (contact) */
.info-item{ display:flex; gap:1.1rem; padding:1.3rem 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.info-item:last-child{ border-bottom:none; }
.info-item .ii-ico{ width:46px; height:46px; border-radius:50%; background:var(--ivory-2); border:1px solid var(--gold-line);
  display:grid; place-items:center; color:var(--gold); flex:none; }
.info-item .ii-ico svg{ width:20px; height:20px; }
.info-item .l{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:.25rem; }
.info-item .v{ font-size:1.08rem; color:var(--ink); font-weight:500; }
.info-item .v a:hover{ color:var(--gold); }

/* hours table */
.hours{ }
.hours li{ display:flex; justify-content:space-between; padding:.7rem 0; border-bottom:1px dashed var(--line); }
.hours li:last-child{ border-bottom:none; }
.hours .d{ font-weight:600; color:var(--ink); }
.hours .t{ color:var(--ink-soft); }
.hours .closed{ color:var(--terra); }

/* ============================================================
   BLOG / JOURNAL
   ============================================================ */
.journal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.post{ display:flex; flex-direction:column; height:100%; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s ease; }
.post:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.post .p-media{ aspect-ratio:3/2; overflow:hidden; background:var(--cream); }
.post .p-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.post:hover .p-media img{ transform:scale(1.06); }
.post .p-body{ padding:1.6rem 1.5rem 1.7rem; display:flex; flex-direction:column; flex:1; }
.post .p-cat{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); font-weight:600; }
.post h3{ font-size:1.28rem; margin:.6rem 0 .8rem; line-height:1.22; }
.post .p-date{ font-size:.82rem; color:var(--muted); margin-top:auto; letter-spacing:.04em; }
.post .p-readmore{ margin-top:1rem; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{ position:relative; overflow:hidden; }
.cta-band .hero-media img{ height:130%; opacity:1; }
.cta-band .scrim{ position:absolute; inset:0; background:linear-gradient(100deg, rgba(20,17,12,.92), rgba(22,18,12,.7) 60%, rgba(24,19,12,.5)); }
.cta-band .inner{ position:relative; z-index:2; text-align:center; max-width:760px; margin:0 auto;
  padding:clamp(4.5rem,9vw,7.5rem) 0; }
.cta-band h2{ color:#FCF8F0; }
.cta-band p{ color:#E4DBCB; margin:1.2rem auto 2rem; max-width:560px; font-size:1.15rem; }
.cta-band .hero-cta{ justify-content:center; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; text-align:left; background:transparent; border:none; padding:1.5rem 0; display:flex;
  justify-content:space-between; align-items:center; gap:1.5rem; font-family:var(--font-display); font-size:1.2rem;
  color:var(--ink); font-weight:500; transition:color .3s ease; }
.faq-q:hover{ color:var(--gold); }
.faq-q .pm{ flex:none; width:30px; height:30px; border:1px solid var(--line-2); border-radius:50%; position:relative; transition:.35s ease; }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; left:50%; top:50%; background:var(--gold); border-radius:2px; }
.faq-q .pm::before{ width:12px; height:1.6px; transform:translate(-50%,-50%); }
.faq-q .pm::after{ width:1.6px; height:12px; transform:translate(-50%,-50%); transition:transform .35s ease; }
.faq-item.open .faq-q .pm{ border-color:var(--gold); background:var(--ivory-2); }
.faq-item.open .faq-q .pm::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .5s var(--ease); }
.faq-a-inner{ padding:0 0 1.6rem; color:var(--ink-soft); max-width:760px; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--espresso); color:#C7BDAB; padding:clamp(3.5rem,7vw,5.5rem) 0 0; position:relative; }
.footer-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.3fr; gap:2.5rem; padding-bottom:3.5rem;
  border-bottom:1px solid rgba(231,217,184,.14); }
.footer-brand img{ height:54px; margin-bottom:1.3rem; }
.footer-brand p{ color:#A99E8C; font-size:.96rem; max-width:300px; }
.footer-col h4{ color:#F2EADb; font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; margin-bottom:1.3rem;
  font-family:var(--font-text); font-weight:600; }
.footer-col ul li{ margin-bottom:.7rem; }
.footer-col ul a{ color:#B6AC9A; font-size:.96rem; transition:color .3s ease; position:relative; }
.footer-col ul a:hover{ color:var(--gold-bright); }
.footer-contact .fc{ display:flex; gap:.7rem; margin-bottom:1rem; align-items:flex-start; font-size:.96rem; color:#BBB1A0; }
.footer-contact .fc svg{ width:17px; height:17px; color:var(--gold-bright); flex:none; margin-top:4px; }
.footer-contact .fc a:hover{ color:var(--gold-bright); }
.footer-social{ display:flex; gap:.7rem; margin-top:1.4rem; }
.footer-social a{ width:40px; height:40px; border-radius:50%; border:1px solid rgba(231,217,184,.22); display:grid;
  place-items:center; color:#C7BDAB; transition:.3s ease; }
.footer-social a:hover{ background:var(--gold); color:#1a160e; border-color:var(--gold); transform:translateY(-3px); }
.footer-social svg{ width:17px; height:17px; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap;
  padding:1.8rem 0; font-size:.84rem; color:#8E8473; letter-spacing:.03em; }
.footer-bottom a:hover{ color:var(--gold-bright); }
.footer-areas{ font-size:.86rem; color:#9A9078; }
.footer-areas b{ color:#C7BDAB; font-weight:600; }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; }
.reveal.d4{ transition-delay:.32s; } .reveal.d5{ transition-delay:.4s; }
.reveal-img{ clip-path:inset(0 100% 0 0); transition:clip-path 1.1s var(--ease-out); }
.reveal-img.in{ clip-path:inset(0 0 0 0); }
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-img{ opacity:1 !important; transform:none !important; clip-path:none !important; transition:none !important; }
  .hero-media img{ transform:none !important; }
}

/* marquee */
.marquee{ overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding:1.4rem 0; background:var(--ivory-2); }
.marquee-track{ display:flex; gap:3.5rem; width:max-content; animation:marquee 38s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-item{ display:inline-flex; align-items:center; gap:.9rem; font-family:var(--font-display); font-size:1.25rem;
  color:var(--ink-soft); white-space:nowrap; font-style:italic; font-weight:340; }
.marquee-item .dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); }
@keyframes marquee{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .marquee-track{ animation:none; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .nav-list{ display:none; }
  .burger{ display:block; }
  .header-phone{ display:none; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:2.2rem; }
}
@media (max-width:860px){
  .cols-3,.cols-4{ grid-template-columns:repeat(2,1fr); }
  .split{ grid-template-columns:1fr; gap:2.4rem; }
  .split.reverse .split-media{ order:0; }
  .split-media .accent-frame{ inset:12px -12px -12px 12px; }
  .masonry{ columns:2; }
  .journal-grid{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .check-grid{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
  .hero-meta{ gap:1.6rem; }
}
@media (max-width:560px){
  body{ font-size:1.02rem; }
  .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr; }
  .masonry{ columns:1; }
  .journal-grid{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .footer-top{ grid-template-columns:1fr; }
  .hero-meta .hm .v{ font-size:1.5rem; }
  .svc-row{ grid-template-columns:1fr; gap:.5rem; }
  .svc-row .num{ font-size:1.2rem; }
  .step{ grid-template-columns:1fr; gap:.8rem; }
  .lb-nav{ width:42px; height:42px; }
}

/* print-friendly + selection */
::selection{ background:var(--gold-soft); color:var(--espresso); }
:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; border-radius:2px; }

/* ============================================================
   IMMERSIVE / FULL-BLEED / VIDEO  (v2 redesign)
   ============================================================ */
.full-bleed{ width:100vw; position:relative; left:50%; right:50%; margin-left:-50vw; margin-right:-50vw; }
.container-xl{ width:100%; max-width:1640px; margin:0 auto; padding:0 clamp(1.4rem,4vw,4rem); }

/* YouTube cover background (16:9 scaled to fill any box) */
.video-bg{ position:absolute; inset:0; overflow:hidden; z-index:0; background:#15120c; }
.video-bg .vb-poster{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
  transition:opacity 1.1s ease; }
.video-bg.playing .vb-poster{ opacity:0; }
.video-bg iframe, .video-bg video{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:100vw; height:56.25vw;            /* 16:9 cover for full-viewport heroes */
  min-height:100vh; min-width:177.78vh;   /* 100vh * 16/9 */
  border:0; pointer-events:none; z-index:1; }
/* video band that is NOT full viewport: cover relative to a fixed-aspect band */
.video-band{ position:relative; overflow:hidden; }
.video-band .vb-frame{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:100%; height:56.25vw; min-height:100%; min-width:177.78vh; border:0; pointer-events:none; }

/* fullscreen immersive section */
.cine{ position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; color:#F6F0E4; }
.cine.center{ align-items:center; }
.cine-media{ position:absolute; inset:0; z-index:0; }
.cine-media img{ width:100%; height:100%; object-fit:cover; }
.cine-scrim{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(0deg, rgba(16,13,8,.82) 0%, rgba(16,13,8,.30) 42%, rgba(16,13,8,.12) 70%, rgba(16,13,8,.42) 100%); }
.cine-scrim.left{ background:linear-gradient(95deg, rgba(16,13,8,.86) 0%, rgba(16,13,8,.55) 42%, rgba(16,13,8,.12) 78%); }
.cine .container, .cine .container-xl{ position:relative; z-index:2; padding-top:9rem; padding-bottom:5rem; width:100%; }
.cine h2{ color:#FCF8F0; }
.cine p{ color:#E4DBCB; }

/* alternating full-bleed image/text band (fills the screen, no empty halves) */
.band{ display:grid; grid-template-columns:1fr 1fr; min-height:clamp(520px,68vh,760px); }
.band .band-media{ position:relative; overflow:hidden; }
.band .band-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.4s var(--ease); }
.band:hover .band-media img{ transform:scale(1.05); }
.band .band-media.video{ background:#15120c; }
.band .band-copy{ display:flex; flex-direction:column; justify-content:center; padding:clamp(2.4rem,6vw,6rem); }
.band .band-copy.dark{ background:var(--espresso); color:#E9E1D2; }
.band .band-copy.petrol{ background:var(--petrol); color:#E9EBE6; }
.band .band-copy.cream{ background:var(--cream); }
.band .band-copy.ivory{ background:var(--ivory-2); }
.band .band-copy.dark h2,.band .band-copy.petrol h2{ color:#FBF7EE; }
.band .band-media .play-badge, .band .band-copy .play-badge{ pointer-events:auto; }
.band.reverse .band-media{ order:2; }
@media (max-width:880px){
  .band{ grid-template-columns:1fr; }
  .band.reverse .band-media{ order:0; }
  .band .band-media{ min-height:54vh; }
  .video-bg iframe, .video-bg video{ height:100vh; width:177.78vh; }
}

/* play badge / button */
.play-badge{ display:inline-flex; align-items:center; gap:.9rem; cursor:pointer; background:transparent; border:none; color:inherit; }
.play-badge .ring{ width:74px; height:74px; border-radius:50%; border:1.5px solid rgba(231,217,184,.55); display:grid; place-items:center;
  position:relative; flex:none; transition:.4s var(--ease); }
.play-badge .ring::after{ content:""; width:0; height:0; border-style:solid; border-width:11px 0 11px 18px; border-color:transparent transparent transparent currentColor; margin-left:5px; }
.play-badge .ring .pulse{ position:absolute; inset:-1px; border-radius:50%; border:1.5px solid var(--gold-bright); animation:pulseRing 2.6s ease-out infinite; }
.play-badge:hover .ring{ background:var(--gold); border-color:var(--gold); color:#1a160e; transform:scale(1.06); }
.play-badge .pl-label{ font-size:.82rem; letter-spacing:.18em; text-transform:uppercase; font-weight:600; }
.play-badge.solid .ring{ background:rgba(250,246,239,.16); backdrop-filter:blur(4px); }
@keyframes pulseRing{ 0%{ transform:scale(1); opacity:.7; } 100%{ transform:scale(1.5); opacity:0; } }
@media (prefers-reduced-motion:reduce){ .play-badge .ring .pulse{ animation:none; } }

/* video lightbox (cinematic player) */
.vlb{ position:fixed; inset:0; z-index:240; background:rgba(10,8,4,.96); display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .45s ease; padding:4vw; }
.vlb.open{ opacity:1; visibility:visible; }
.vlb .vlb-stage{ width:min(1180px,94vw); aspect-ratio:16/9; position:relative; transform:scale(.96); transition:transform .45s var(--ease);
  box-shadow:0 40px 120px rgba(0,0,0,.6); border-radius:6px; overflow:hidden; background:#000; }
.vlb.open .vlb-stage{ transform:scale(1); }
.vlb .vlb-stage iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.vlb-close{ position:absolute; top:3vh; right:3vw; width:54px; height:54px; border-radius:50%; background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22); color:#fff; display:grid; place-items:center; font-size:1.4rem; transition:.3s ease; }
.vlb-close:hover{ background:var(--gold); border-color:var(--gold); color:#1a160e; }

/* full-bleed edge gallery */
.edge-gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.edge-gallery .eg{ position:relative; overflow:hidden; aspect-ratio:4/5; cursor:pointer; }
.edge-gallery .eg img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease); }
.edge-gallery .eg::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(16,12,7,.7), transparent 55%); opacity:.35; transition:opacity .4s ease; }
.edge-gallery .eg:hover img{ transform:scale(1.07); }
.edge-gallery .eg:hover::after{ opacity:.9; }
.edge-gallery .eg .eg-cap{ position:absolute; left:0; right:0; bottom:0; padding:1.3rem; color:#fff; z-index:2; transform:translateY(8px); opacity:0; transition:.45s var(--ease); }
.edge-gallery .eg:hover .eg-cap{ transform:none; opacity:1; }
.edge-gallery .eg .eg-cap .t{ font-family:var(--font-display); font-size:1.1rem; }
.edge-gallery .eg .eg-cap .s{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-bright); margin-top:.2rem; }
@media (max-width:1024px){ .edge-gallery{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .edge-gallery{ grid-template-columns:1fr 1fr; } }

/* overlap pull (lift a band into the section above for density) */
.pull-up{ margin-top:clamp(-7rem,-9vw,-5rem); position:relative; z-index:3; }

/* scroll progress + section index (immersive feel) */
.scroll-bar{ position:fixed; top:0; left:0; height:3px; width:0; z-index:130;
  background:linear-gradient(90deg,var(--gold),var(--gold-bright)); transition:width .1s linear; }

/* contained heading block above full-bleed sections */
.section-intro{ padding:clamp(4rem,8vw,7rem) 0 clamp(2rem,4vw,3rem); }
.section-intro.tight{ padding-bottom:clamp(1.4rem,3vw,2.4rem); }
.head-row{ display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; flex-wrap:wrap; }
.display-2{ font-family:var(--font-display); font-weight:340; font-size:clamp(2.3rem,5vw,4.2rem); line-height:1.02; letter-spacing:-.02em; color:var(--ink); }
.display-2.lt{ color:#FBF7EE; }

/* service nav tiles (edge gallery with permanent label) */
.svc-tiles{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.svc-tiles .st{ position:relative; overflow:hidden; aspect-ratio:3/4; display:block; color:#fff; }
.svc-tiles .st img{ width:100%; height:100%; object-fit:cover; transition:transform 1.3s var(--ease); }
.svc-tiles .st::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(14,11,6,.85) 0%, rgba(14,11,6,.25) 45%, rgba(14,11,6,.05) 75%); transition:opacity .5s ease; }
.svc-tiles .st:hover img{ transform:scale(1.07); }
.svc-tiles .st .st-in{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:clamp(1.4rem,2vw,2.1rem); }
.svc-tiles .st .st-n{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-bright); font-weight:600; }
.svc-tiles .st h3{ color:#fff; font-size:clamp(1.3rem,1.7vw,1.7rem); margin:.45rem 0 .2rem; }
.svc-tiles .st .st-go{ display:inline-flex; align-items:center; gap:.5rem; font-size:.8rem; letter-spacing:.12em; text-transform:uppercase;
  color:#E7DECF; margin-top:.7rem; opacity:0; transform:translateY(8px); transition:.45s var(--ease); }
.svc-tiles .st:hover .st-go{ opacity:1; transform:none; }
.svc-tiles .st .st-go .arr{ color:var(--gold-bright); }
@media (max-width:980px){ .svc-tiles{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .svc-tiles{ grid-template-columns:1fr; } .svc-tiles .st{ aspect-ratio:16/10; } }

/* film / watch cards */
.film-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,1.6vw,1.6rem); }
.film-card{ position:relative; overflow:hidden; border-radius:6px; aspect-ratio:16/9; cursor:pointer; background:#15120c; }
.film-card img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease), opacity .5s ease; opacity:.82; }
.film-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(12,9,5,.78), rgba(12,9,5,.12) 60%); }
.film-card:hover img{ transform:scale(1.06); opacity:.95; }
.film-card .fc-play{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:2; width:64px; height:64px; border-radius:50%;
  background:rgba(250,246,239,.16); backdrop-filter:blur(4px); border:1.5px solid rgba(231,217,184,.6); display:grid; place-items:center; transition:.4s var(--ease); }
.film-card .fc-play::after{ content:""; width:0; height:0; border-style:solid; border-width:9px 0 9px 15px; border-color:transparent transparent transparent #fff; margin-left:4px; }
.film-card:hover .fc-play{ background:var(--gold); border-color:var(--gold); transform:translate(-50%,-50%) scale(1.08); }
.film-card:hover .fc-play::after{ border-left-color:#1a160e; }
.film-card .fc-cap{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1.2rem 1.3rem; }
.film-card .fc-cap .t{ font-family:var(--font-display); color:#fff; font-size:1.12rem; }
.film-card .fc-cap .s{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-bright); margin-top:.2rem; }
.film-feature{ position:relative; overflow:hidden; border-radius:8px; aspect-ratio:16/9; cursor:pointer; background:#15120c; }
.film-feature img{ width:100%; height:100%; object-fit:cover; transition:transform 1.4s var(--ease); }
.film-feature:hover img{ transform:scale(1.04); }
.film-feature .ff-scrim{ position:absolute; inset:0; background:linear-gradient(0deg, rgba(12,9,5,.8), rgba(12,9,5,.15) 55%), linear-gradient(90deg, rgba(12,9,5,.5), transparent 60%); }
@media (max-width:760px){ .film-grid{ grid-template-columns:1fr; } }

/* ============================================================
   GLOBAL LIFT — make every interior page read FULL, not empty
   (removes floating-card framing, enlarges imagery, full-bleeds
    galleries; per the immersive blueprint)
   ============================================================ */
/* Splits become substantial editorial pairings, not two floating halves */
.split{ align-items:stretch; gap:clamp(1.6rem,3.5vw,3.4rem); }
.split > *{ align-self:center; }
.split-media{ align-self:stretch; }
.split-media .accent-frame{ display:none; }            /* the offset frame WAS the empty space */
.split-media .frame{ border-radius:4px; box-shadow:0 26px 56px rgba(34,27,15,.16); height:100%; }
.split-media .frame img{ width:100%; height:100%; object-fit:cover; min-height:clamp(400px,40vw,580px); }
.split-media .tag-badge{ border-radius:3px; }

/* Asymmetry: give the photography more weight than the text column */
.section .split:not(.reverse), .section-sm .split:not(.reverse){ grid-template-columns:1.18fr .82fr; }
.section .split.reverse, .section-sm .split.reverse{ grid-template-columns:.82fr 1.18fr; }

/* Galleries break out edge-to-edge and pack denser into a wall */
.masonry{ position:relative; width:100vw; left:50%; right:50%; margin-left:-50vw; margin-right:-50vw;
  padding-inline:clamp(.8rem,1.6vw,1.6rem); columns:4; column-gap:clamp(.7rem,1vw,1.1rem); margin-top:2.6rem; }
.masonry .tile{ margin-bottom:clamp(.7rem,1vw,1.1rem); border-radius:4px; }
@media (max-width:1100px){ .masonry{ columns:3; } }
@media (max-width:760px){ .masonry{ columns:2; } }
@media (max-width:460px){ .masonry{ columns:1; padding-inline:1rem; } }

/* The grid of collection cards on cabinetry goes edge-to-edge too */
.section .grid.cols-3 .tile{ border-radius:4px; }

/* Page heroes get more presence */
.page-hero{ min-height:74vh; min-height:74svh; display:flex; align-items:flex-end; }
.page-hero .container{ padding-bottom:1rem; }
