/* =====================================================================
   HARTSTONE CONSTRUCTION — SHARED STYLESHEET
   index · services · about · projects · contact
   ===================================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* ── Dark base (the brand's weight) ── */
  --ink:#0B0C0D;
  --slate:#14171A;
  --steel:#1F2428;
  --graphite:#2A3036;
  --concrete:#444C54;
  --stone:#727A82;
  --fog:#A8AFB6;
  --mist:#D4D8DC;

  /* ── Warm off-white (text / backgrounds) ── */
  --paper:#F6F2EA;
  --bone:#EFE9DB;
  --linen:#E5DECC;
  --sand:#D5CCB6;

  /* ── Accents — burnt amber / brick ── */
  --amber:#D97706;
  --amber-bright:#F59E0B;
  --ember:#EA580C;
  --rust:#B45309;
  --brick:#9E2A2B;
  --amber-soft:#FCD9A8;

  /* ── Misc ── */
  --rule:rgba(11,12,13,0.10);
  --rule-strong:rgba(11,12,13,0.20);
  --rule-light:rgba(246,242,234,0.14);

  --display:'Archivo',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  --shadow:0 4px 24px rgba(11,12,13,0.10);
  --shadow-lg:0 24px 60px rgba(11,12,13,0.22);
  --shadow-amber:0 12px 40px rgba(217,119,6,0.28);

  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-smooth:cubic-bezier(0.4,0,0.2,1);
  --ease-soft:cubic-bezier(0.65,0,0.35,1);
  --ease-pop:cubic-bezier(0.34,1.56,0.64,1);

  --r-sm:3px;
  --r-md:6px;
  --r-lg:12px;

  --grad-slate:linear-gradient(180deg,#14171A 0%,#0B0C0D 100%);
  --grad-amber:linear-gradient(135deg,#EA580C 0%,#D97706 60%,#92400E 100%);
}

html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  letter-spacing:0.005em;
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--amber);color:var(--paper)}

/* Subtle paper grain overlay */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ========================================================================
   1.  TOP-LEFT BACK-TO-MTMN PILL
   ======================================================================== */
.mtmn-back{
  position:fixed;top:96px;left:24px;z-index:101;
  display:inline-flex;align-items:center;gap:9px;
  padding:9px 16px 9px 13px;
  background:rgba(20,23,26,0.78);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(217,119,6,0.30);
  border-radius:999px;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.32em;text-transform:uppercase;
  font-weight:500;
  color:var(--bone);
  box-shadow:0 4px 18px rgba(0,0,0,0.30);
  transition:border-color .35s var(--ease-out),transform .35s var(--ease-out),background .35s var(--ease-out);
}
.mtmn-back:hover{border-color:var(--amber-bright);transform:translateY(-1px);background:rgba(20,23,26,0.92)}
.mtmn-back-arrow{font-size:11px;letter-spacing:0;opacity:.65;transition:transform .3s var(--ease-out),opacity .3s var(--ease-out)}
.mtmn-back:hover .mtmn-back-arrow{transform:translateX(-3px);opacity:1}
.mtmn-back-dot{width:6px;height:6px;border-radius:50%;background:var(--amber-bright);box-shadow:0 0 10px rgba(245,158,11,0.7)}
@media(max-width:900px){
  .mtmn-back{top:auto;bottom:18px;left:18px;padding:8px 12px 8px 10px;font-size:8.5px;letter-spacing:.18em;gap:7px}
  .mtmn-back-dot{width:5px;height:5px}
}

/* ========================================================================
   2.  NAV
   ======================================================================== */
nav{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);
  z-index:100;width:96%;max-width:1500px;
  display:flex;justify-content:space-between;align-items:center;gap:36px;
  padding:12px 22px 12px 18px;
  background:rgba(11,12,13,0.78);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(246,242,234,0.10);
  border-radius:0;
  transition:
    width .65s var(--ease-out),
    background .55s var(--ease-out),
    box-shadow .55s var(--ease-out),
    border-color .55s var(--ease-out),
    padding .55s var(--ease-out);
  box-shadow:0 4px 24px rgba(0,0,0,0.30);
}
nav.scrolled{
  width:65%;
  background:rgba(11,12,13,0.62);
  backdrop-filter:blur(40px) saturate(1.4);
  -webkit-backdrop-filter:blur(40px) saturate(1.4);
  border-color:rgba(217,119,6,0.30);
  box-shadow:0 18px 46px rgba(0,0,0,0.45),inset 0 1px 0 rgba(255,255,255,0.06);
  padding:9px 18px 9px 14px;
}

.nav-brand{display:flex;align-items:center;gap:13px}
.nav-logo-mark{width:38px;height:38px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--amber);transition:background .4s var(--ease-out)}
nav:hover .nav-logo-mark{background:var(--amber-bright)}
.nav-logo-mark svg{width:22px;height:22px}
.nav-brand-text{display:flex;flex-direction:column;gap:0;line-height:1}
.nav-brand-name{font-family:var(--display);font-weight:800;font-size:14.5px;letter-spacing:0.01em;text-transform:uppercase;color:var(--paper)}
.nav-brand-sub{font-family:var(--mono);font-size:9.5px;letter-spacing:.24em;color:var(--fog);margin-top:4px;text-transform:uppercase}

nav ul{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  display:flex;gap:40px;list-style:none;
}
nav ul li a{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  color:var(--mist);
  position:relative;padding:6px 0;
  transition:color .3s var(--ease-out);
}
nav ul li a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--amber-bright);
  transition:width .4s var(--ease-out);
}
nav ul li a:hover{color:var(--paper)}
nav ul li a:hover::after,nav ul li a.active::after{width:100%}
nav ul li a.active{color:var(--amber-bright)}

.nav-cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:11px 20px;
  background:var(--amber);
  color:var(--ink);
  font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;font-weight:600;
  text-transform:uppercase;
  position:relative;overflow:hidden;
  transition:background .35s var(--ease-out),transform .35s var(--ease-out),box-shadow .35s var(--ease-out);
}
.nav-cta::before{
  content:"";position:absolute;inset:0;background:var(--amber-bright);
  transform:translateX(-101%);transition:transform .45s var(--ease-out);
}
.nav-cta span{position:relative;z-index:1}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(217,119,6,0.45)}
.nav-cta:hover::before{transform:translateX(0)}

@media(max-width:1000px){
  nav{gap:14px;padding:10px 16px}
  nav.scrolled{width:96%;padding:9px 14px}
  nav ul{display:none}
  .nav-cta{padding:9px 14px;font-size:9.5px;letter-spacing:.18em}
  .nav-brand-name{font-size:12.5px}
  .nav-brand-sub{font-size:8.5px}
}

/* ── Mobile menu trigger + panel (hidden on desktop) ── */
.nav-mobile-trigger,.nav-mobile-panel{display:none}

@media(max-width:1000px){
  .nav-mobile-trigger{
    display:inline-flex;
    position:fixed;top:80px;left:50%;transform:translateX(-50%);
    z-index:99;
    align-items:center;justify-content:center;gap:11px;
    padding:11px 22px;
    background:rgba(11,12,13,0.82);
    backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
    border:1px solid rgba(217,119,6,0.30);
    color:var(--paper);
    font-family:var(--mono);font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;font-weight:600;
    cursor:pointer;
    box-shadow:0 6px 20px rgba(0,0,0,0.32);
    transition:background .35s var(--ease-out),border-color .35s var(--ease-out);
  }
  .nav-mobile-trigger:hover,
  .nav-mobile-trigger[aria-expanded="true"]{
    border-color:var(--amber-bright);
    background:rgba(11,12,13,0.95);
  }
  .nav-mobile-chev{
    width:13px;height:13px;flex-shrink:0;
    transition:transform .35s var(--ease-out);
  }
  .nav-mobile-trigger[aria-expanded="true"] .nav-mobile-chev{transform:rotate(180deg)}

  .nav-mobile-panel{
    display:flex;flex-direction:column;
    position:fixed;top:128px;left:50%;
    transform:translateX(-50%) translateY(-12px);
    z-index:98;
    width:min(94%,360px);
    background:rgba(11,12,13,0.94);
    backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
    border:1px solid rgba(217,119,6,0.30);
    box-shadow:0 28px 60px rgba(0,0,0,0.50);
    opacity:0;pointer-events:none;
    transition:opacity .42s var(--ease-out),transform .42s var(--ease-out);
  }
  .nav-mobile-panel.open{
    opacity:1;pointer-events:auto;
    transform:translateX(-50%) translateY(0);
  }
  .nav-mobile-panel a{
    padding:16px 24px;
    font-family:var(--mono);font-size:12px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;
    color:var(--mist);
    border-top:1px solid rgba(246,242,234,0.08);
    transition:background .25s var(--ease-out),color .25s var(--ease-out),padding-left .25s var(--ease-out);
  }
  .nav-mobile-panel a:first-child{border-top:none}
  .nav-mobile-panel a:hover,
  .nav-mobile-panel a.active{
    background:rgba(217,119,6,0.10);
    color:var(--amber-bright);
    padding-left:34px;
  }
}

/* ========================================================================
   3.  HERO
   ======================================================================== */
.hero{
  position:relative;height:100vh;min-height:680px;
  display:flex;align-items:flex-end;justify-content:flex-start;
  overflow:hidden;background:var(--ink);
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;animation:slow-zoom 18s ease-out forwards}
@keyframes slow-zoom{
  from{transform:scale(1.08)}
  to{transform:scale(1.0)}
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(11,12,13,0.45) 0%,rgba(11,12,13,0.30) 35%,rgba(11,12,13,0.85) 100%),
    linear-gradient(90deg,rgba(11,12,13,0.55) 0%,rgba(11,12,13,0.10) 60%);
}
.hero-overlay::after{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(217,119,6,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(217,119,6,0.04) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at 70% 50%,black,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at 70% 50%,black,transparent 70%);
}

.hero-content{
  position:relative;z-index:2;
  max-width:1500px;width:96%;margin:0 auto;
  padding:0 28px 170px;color:var(--paper);
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;font-weight:500;
  color:var(--amber-bright);
  margin-bottom:30px;
  opacity:0;transform:translateY(14px);
  animation:hero-rise 0.8s var(--ease-out) 0.3s forwards;
}
.hero-eyebrow::before{content:"";width:46px;height:1px;background:var(--amber-bright)}

.hero h1{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(44px,7.8vw,128px);
  line-height:0.94;
  letter-spacing:-0.025em;
  text-transform:uppercase;
  margin-bottom:30px;
}
.hero h1 .h-line{display:block;overflow:hidden}
.hero h1 .h-word{
  display:inline-block;
  transform:translateY(110%);
  animation:hero-word-up 0.95s var(--ease-out) forwards;
}
.hero h1 .h-line:nth-child(1) .h-word{animation-delay:0.45s}
.hero h1 .h-line:nth-child(2) .h-word{animation-delay:0.55s}
.hero h1 .h-line:nth-child(3) .h-word{animation-delay:0.65s}
.hero h1 em{font-style:normal;color:var(--amber-bright);font-weight:900}

@keyframes hero-word-up{to{transform:translateY(0)}}
@keyframes hero-rise{to{opacity:1;transform:translateY(0)}}

.hero-lede{
  max-width:540px;
  font-size:17px;line-height:1.6;color:var(--mist);font-weight:300;
  margin-bottom:38px;
  opacity:0;transform:translateY(14px);
  animation:hero-rise 0.8s var(--ease-out) 1.0s forwards;
}

.hero-actions{
  display:flex;gap:14px;flex-wrap:wrap;
  opacity:0;transform:translateY(14px);
  animation:hero-rise 0.8s var(--ease-out) 1.15s forwards;
}

/* Buttons */
.btn-primary{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 28px;
  background:var(--amber);color:var(--ink);
  font-family:var(--mono);font-size:11.5px;letter-spacing:.22em;font-weight:600;text-transform:uppercase;
  position:relative;overflow:hidden;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out);
}
.btn-primary::before{content:"";position:absolute;inset:0;background:var(--amber-bright);transform:translateX(-101%);transition:transform .45s var(--ease-out)}
.btn-primary > *{position:relative;z-index:1}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 38px rgba(217,119,6,0.45)}
.btn-primary:hover::before{transform:translateX(0)}
.btn-primary .arrow{transition:transform .4s var(--ease-out)}
.btn-primary:hover .arrow{transform:translateX(5px)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 28px;
  background:transparent;color:var(--paper);
  font-family:var(--mono);font-size:11.5px;letter-spacing:.22em;font-weight:600;text-transform:uppercase;
  border:1px solid rgba(246,242,234,0.30);
  transition:border-color .35s var(--ease-out),background .35s var(--ease-out),color .35s var(--ease-out);
}
.btn-ghost:hover{border-color:var(--amber-bright);background:rgba(217,119,6,0.10);color:var(--amber-bright)}

.btn-ink{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 28px;
  background:var(--ink);color:var(--paper);
  font-family:var(--mono);font-size:11.5px;letter-spacing:.22em;font-weight:600;text-transform:uppercase;
  position:relative;overflow:hidden;
  transition:transform .35s var(--ease-out);
}
.btn-ink::before{content:"";position:absolute;inset:0;background:var(--amber);transform:translateX(-101%);transition:transform .45s var(--ease-out)}
.btn-ink > *{position:relative;z-index:1;transition:color .3s var(--ease-out)}
.btn-ink:hover::before{transform:translateX(0)}
.btn-ink:hover > *{color:var(--ink)}
.btn-ink:hover{transform:translateY(-2px);box-shadow:0 18px 38px rgba(11,12,13,0.30)}

/* Hero scroll cue (sits above the trust strip) */
.hero-scroll{
  position:absolute;bottom:130px;right:42px;z-index:3;
  display:flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--fog);
  opacity:0;animation:hero-rise 0.8s var(--ease-out) 1.4s forwards;
}
@media(max-width:900px){.hero-scroll{display:none}}
.hero-scroll-line{width:60px;height:1px;background:var(--fog);position:relative;overflow:hidden}
.hero-scroll-line::after{content:"";position:absolute;inset:0;background:var(--amber-bright);animation:scroll-line 2.4s ease-in-out infinite}
@keyframes scroll-line{
  0%{transform:translateX(-100%)}
  60%,100%{transform:translateX(100%)}
}

/* Hero trust strip */
.hero-trust{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  border-top:1px solid rgba(246,242,234,0.10);
  background:rgba(11,12,13,0.6);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.hero-trust-inner{
  max-width:1500px;width:96%;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
}
.hero-trust-item{
  padding:22px 28px;
  border-left:1px solid rgba(246,242,234,0.10);
  display:flex;flex-direction:column;gap:6px;
}
.hero-trust-item:first-child{border-left:none}
.hero-trust-num{font-family:var(--display);font-weight:800;font-size:30px;letter-spacing:-0.02em;color:var(--amber-bright);line-height:1}
.hero-trust-num em{font-style:normal;color:var(--paper);font-size:18px;margin-left:4px}
.hero-trust-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--fog)}
@media(max-width:900px){
  .hero-trust-inner{grid-template-columns:repeat(2,1fr)}
  .hero-trust-item{padding:16px 20px}
  .hero-trust-item:nth-child(3){border-left:none}
  .hero-trust-item:nth-child(odd){border-top:none}
  .hero-trust-num{font-size:24px}
  .hero-content{padding:0 20px 220px}
}

/* ========================================================================
   4.  REVEAL ON SCROLL
   ======================================================================== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.in-view{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal-stagger.in-view > *:nth-child(1){transition-delay:0.05s}
.reveal-stagger.in-view > *:nth-child(2){transition-delay:0.13s}
.reveal-stagger.in-view > *:nth-child(3){transition-delay:0.21s}
.reveal-stagger.in-view > *:nth-child(4){transition-delay:0.29s}
.reveal-stagger.in-view > *:nth-child(5){transition-delay:0.37s}
.reveal-stagger.in-view > *:nth-child(6){transition-delay:0.45s}
.reveal-stagger.in-view > *{opacity:1;transform:translateY(0)}

/* ========================================================================
   5.  COMMON SECTION + HEADERS
   ======================================================================== */
section{position:relative;z-index:2}
.section-inner{max-width:1500px;width:96%;margin:0 auto;padding:120px 28px}
.section-inner.tight{padding:80px 28px}
.section-dark{background:var(--ink);color:var(--paper)}
.section-slate{background:var(--slate);color:var(--paper)}
.section-bone{background:var(--bone)}
.section-paper{background:var(--paper)}

.section-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;font-weight:500;
  color:var(--amber);
  margin-bottom:24px;
}
.section-eyebrow::before{content:"";width:38px;height:1px;background:currentColor}
.section-dark .section-eyebrow,.section-slate .section-eyebrow{color:var(--amber-bright)}

.section-title{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(34px,5.4vw,72px);
  line-height:1.0;
  letter-spacing:-0.025em;
  text-transform:uppercase;
  margin-bottom:24px;
  max-width:18ch;
}
.section-title em{font-style:normal;color:var(--amber);font-weight:900}
.section-dark .section-title em,.section-slate .section-title em{color:var(--amber-bright)}

.section-lede{font-size:16.5px;line-height:1.7;max-width:62ch;color:var(--concrete);font-weight:400}
.section-dark .section-lede,.section-slate .section-lede{color:var(--mist)}

.section-header{margin-bottom:64px;display:flex;justify-content:space-between;align-items:flex-end;gap:60px;flex-wrap:wrap}
.section-header > div:first-child{flex:1;min-width:300px}

.section-link{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;font-weight:600;
  color:var(--ink);padding-bottom:6px;
  border-bottom:1px solid var(--ink);
  transition:color .3s var(--ease-out),border-color .3s var(--ease-out),padding-right .3s var(--ease-out);
}
.section-link:hover{color:var(--amber);border-color:var(--amber);padding-right:6px}
.section-dark .section-link,.section-slate .section-link{color:var(--paper);border-color:var(--paper)}
.section-dark .section-link:hover,.section-slate .section-link:hover{color:var(--amber-bright);border-color:var(--amber-bright)}

/* Generic page header for sub-pages */
.page-header{
  position:relative;
  background:var(--ink);color:var(--paper);
  padding:200px 28px 100px;
  overflow:hidden;
  border-bottom:1px solid rgba(246,242,234,0.10);
}
.page-header::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(217,119,6,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(217,119,6,0.05) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at 80% 50%,black,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at 80% 50%,black,transparent 75%);
}
.page-header-inner{position:relative;max-width:1500px;width:100%;margin:0 auto}
.page-header h1{
  font-family:var(--display);font-weight:900;
  font-size:clamp(48px,7vw,108px);line-height:0.95;letter-spacing:-0.025em;text-transform:uppercase;
  margin-bottom:18px;
}
.page-header h1 em{font-style:normal;color:var(--amber-bright)}
.page-header p{font-size:18px;color:var(--mist);max-width:62ch;line-height:1.6;font-weight:300}
.page-header .crumbs{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--fog);
  margin-bottom:32px;
}
.page-header .crumbs span{color:var(--amber-bright)}

/* ========================================================================
   6.  SERVICES — card grid
   ======================================================================== */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule-strong);border-left:1px solid var(--rule-strong)}
.section-dark .services-grid,.section-slate .services-grid{border-color:var(--rule-light)}

.service-card{
  position:relative;
  padding:48px 38px 44px;
  background:transparent;
  border-right:1px solid var(--rule-strong);
  border-bottom:1px solid var(--rule-strong);
  cursor:pointer;
  overflow:hidden;
  --mx:50%;--my:50%;
  transition:background .5s var(--ease-out);
}
.section-dark .service-card,.section-slate .service-card{border-color:var(--rule-light)}

.service-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(380px circle at var(--mx) var(--my),rgba(217,119,6,0.16),transparent 65%);
  opacity:0;transition:opacity .55s var(--ease-out);
  pointer-events:none;
}
.service-card:hover::before{opacity:1}
.service-card:hover{background:rgba(11,12,13,0.02)}
.section-dark .service-card:hover,.section-slate .service-card:hover{background:rgba(217,119,6,0.04)}

.service-icon{
  width:56px;height:56px;display:flex;align-items:center;justify-content:center;
  background:var(--ink);color:var(--amber-bright);
  margin-bottom:32px;
  transition:background .4s var(--ease-out),transform .5s var(--ease-out);
}
.section-dark .service-icon,.section-slate .service-icon{background:var(--amber);color:var(--ink)}
.service-card:hover .service-icon{background:var(--amber);color:var(--ink);transform:rotate(-4deg) scale(1.05)}
.service-icon svg{width:28px;height:28px}

.service-num{
  position:absolute;top:32px;right:32px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--stone);
}
.service-title{
  font-family:var(--display);font-weight:800;font-size:24px;letter-spacing:-0.01em;line-height:1.1;
  text-transform:uppercase;
  margin-bottom:14px;
}
.service-blurb{font-size:14.5px;line-height:1.65;color:var(--concrete);margin-bottom:28px}
.section-dark .service-blurb,.section-slate .service-blurb{color:var(--mist)}
.service-link{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;letter-spacing:.26em;text-transform:uppercase;font-weight:600;
  color:var(--amber);
}
.service-card:hover .service-link{color:var(--amber-bright)}
.service-link .arrow{transition:transform .4s var(--ease-out)}
.service-card:hover .service-link .arrow{transform:translateX(6px)}

@media(max-width:1100px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.services-grid{grid-template-columns:1fr}.service-card{padding:36px 26px 32px}}

/* Services detail (services.html) — wide rows */
.service-row{
  display:grid;grid-template-columns:0.8fr 1.6fr 1fr;gap:60px;
  padding:64px 0;border-bottom:1px solid var(--rule);
  align-items:start;
}
.service-row:last-child{border-bottom:none}
.service-row-num{
  font-family:var(--display);font-weight:900;font-size:80px;letter-spacing:-0.04em;line-height:1;
  color:var(--ink);
  -webkit-text-stroke:1.5px var(--ink);
  color:transparent;
}
.service-row-body h3{
  font-family:var(--display);font-weight:800;font-size:38px;line-height:1;letter-spacing:-0.02em;text-transform:uppercase;
  margin-bottom:18px;
}
.service-row-body h3 em{font-style:normal;color:var(--amber)}
.service-row-body p{font-size:15.5px;line-height:1.75;color:var(--concrete);margin-bottom:18px;max-width:55ch}
.service-row-body ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;margin-top:20px}
.service-row-body ul li{font-size:14px;color:var(--graphite);padding-left:22px;position:relative}
.service-row-body ul li::before{content:"";position:absolute;left:0;top:9px;width:12px;height:1px;background:var(--amber)}
.service-row-img{
  position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--steel);
}
.service-row-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s var(--ease-out)}
.service-row:hover .service-row-img img{transform:scale(1.06)}
@media(max-width:1100px){.service-row{grid-template-columns:1fr}.service-row-num{font-size:64px}}

/* ========================================================================
   7.  STATS BAND (gradient, dark)
   ======================================================================== */
.stats-band{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.stats-band::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 12% 20%,rgba(234,88,12,0.18),transparent 50%),radial-gradient(circle at 90% 80%,rgba(217,119,6,0.14),transparent 55%);
}
.stats-band-inner{
  position:relative;max-width:1500px;width:96%;margin:0 auto;padding:80px 28px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
}
.stats-band-inner > div{
  padding:0 28px;border-left:1px solid rgba(246,242,234,0.10);
}
.stats-band-inner > div:first-child{border-left:none;padding-left:0}
.stats-band .stat-num{
  font-family:var(--display);font-weight:900;font-size:clamp(54px,6vw,84px);letter-spacing:-0.04em;line-height:0.95;
  color:var(--amber-bright);margin-bottom:14px;
}
.stats-band .stat-num em{font-style:normal;color:var(--paper);font-size:0.5em;margin-left:6px;font-weight:800}
.stats-band .stat-label{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mist)}
@media(max-width:900px){
  .stats-band-inner{grid-template-columns:repeat(2,1fr);gap:40px 0}
  .stats-band-inner > div{padding:0 20px}
  .stats-band-inner > div:nth-child(3){border-left:none;padding-left:0}
}

/* ========================================================================
   8.  WHY CHOOSE US — feature grid
   ======================================================================== */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px}
.why-item{position:relative;padding-top:24px;border-top:2px solid var(--ink);transition:border-color .35s var(--ease-out)}
.why-item:hover{border-top-color:var(--amber)}
.why-icon{
  width:48px;height:48px;display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;color:var(--amber);
  transition:transform .5s var(--ease-out);
}
.why-item:hover .why-icon{transform:translateY(-3px)}
.why-icon svg{width:34px;height:34px}
.why-title{font-family:var(--display);font-weight:800;font-size:18px;letter-spacing:0;line-height:1.2;text-transform:uppercase;margin-bottom:10px}
.why-blurb{font-size:14px;line-height:1.6;color:var(--concrete)}
@media(max-width:1000px){.why-grid{grid-template-columns:repeat(2,1fr);gap:36px}}

/* ========================================================================
   9.  PROCESS — How it works
   ======================================================================== */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.process::before{
  content:"";position:absolute;left:0;right:0;top:42px;height:1px;
  background:linear-gradient(90deg,transparent,var(--rule-strong) 5%,var(--rule-strong) 95%,transparent);
}
.section-dark .process::before,.section-slate .process::before{background:linear-gradient(90deg,transparent,var(--rule-light) 5%,var(--rule-light) 95%,transparent)}
.process-step{padding:0 24px;position:relative}
.process-step:first-child{padding-left:0}
.process-step:last-child{padding-right:0}

.process-num{
  width:84px;height:84px;
  display:flex;align-items:center;justify-content:center;
  background:var(--paper);border:1px solid var(--rule-strong);
  font-family:var(--display);font-weight:900;font-size:30px;color:var(--ink);
  margin-bottom:28px;
  position:relative;z-index:2;
  transition:background .4s var(--ease-out),color .4s var(--ease-out),border-color .4s var(--ease-out);
}
.section-dark .process-num,.section-slate .process-num{background:var(--ink);color:var(--paper);border-color:var(--rule-light)}
.process-step:hover .process-num{background:var(--amber);color:var(--ink);border-color:var(--amber)}

.process-label{font-family:var(--mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--amber);margin-bottom:8px}
.section-dark .process-label,.section-slate .process-label{color:var(--amber-bright)}
.process-title{font-family:var(--display);font-weight:800;font-size:22px;line-height:1.15;text-transform:uppercase;letter-spacing:-0.005em;margin-bottom:14px}
.process-blurb{font-size:14px;line-height:1.65;color:var(--concrete)}
.section-dark .process-blurb,.section-slate .process-blurb{color:var(--mist)}

@media(max-width:1000px){
  .process{grid-template-columns:1fr;gap:40px}
  .process::before{display:none}
  .process-step{padding:0;border-left:2px solid var(--rule-strong);padding-left:24px}
}

/* ========================================================================
   10.  PROJECTS GALLERY
   ======================================================================== */
.gallery-filter{
  display:flex;gap:8px;flex-wrap:wrap;margin-bottom:48px;
}
.filter-btn{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  padding:11px 18px;
  border:1px solid var(--rule-strong);
  color:var(--graphite);
  background:transparent;
  transition:background .3s var(--ease-out),color .3s var(--ease-out),border-color .3s var(--ease-out);
}
.filter-btn:hover{border-color:var(--amber);color:var(--amber)}
.filter-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.gallery-card{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--steel);
  cursor:pointer;
  transition:opacity .5s var(--ease-out),transform .5s var(--ease-out);
}
.gallery-card.hidden{
  display:none;
}
.gallery-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s var(--ease-out),filter .6s var(--ease-out);
  filter:grayscale(0.15) contrast(1.05);
}
.gallery-card:hover img{transform:scale(1.07);filter:grayscale(0) contrast(1.05)}
.gallery-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(11,12,13,0.85) 100%);
  pointer-events:none;
}
.gallery-card-info{
  position:absolute;left:24px;right:24px;bottom:22px;
  color:var(--paper);
  transform:translateY(8px);
  transition:transform .5s var(--ease-out);
}
.gallery-card:hover .gallery-card-info{transform:translateY(0)}
.gallery-card-tag{
  display:inline-block;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;font-weight:600;
  color:var(--amber-bright);
  margin-bottom:10px;
  padding:5px 9px;background:rgba(11,12,13,0.55);
}
.gallery-card-title{
  font-family:var(--display);font-weight:800;font-size:22px;line-height:1.15;text-transform:uppercase;
}
.gallery-card-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;color:var(--mist);margin-top:6px}

.gallery-card-tall{grid-row:span 2;aspect-ratio:auto}
@media(max-width:1000px){.gallery-grid{grid-template-columns:repeat(2,1fr)}.gallery-card-tall{grid-row:auto;aspect-ratio:4/5}}
@media(max-width:600px){.gallery-grid{grid-template-columns:1fr}}

/* Before / After slider */
.ba-wrap{
  margin-top:96px;padding:80px 0 0;border-top:1px solid var(--rule);
}
.ba-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;gap:40px;flex-wrap:wrap}
.ba-slider{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  overflow:hidden;
  user-select:none;
  background:var(--steel);
  cursor:ew-resize;
}
.ba-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba-after{clip-path:inset(0 0 0 50%)}
.ba-handle{
  position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--paper);
  transform:translateX(-50%);
  pointer-events:none;
  box-shadow:0 0 0 1px rgba(11,12,13,0.30);
}
.ba-handle::before{
  content:"";position:absolute;top:50%;left:50%;
  width:48px;height:48px;
  background:var(--amber);
  transform:translate(-50%,-50%) rotate(45deg);
  box-shadow:0 6px 20px rgba(0,0,0,0.30);
}
.ba-handle::after{
  content:"⇄";position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  color:var(--ink);font-weight:900;font-size:18px;
  font-family:var(--display);letter-spacing:-0.03em;
  pointer-events:none;
}
.ba-tag{
  position:absolute;top:18px;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;font-weight:600;
  background:var(--ink);color:var(--paper);
  padding:7px 12px;
  z-index:2;
}
.ba-tag.before{left:18px}
.ba-tag.after{right:18px;background:var(--amber);color:var(--ink)}

/* ========================================================================
   11.  TESTIMONIALS CAROUSEL
   ======================================================================== */
.testimonials{background:var(--ink);color:var(--paper);overflow:hidden}
.testimonials-inner{max-width:1500px;width:96%;margin:0 auto;padding:120px 28px}

.testimonial-carousel-wrap{position:relative;max-width:1100px;margin:0 auto;padding:0 80px}
.testimonial-track{position:relative;height:280px}
.testimonial-slide{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:center;
  padding:0 20px;
  text-align:center;
}
.testimonial-qmark{
  font-family:var(--display);font-weight:900;font-size:120px;line-height:0.8;
  color:var(--amber);opacity:0.4;
  margin-bottom:0;
}
.testimonial-quote{
  font-family:var(--display);font-weight:500;
  font-size:clamp(20px,2.4vw,30px);
  line-height:1.4;letter-spacing:-0.005em;
  color:var(--paper);
  margin-bottom:36px;
}
.testimonial-author{display:flex;flex-direction:column;align-items:center;gap:6px}
.testimonial-name{font-family:var(--display);font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--paper)}
.testimonial-meta{font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--fog);text-transform:uppercase}

.testimonial-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:50px;height:50px;
  border:1px solid rgba(246,242,234,0.20);
  background:transparent;
  display:flex;align-items:center;justify-content:center;
  color:var(--paper);
  transition:background .3s var(--ease-out),border-color .3s var(--ease-out),color .3s var(--ease-out),transform .3s var(--ease-out);
  z-index:2;
}
.testimonial-btn:hover{background:var(--amber);border-color:var(--amber);color:var(--ink);transform:translateY(-50%) scale(1.05)}
.testimonial-btn-prev{left:0}
.testimonial-btn-next{right:0}

.testimonial-dots{display:flex;justify-content:center;gap:8px;margin-top:50px}
.testimonial-dot{width:32px;height:2px;background:rgba(246,242,234,0.20);transition:background .3s var(--ease-out)}
.testimonial-dot.dot-active{background:var(--amber-bright)}

/* Google rating chip */
.gmb-chip{
  display:inline-flex;align-items:center;gap:14px;
  margin-top:30px;
  padding:13px 22px;
  border:1px solid rgba(246,242,234,0.20);
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mist);
}
.gmb-chip strong{color:var(--paper);font-weight:600}
.gmb-stars{color:var(--amber-bright);letter-spacing:0.1em;font-size:12px}

@media(max-width:700px){
  .testimonial-carousel-wrap{padding:0 0 60px}
  .testimonial-btn{top:auto;bottom:0;transform:none}
  .testimonial-btn-prev{left:36%}
  .testimonial-btn-next{right:36%}
  .testimonial-dots{display:none}
}

/* ========================================================================
   12.  ACCREDITATIONS MARQUEE
   ======================================================================== */
.accred-strip{
  background:var(--bone);
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:28px 0;
  overflow:hidden;
}
.accred-track{
  display:flex;gap:80px;align-items:center;
  animation:accred-scroll 32s linear infinite;
  width:max-content;
}
.accred-strip:hover .accred-track{animation-play-state:paused}
.accred-item{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  color:var(--graphite);
  white-space:nowrap;
  flex-shrink:0;
}
.accred-item svg{width:28px;height:28px;color:var(--amber);flex-shrink:0}
@keyframes accred-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ========================================================================
   13.  CTA BAND (full / dark)
   ======================================================================== */
.cta-band{
  background:var(--ink);color:var(--paper);position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 0% 100%,rgba(234,88,12,0.22),transparent 50%),
    radial-gradient(circle at 100% 0%,rgba(217,119,6,0.12),transparent 50%);
}
.cta-band-inner{
  position:relative;max-width:1500px;width:96%;margin:0 auto;
  padding:120px 28px;
  display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:center;
}
.cta-band-left h2{
  font-family:var(--display);font-weight:900;font-size:clamp(42px,5.6vw,80px);line-height:0.95;letter-spacing:-0.025em;text-transform:uppercase;
  margin-bottom:24px;
}
.cta-band-left h2 em{font-style:normal;color:var(--amber-bright)}
.cta-band-left p{color:var(--mist);font-size:17px;line-height:1.65;font-weight:300;max-width:54ch;margin-bottom:36px}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap}

.cta-quote-card{
  background:rgba(246,242,234,0.04);
  border:1px solid rgba(246,242,234,0.12);
  padding:38px 32px;
}
.cta-quote-card .label{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--amber-bright);margin-bottom:18px}
.cta-quote-card .phone{font-family:var(--display);font-weight:800;font-size:36px;letter-spacing:-0.01em;color:var(--paper);display:block;margin-bottom:22px;transition:color .3s var(--ease-out)}
.cta-quote-card .phone:hover{color:var(--amber-bright)}
.cta-quote-row{display:flex;justify-content:space-between;padding:11px 0;border-top:1px solid rgba(246,242,234,0.10);font-size:13px}
.cta-quote-row span:first-child{font-family:var(--mono);font-size:10.5px;letter-spacing:.20em;text-transform:uppercase;color:var(--fog)}
.cta-quote-row span:last-child{color:var(--paper);font-weight:500}

@media(max-width:1000px){
  .cta-band-inner{grid-template-columns:1fr;gap:48px}
}

/* ========================================================================
   14.  FORM (contact page)
   ======================================================================== */
.form-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:80px;align-items:start}
@media(max-width:1000px){.form-grid{grid-template-columns:1fr;gap:48px}}

.q-form{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.q-form .full{grid-column:1/-1}
.q-field{display:flex;flex-direction:column;gap:8px;position:relative}
.q-field label{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--graphite);
}
.q-field label .req{color:var(--amber);margin-left:4px}
.q-field input,.q-field select,.q-field textarea{
  font-family:var(--body);font-size:15px;
  padding:14px 16px;
  background:var(--paper);
  border:1px solid var(--rule-strong);
  color:var(--ink);
  border-radius:0;
  transition:border-color .3s var(--ease-out),background .3s var(--ease-out),box-shadow .3s var(--ease-out);
}
.q-field textarea{resize:vertical;min-height:130px;font-family:var(--body)}
.q-field input:focus,.q-field select:focus,.q-field textarea:focus{
  outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(217,119,6,0.16);
}
.q-field select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%230B0C0D' stroke-width='1.6' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 18px center;padding-right:42px}

.q-submit{
  grid-column:1/-1;
  margin-top:8px;
}

.contact-side{
  background:var(--ink);color:var(--paper);
  padding:48px 36px;
}
.contact-side .title{
  font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-0.005em;text-transform:uppercase;
  margin-bottom:24px;
}
.contact-side .row{
  display:flex;flex-direction:column;gap:6px;
  padding:18px 0;border-top:1px solid rgba(246,242,234,0.12);
}
.contact-side .row:first-of-type{border-top:none;padding-top:0}
.contact-side .row .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--fog)}
.contact-side .row .val{font-family:var(--display);font-weight:700;font-size:18px;color:var(--paper);transition:color .3s var(--ease-out)}
.contact-side .row a.val:hover{color:var(--amber-bright)}

.contact-map{
  margin-top:24px;
  aspect-ratio:4/3;background:var(--steel);
  border:1px solid rgba(246,242,234,0.10);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.contact-map iframe{width:100%;height:100%;border:0;filter:grayscale(0.3) contrast(1.1) invert(0.92) hue-rotate(180deg)}

/* ========================================================================
   15.  FAQ
   ======================================================================== */
.faq-list{border-top:1px solid var(--rule-strong)}
.faq-item{
  border-bottom:1px solid var(--rule-strong);
  cursor:pointer;
}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:32px;
  padding:28px 0;
  font-family:var(--display);font-weight:700;font-size:20px;letter-spacing:-0.005em;
  text-transform:uppercase;
  color:var(--ink);
  transition:color .3s var(--ease-out);
}
.faq-item:hover .faq-q{color:var(--amber)}
.faq-toggle{
  flex-shrink:0;
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--rule-strong);
  position:relative;
  transition:background .3s var(--ease-out),border-color .3s var(--ease-out),transform .3s var(--ease-out);
}
.faq-toggle::before,.faq-toggle::after{
  content:"";position:absolute;background:var(--ink);transition:transform .35s var(--ease-out),background .35s var(--ease-out);
}
.faq-toggle::before{width:14px;height:1.5px}
.faq-toggle::after{width:1.5px;height:14px}
.faq-item.open .faq-toggle{background:var(--amber);border-color:var(--amber)}
.faq-item.open .faq-toggle::before,.faq-item.open .faq-toggle::after{background:var(--ink)}
.faq-item.open .faq-toggle::after{transform:scaleY(0)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .5s var(--ease-out),opacity .4s var(--ease-out);
  opacity:0;
}
.faq-item.open .faq-a{max-height:400px;opacity:1}
.faq-a-inner{padding-bottom:28px;color:var(--concrete);font-size:15px;line-height:1.7;max-width:72ch}

/* ========================================================================
   16.  ABOUT — split block
   ======================================================================== */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-split-img{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--steel)}
.about-split-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.1) contrast(1.05);transition:transform 1.6s var(--ease-out)}
.about-split:hover .about-split-img img{transform:scale(1.04)}
.about-split-img::after{
  content:"";position:absolute;inset:auto 0 0 0;height:50%;
  background:linear-gradient(180deg,transparent,rgba(11,12,13,0.30));
}
.about-split-tag{
  position:absolute;left:24px;bottom:24px;
  background:var(--amber);color:var(--ink);
  padding:10px 16px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
}
.about-block-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--amber);margin-bottom:18px;font-weight:500}
.about-block-title{font-family:var(--display);font-weight:800;font-size:clamp(34px,4.6vw,56px);line-height:0.98;letter-spacing:-0.02em;text-transform:uppercase;margin-bottom:24px}
.about-block-title em{font-style:normal;color:var(--amber)}
.about-block-body p{font-size:15.5px;line-height:1.75;color:var(--graphite);margin-bottom:18px}

@media(max-width:1000px){.about-split{grid-template-columns:1fr;gap:48px}}

/* Values list */
.values-list{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--rule-strong)}
.value-item{padding:32px 36px 32px 0;border-bottom:1px solid var(--rule-strong);position:relative}
.value-item:nth-child(even){padding-left:36px;padding-right:0;border-left:1px solid var(--rule-strong)}
.value-num{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--amber);font-weight:600}
.value-title{font-family:var(--display);font-weight:800;font-size:22px;line-height:1.1;text-transform:uppercase;margin:14px 0 10px}
.value-blurb{font-size:14.5px;line-height:1.7;color:var(--concrete)}
@media(max-width:700px){.values-list{grid-template-columns:1fr}.value-item:nth-child(even){padding-left:0;border-left:none}}

/* Team grid */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.team-card{position:relative;cursor:pointer}
.team-img{aspect-ratio:3/4;overflow:hidden;background:var(--steel);position:relative;margin-bottom:18px}
.team-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.4) contrast(1.05);transition:filter .8s var(--ease-out),transform 1.4s var(--ease-out)}
.team-card:hover .team-img img{filter:grayscale(0) contrast(1.05);transform:scale(1.04)}
.team-img::after{
  content:"";position:absolute;inset:auto 0 0 0;height:60%;
  background:linear-gradient(180deg,transparent,rgba(11,12,13,0.55));
  opacity:0;transition:opacity .5s var(--ease-out);
}
.team-card:hover .team-img::after{opacity:1}
.team-name{font-family:var(--display);font-weight:800;font-size:19px;line-height:1.1;text-transform:uppercase;margin-bottom:5px}
.team-role{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--amber);font-weight:600}
@media(max-width:900px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.team-grid{grid-template-columns:1fr}}

/* ========================================================================
   17.  FOOTER
   ======================================================================== */
footer{
  background:var(--ink);color:var(--paper);
  padding:90px 28px 40px;
  position:relative;
  border-top:1px solid rgba(246,242,234,0.08);
}
.footer-mark{
  display:flex;justify-content:space-between;align-items:flex-end;gap:30px;
  padding-bottom:60px;border-bottom:1px solid rgba(246,242,234,0.10);margin-bottom:60px;flex-wrap:wrap;
}
.footer-mark-logo{display:flex;align-items:center;gap:18px}
.footer-mark-logo .mark{width:54px;height:54px;background:var(--amber);display:flex;align-items:center;justify-content:center}
.footer-mark-logo .mark svg{width:30px;height:30px;color:var(--ink)}
.footer-brand-name{font-family:var(--display);font-weight:900;font-size:30px;letter-spacing:-0.015em;text-transform:uppercase;line-height:1}
.footer-brand-sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--fog);margin-top:8px}
.footer-tagline{
  font-family:var(--display);font-weight:500;font-size:18px;line-height:1.4;color:var(--mist);max-width:32ch;text-align:right;
}
.footer-tagline em{color:var(--amber-bright);font-style:normal;font-weight:700}

.footer-cols{
  max-width:1500px;width:100%;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:60px;
  padding-bottom:60px;border-bottom:1px solid rgba(246,242,234,0.10);
}
.footer-col-label{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--amber-bright);font-weight:600;
  margin-bottom:22px;
}
.footer-col p{font-size:14px;line-height:1.7;color:var(--mist);font-weight:300}
.footer-col a{
  display:block;font-size:14.5px;color:var(--mist);
  padding:7px 0;
  transition:color .3s var(--ease-out),padding-left .3s var(--ease-out);
}
.footer-col a:hover{color:var(--amber-bright);padding-left:6px}
.footer-contact{font-size:14.5px;color:var(--mist);padding:5px 0;display:block}
.footer-contact a{display:inline;padding:0}
.footer-contact a:hover{padding-left:0}

.footer-bottom{
  max-width:1500px;width:100%;margin:0 auto;padding-top:30px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
}
.footer-copy{font-family:var(--mono);font-size:10.5px;letter-spacing:.20em;text-transform:uppercase;color:var(--fog)}
.footer-creg{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--stone)}
.footer-badges{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.footer-badge{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  padding:7px 12px;
  border:1px solid rgba(246,242,234,0.16);
  color:var(--mist);
}

@media(max-width:1000px){
  .footer-cols{grid-template-columns:1fr 1fr;gap:40px}
  .footer-tagline{text-align:left}
  .footer-mark{flex-direction:column;align-items:flex-start;gap:24px}
}
@media(max-width:600px){.footer-cols{grid-template-columns:1fr}}

/* ========================================================================
   18.  MOBILE CALL FAB
   ======================================================================== */
.mobile-call-fab{
  display:none;
  position:fixed;bottom:18px;right:18px;z-index:99;
  background:var(--amber);color:var(--ink);
  padding:13px 18px;
  font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  align-items:center;gap:10px;
  box-shadow:0 8px 28px rgba(217,119,6,0.50);
}
@media(max-width:900px){.mobile-call-fab{display:inline-flex}}
