
:root{
  --obsidian:#000;
  --ink:#070708;
  --steel:#101216;
  --line:#1a1c20;
  --line-2:#252830;
  --muted:#7a7f86;
  --chrome:#b0b4ba;
  --silver:#dadcdf;
  --platinum:#f5f5f7;
  --brass:#b89968;
  --brass-soft:rgba(184,153,104,.5);
  --display:"Bodoni Moda",Georgia,"Times New Roman",serif;
  --body:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--obsidian);
  color:var(--silver);
  font-family:var(--body);
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ========== Promo bar ========== */
.promo-bar{
  background:var(--ink);
  border-bottom:1px solid var(--line);
  color:var(--chrome);
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-weight:500;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  padding:16px 24px;
  text-align:center;
}
.promo-bar .dot{
  display:inline-block;
  width:5px;height:5px;
  background:var(--brass);
}
@media(max-width:680px){
  .promo-bar{padding:13px 14px;font-size:9.5px;gap:10px;letter-spacing:.18em}
  .promo-bar .dot{width:4px;height:4px}
}

/* ========== Nav ========== */
.nav{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(0,0,0,.78);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 40px;
  gap:24px;
}
.wordmark{
  font-family:var(--display);
  font-weight:500;
  font-size:22px;
  letter-spacing:-.01em;
  color:var(--platinum);
  line-height:1;
}
.wordmark em{
  font-style:italic;
  color:var(--brass);
  font-weight:500;
}
.nav-links{
  list-style:none;
  display:flex;
  gap:38px;
}
.nav-links a{
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--silver);
  position:relative;
  padding:6px 0;
  transition:color .3s ease;
}
.nav-links a::after{
  content:"";
  position:absolute;
  bottom:0;left:0;
  width:100%;
  height:1px;
  background:var(--brass);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s ease;
}
.nav-links a:hover{color:var(--platinum)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-phone{
  font-family:var(--display);
  font-size:18px;
  font-weight:500;
  color:var(--platinum);
  letter-spacing:.02em;
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  gap:12px;
  transition:color .3s ease;
}
.nav-phone::before{
  content:"";
  display:inline-block;
  width:5px;height:5px;
  background:var(--brass);
}
.nav-phone:hover{color:var(--brass)}
@media(max-width:920px){
  .nav{padding:14px 22px}
  .nav-links{display:none}
  .wordmark{font-size:19px;font-weight:500}
  .nav-phone{font-size:15px}
}
@media(max-width:520px){
  .wordmark{font-size:17px}
  .nav-phone{font-size:14px;gap:9px}
}

/* ========== Hero ========== */
.hero{
  position:relative;
  height:100vh;
  min-height:680px;
  overflow:hidden;
  background:var(--obsidian);
}
.hero-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  transform:scale(1.04);
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse at 25% 75%,rgba(0,0,0,.55) 0%,transparent 55%),
    linear-gradient(180deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.1) 35%,rgba(0,0,0,.82) 100%);
}
.hero-content{
  position:relative;
  z-index:2;
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:0 56px 96px;
  max-width:1500px;
  margin:0 auto;
}
.kicker{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.34em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--brass);
  margin-bottom:36px;
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.kicker::before{
  content:"";
  width:32px;height:1px;
  background:var(--brass-soft);
}
.hero h1{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(56px,8.8vw,138px);
  line-height:1.01;
  letter-spacing:-.022em;
  color:var(--platinum);
  max-width:15ch;
}
.hero h1 em{
  font-style:italic;
  color:var(--brass);
  font-weight:400;
}
.divider{
  width:60px;
  height:1px;
  background:var(--silver);
  position:relative;
  margin:38px 0 30px;
}
.divider::after{
  content:"";
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:7px;height:7px;
  background:var(--brass);
}
.tagline{
  font-family:var(--display);
  font-style:italic;
  font-size:clamp(18px,1.7vw,23px);
  color:var(--silver);
  font-weight:400;
  max-width:50ch;
  line-height:1.45;
}
.service-area{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.3em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--chrome);
  margin:38px 0 42px;
}
.hero-ctas{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
}
.btn{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:600;
  padding:19px 36px;
  border:1px solid var(--platinum);
  display:inline-block;
  transition:all .35s ease;
  cursor:pointer;
  background:transparent;
  color:var(--platinum);
}
.btn-primary{
  background:var(--platinum);
  color:var(--obsidian);
}
.btn-primary:hover{
  background:transparent;
  color:var(--platinum);
}
.btn-outline:hover{
  background:var(--platinum);
  color:var(--obsidian);
}
@media(max-width:860px){
  .hero-content{padding:80px 24px 64px}
  .kicker{margin-bottom:26px;font-size:10px}
  .divider{margin:28px 0 22px}
  .service-area{margin:28px 0 32px;font-size:10px}
  .btn{padding:15px 26px;font-size:10px}
}

/* ========== Section frame ========== */
.section{padding:140px 0;position:relative}
.section-title-block{
  text-align:center;
  max-width:920px;
  margin:0 auto 100px;
  padding:0 24px;
}
.label-rule{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  margin-bottom:30px;
}
.label-rule::before,.label-rule::after{
  content:"";
  flex:0 0 auto;
  width:42px;
  height:1px;
  background:var(--line-2);
}
.label-rule span{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.34em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--chrome);
}
.section-title{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(40px,6vw,90px);
  line-height:1.04;
  letter-spacing:-.022em;
  color:var(--platinum);
}
.section-title em{
  font-style:italic;
  color:var(--brass);
  font-weight:400;
}
.section-sub{
  margin-top:32px;
  font-family:var(--display);
  font-style:italic;
  font-size:20px;
  color:var(--chrome);
  line-height:1.55;
  max-width:62ch;
  margin-left:auto;
  margin-right:auto;
  font-weight:400;
}
@media(max-width:860px){
  .section{padding:90px 0}
  .section-title-block{margin-bottom:64px}
  .section-sub{font-size:17px}
}

/* ========== Service stripes ========== */
.stripe{
  position:relative;
  min-height:540px;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:var(--ink);
  border-top:1px solid var(--line);
}
.stripe-bg{
  position:absolute;
  inset:0;
}
.stripe-1 .stripe-bg{
  background:
    radial-gradient(circle at 35% 40%,rgba(184,153,104,.07) 0%,transparent 55%),
    radial-gradient(circle at 80% 70%,rgba(80,60,30,.12) 0%,transparent 60%),
    linear-gradient(135deg,#0c0a08 0%,#16120a 100%);
}
.stripe-2 .stripe-bg{
  background:
    radial-gradient(circle at 65% 40%,rgba(184,153,104,.06) 0%,transparent 55%),
    radial-gradient(circle at 20% 70%,rgba(50,40,60,.15) 0%,transparent 60%),
    linear-gradient(225deg,#0a0a0c 0%,#15131a 100%);
}
.stripe-3 .stripe-bg{
  background:
    radial-gradient(circle at 35% 40%,rgba(184,153,104,.05) 0%,transparent 55%),
    radial-gradient(circle at 80% 70%,rgba(40,55,55,.14) 0%,transparent 60%),
    linear-gradient(135deg,#08090a 0%,#101418 100%);
}
.stripe-content{
  position:relative;
  z-index:2;
  padding:90px 56px;
  max-width:1500px;
  margin:0 auto;
  width:100%;
}
.stripe-2 .stripe-content{
  display:flex;
  justify-content:flex-end;
  text-align:right;
}
.stripe-content-inner{max-width:580px;position:relative}
.stripe-numeral{
  font-family:var(--display);
  font-style:italic;
  font-weight:400;
  font-size:clamp(120px,16vw,200px);
  color:var(--brass);
  opacity:.16;
  position:absolute;
  line-height:.8;
  pointer-events:none;
  user-select:none;
  z-index:1;
}
.stripe-1 .stripe-numeral{top:70px;right:80px}
.stripe-2 .stripe-numeral{top:70px;left:80px}
.stripe-3 .stripe-numeral{top:70px;right:80px}
.stripe-eyebrow{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.34em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--brass);
  margin-bottom:26px;
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.stripe-eyebrow::before{
  content:"";
  width:24px;height:1px;
  background:var(--brass);
}
.stripe-2 .stripe-eyebrow{
  flex-direction:row-reverse;
}
.stripe-title{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(34px,4.4vw,60px);
  line-height:1.06;
  letter-spacing:-.022em;
  color:var(--platinum);
  margin-bottom:26px;
}
.stripe-title em{font-style:italic;color:var(--brass);font-weight:400}
.stripe-text{
  font-family:var(--body);
  font-size:16px;
  line-height:1.85;
  color:var(--chrome);
  margin-bottom:34px;
  max-width:52ch;
}
.stripe-2 .stripe-text{margin-left:auto}
.stripe-link{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--platinum);
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding-bottom:10px;
  border-bottom:1px solid var(--brass);
  transition:all .3s ease;
}
.stripe-link:hover{color:var(--brass);gap:18px}
@media(max-width:860px){
  .stripe{min-height:auto}
  .stripe-content{padding:70px 24px}
  .stripe-2 .stripe-content{justify-content:flex-start;text-align:left}
  .stripe-2 .stripe-text{margin-left:0}
  .stripe-2 .stripe-eyebrow{flex-direction:row}
  .stripe-1 .stripe-numeral,
  .stripe-2 .stripe-numeral,
  .stripe-3 .stripe-numeral{top:30px;right:24px;left:auto;font-size:110px}
}

/* ========== Philosophy 50/50 ========== */
.philosophy{
  background:var(--ink);
  border-top:1px solid var(--line);
}
.philosophy-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  max-width:1600px;
  margin:0 auto;
  gap:0;
  min-height:720px;
}
.philosophy-image{
  position:relative;
  background-size:cover;background-position:center;background-repeat:no-repeat;
}
.philosophy-image::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(0,0,0,.2) 0%,transparent 55%);
}
.philosophy-text{
  padding:90px 90px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.tag-pill{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-family:var(--body);
  font-size:10px;
  letter-spacing:.36em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--brass);
  margin-bottom:36px;
  align-self:flex-start;
}
.tag-pill::before{
  content:"";
  width:24px;
  height:1px;
  background:var(--brass);
}
.philosophy-title{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(36px,4.4vw,66px);
  line-height:1.05;
  letter-spacing:-.022em;
  color:var(--platinum);
  margin-bottom:38px;
}
.philosophy-title em{font-style:italic;color:var(--brass);font-weight:400}
.philosophy-body{
  font-family:var(--body);
  font-size:16px;
  line-height:1.85;
  color:var(--chrome);
  margin-bottom:22px;
  max-width:48ch;
}
@media(max-width:980px){
  .philosophy-grid{grid-template-columns:1fr;min-height:auto}
  .philosophy-image{min-height:420px}
  .philosophy-text{padding:70px 30px}
}

/* ========== Promise / ethos ========== */
.promise{
  position:relative;
  padding:170px 24px;
  background:var(--ink);
  border-top:1px solid var(--line);
  text-align:center;
  overflow:hidden;
}
.promise-bg{
  position:absolute;
  inset:0;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  opacity:.18;
  filter:grayscale(.7);
}
.promise-overlay{
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at center,transparent 0%,var(--ink) 85%);
}
.promise-inner{
  position:relative;
  z-index:2;
  max-width:920px;
  margin:0 auto;
}
.promise-title{
  font-family:var(--display);
  font-weight:400;
  font-style:italic;
  font-size:clamp(30px,3.8vw,52px);
  line-height:1.32;
  letter-spacing:-.01em;
  color:var(--platinum);
}
.promise-title em{font-style:normal;color:var(--brass)}
.promise-divider{
  width:60px;
  height:1px;
  background:var(--silver);
  margin:48px auto;
  position:relative;
}
.promise-divider::after{
  content:"";
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:7px;height:7px;
  background:var(--brass);
}
.promise-sig{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.34em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--chrome);
}
@media(max-width:860px){
  .promise{padding:110px 24px}
}

/* ========== Showcase ========== */
.showcase{
  position:relative;
  min-height:680px;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:var(--ink);
  border-top:1px solid var(--line);
}
.showcase-bg{
  position:absolute;
  inset:0;
  background-size:cover;background-position:80% center;background-repeat:no-repeat;
}
.showcase-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(0,0,0,.94) 0%,rgba(0,0,0,.55) 50%,transparent 100%);
}
.showcase-content{
  position:relative;
  z-index:2;
  padding:90px 56px;
  max-width:1500px;
  margin:0 auto;
  width:100%;
}
.showcase-inner{max-width:600px}
.showcase-inner .kicker{margin-bottom:30px}
.showcase-title{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(36px,4.8vw,70px);
  line-height:1.05;
  letter-spacing:-.022em;
  color:var(--platinum);
  margin-bottom:30px;
}
.showcase-title em{font-style:italic;color:var(--brass);font-weight:400}
.showcase-text{
  font-family:var(--body);
  font-size:17px;
  line-height:1.85;
  color:var(--chrome);
  margin-bottom:38px;
  max-width:52ch;
}
@media(max-width:860px){
  .showcase{min-height:auto}
  .showcase-overlay{background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.94) 100%)}
  .showcase-content{padding:90px 24px}
}

/* ========== Gallery ========== */
.gallery{
  padding:140px 0;
  background:var(--obsidian);
}
.gallery-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px 40px;
  max-width:1400px;
  margin:0 auto;
  padding:0 40px;
}
.gallery-item{display:flex;flex-direction:column}
.gallery-image{
  aspect-ratio:4/3;
  background-color:var(--steel);
  background-size:cover;
  background-position:center;
  position:relative;
  overflow:hidden;
}

.gallery-caption{
  margin-top:26px;
  display:flex;
  align-items:center;
  gap:14px;
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.3em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--silver);
}
.gallery-caption::before{
  content:"";
  width:20px;height:1px;
  background:var(--brass);
  flex:0 0 auto;
}
@media(max-width:860px){
  .gallery{padding:80px 0}
  .gallery-grid{grid-template-columns:1fr;padding:0 24px;gap:42px}
}

/* ========== Contact ========== */
.contact{
  padding:140px 0;
  background:var(--ink);
  border-top:1px solid var(--line);
}
.contact-inner{
  max-width:960px;
  margin:0 auto;
  padding:0 40px;
}
.contact-phone-block{
  text-align:center;
  margin-bottom:90px;
}
.contact-phone-eyebrow{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.34em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--brass);
  margin-bottom:28px;
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.contact-phone-eyebrow::before,.contact-phone-eyebrow::after{
  content:"";
  width:30px;height:1px;
  background:var(--brass-soft);
}
.contact-phone{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(40px,6vw,86px);
  letter-spacing:-.01em;
  color:var(--platinum);
  line-height:1;
  display:inline-block;
  margin-bottom:22px;
  transition:color .3s ease;
}
.contact-phone:hover{color:var(--brass)}
.contact-phone-sub{
  font-family:var(--display);
  font-style:italic;
  font-size:18px;
  color:var(--chrome);
}
.contact-or{
  text-align:center;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:24px;
  margin-bottom:70px;
}
.contact-or::before,.contact-or::after{
  content:"";
  flex:1;
  max-width:130px;
  height:1px;
  background:var(--line-2);
}
.contact-or span{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.36em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--chrome);
}
.form{display:flex;flex-direction:column;gap:42px}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:46px;
}
.field{
  display:flex;
  flex-direction:column;
}
.field label{
  font-family:var(--body);
  font-size:10px;
  letter-spacing:.34em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--chrome);
  margin-bottom:16px;
}
.field input,.field select,.field textarea{
  background:transparent;
  border:none;
  border-bottom:1px solid var(--line-2);
  padding:12px 0;
  font-family:var(--display);
  font-size:19px;
  font-weight:400;
  color:var(--platinum);
  outline:none;
  transition:border-color .3s ease;
  width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-bottom-color:var(--brass);
}
.field select{
  appearance:none;
  -webkit-appearance:none;
  cursor:pointer;
  background-image:
    linear-gradient(45deg,transparent 50%,var(--chrome) 50%),
    linear-gradient(135deg,var(--chrome) 50%,transparent 50%);
  background-position:calc(100% - 14px) 50%,calc(100% - 8px) 50%;
  background-size:6px 6px,6px 6px;
  background-repeat:no-repeat;
  padding-right:30px;
}
.field select option{background:var(--ink);color:var(--platinum);font-family:var(--body)}
.field textarea{resize:vertical;min-height:90px;line-height:1.55}
.field-honeypot{
  position:absolute !important;
  left:-9999px !important;
  opacity:0 !important;
  pointer-events:none !important;
}
.form-submit{
  margin-top:30px;
  align-self:flex-start;
}
.submit-btn{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:600;
  padding:20px 52px;
  background:var(--platinum);
  color:var(--obsidian);
  border:1px solid var(--platinum);
  cursor:pointer;
  transition:all .35s ease;
}
.submit-btn:hover:not(:disabled){
  background:transparent;
  color:var(--platinum);
}
.submit-btn:disabled{
  opacity:.4;
  cursor:not-allowed;
}
@media(max-width:680px){
  .contact{padding:80px 0}
  .contact-inner{padding:0 24px}
  .form-row{grid-template-columns:1fr;gap:42px}
  .contact-phone-block{margin-bottom:60px}
}

/* ========== Footer ========== */
.footer{
  padding:110px 24px 50px;
  background:var(--obsidian);
  border-top:1px solid var(--line);
  text-align:center;
}
.footer-mark{
  width:54px;height:54px;
  border:1px solid var(--brass);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 34px;
}
.footer-mark span{
  font-family:var(--display);
  font-style:italic;
  font-size:17px;
  color:var(--brass);
  font-weight:500;
  line-height:1;
}
.footer-wordmark{
  font-family:var(--display);
  font-weight:500;
  font-size:36px;
  letter-spacing:-.01em;
  color:var(--platinum);
  margin-bottom:20px;
}
.footer-wordmark em{
  font-style:italic;
  color:var(--brass);
  font-weight:500;
}
.footer-desc{
  font-family:var(--display);
  font-style:italic;
  font-size:17px;
  color:var(--chrome);
  margin-bottom:46px;
  max-width:58ch;
  margin-left:auto;
  margin-right:auto;
  line-height:1.55;
  font-weight:400;
}
.footer-cities{
  font-family:var(--body);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--chrome);
  margin-bottom:38px;
  line-height:2;
}
.footer-phone{
  font-family:var(--display);
  font-size:26px;
  color:var(--platinum);
  font-weight:400;
  letter-spacing:.02em;
  display:inline-block;
  margin-bottom:70px;
  transition:color .3s ease;
}
.footer-phone:hover{color:var(--brass)}
.footer-base{
  padding-top:32px;
  border-top:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  font-family:var(--body);
  font-size:10px;
  letter-spacing:.3em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--muted);
  max-width:1200px;
  margin:0 auto;
}
.footer-base a:hover{color:var(--brass)}
@media(max-width:680px){
  .footer{padding:80px 24px 40px}
  .footer-base{flex-direction:column;gap:14px;text-align:center}
  .footer-wordmark{font-size:30px}
}


/* ============ NAV DROPDOWN ============ */
.nav-links li.has-dropdown{position:relative}
.nav-links .dd-toggle{display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;color:var(--silver)}
.nav-links .dd-toggle::after{content:"";width:5px;height:5px;border-right:1px solid var(--chrome);border-bottom:1px solid var(--chrome);transform:rotate(45deg);margin-top:-3px;transition:border-color .3s}
.nav-links li.has-dropdown:hover .dd-toggle{color:var(--platinum)}
.nav-links li.has-dropdown:hover .dd-toggle::after{border-color:var(--brass)}
.dropdown{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  background:rgba(7,7,8,.96);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--line-2);min-width:280px;padding:14px 0;
  opacity:0;visibility:hidden;transition:opacity .3s ease,transform .3s ease;z-index:200;
}
.nav-links li.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.dropdown a{display:block;padding:13px 28px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;color:var(--silver);transition:all .25s ease;white-space:nowrap}
.dropdown a::after{display:none}
.dropdown a:hover{color:var(--brass);background:rgba(184,153,104,.06);padding-left:34px}

/* ============ MOBILE MENU ============ */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;z-index:120}
.nav-toggle span{display:block;width:24px;height:1.5px;background:var(--platinum);transition:.3s}
.mobile-menu{
  position:fixed;inset:0;background:rgba(0,0,0,.98);z-index:110;
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;
  opacity:0;visibility:hidden;transition:opacity .4s ease;padding:40px;overflow-y:auto;
}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu .mm-group{font-family:var(--body);font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--brass);font-weight:600;margin:26px 0 8px}
.mobile-menu a{font-family:var(--display);font-size:24px;color:var(--silver);font-weight:400;padding:8px 0;transition:color .25s}
.mobile-menu a:hover{color:var(--brass)}
.mobile-menu .mm-close{position:absolute;top:26px;right:30px;font-size:34px;color:var(--silver);font-family:var(--body);font-weight:300;line-height:1}
@media(max-width:920px){
  .nav-toggle{display:flex}
}

/* ============ BREADCRUMB ============ */
.breadcrumb{
  max-width:1500px;margin:0 auto;padding:26px 56px 0;
  font-family:var(--body);font-size:10px;letter-spacing:.26em;text-transform:uppercase;font-weight:500;color:var(--muted);
}
.breadcrumb a{color:var(--chrome);transition:color .25s}
.breadcrumb a:hover{color:var(--brass)}
.breadcrumb span{margin:0 10px;color:var(--line-2)}
.breadcrumb .current{color:var(--brass)}
@media(max-width:860px){.breadcrumb{padding:20px 24px 0}}

/* ============ SERVICE PAGE HERO (shorter than home) ============ */
.page-hero{height:78vh;min-height:560px}
@media(max-width:860px){.page-hero{height:auto;min-height:0}}

/* ============ SERVICE NAV CARDS (homepage) ============ */
.svc-group{max-width:1400px;margin:0 auto;padding:0 40px}
.svc-group + .svc-group{margin-top:80px}
.svc-group-label{
  display:flex;align-items:center;gap:20px;margin-bottom:44px;
}
.svc-group-label span{font-family:var(--body);font-size:12px;letter-spacing:.34em;text-transform:uppercase;font-weight:600;color:var(--brass);white-space:nowrap}
.svc-group-label::after{content:"";flex:1;height:1px;background:var(--line-2)}
.svc-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.svc-card{
  background:var(--ink);padding:48px 44px;display:flex;flex-direction:column;
  text-decoration:none;transition:background .4s ease;position:relative;min-height:230px;
}
.svc-card:hover{background:var(--steel)}
.svc-card-num{font-family:var(--display);font-style:italic;font-size:18px;color:var(--brass);opacity:.7;margin-bottom:auto}
.svc-card-name{font-family:var(--display);font-weight:400;font-size:30px;line-height:1.1;letter-spacing:-.02em;color:var(--platinum);margin:28px 0 14px}
.svc-card-desc{font-family:var(--body);font-size:14px;line-height:1.7;color:var(--chrome);margin-bottom:24px}
.svc-card-link{font-family:var(--body);font-size:10px;letter-spacing:.28em;text-transform:uppercase;font-weight:600;color:var(--silver);display:inline-flex;align-items:center;gap:10px;transition:gap .3s,color .3s}
.svc-card:hover .svc-card-link{color:var(--brass);gap:16px}
@media(max-width:760px){
  .svc-group{padding:0 24px}
  .svc-cards{grid-template-columns:1fr}
  .svc-card{padding:38px 28px;min-height:0}
  .svc-card-name{font-size:26px}
}

/* ============ SCOPE LIST ============ */
.scope{max-width:1400px;margin:0 auto;padding:0 56px}
.scope-title{font-family:var(--body);font-size:11px;letter-spacing:.32em;text-transform:uppercase;font-weight:600;color:var(--brass);margin-bottom:36px;display:flex;align-items:center;gap:14px}
.scope-title::before{content:"";width:24px;height:1px;background:var(--brass)}
.scope-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.scope-grid div{background:var(--obsidian);padding:26px 24px;font-family:var(--display);font-size:18px;color:var(--silver);font-weight:400;line-height:1.3}
@media(max-width:980px){.scope-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){.scope{padding:0 24px}}
@media(max-width:520px){.scope-grid{grid-template-columns:1fr}.scope-grid div{padding:20px}}

/* ============ FLEXIBLE GALLERY (auto-fit) ============ */
.svc-gallery-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(440px,1fr));
  gap:50px 36px;max-width:1400px;margin:0 auto;padding:0 40px;
}
@media(max-width:860px){.svc-gallery-grid{grid-template-columns:1fr;padding:0 24px;gap:38px}}

/* ============ PROCESS BAND ============ */
.process{padding:130px 0;background:var(--ink);border-top:1px solid var(--line)}
.process-inner{max-width:1200px;margin:0 auto;padding:0 40px;text-align:center}
.process-title{font-family:var(--display);font-weight:400;font-size:clamp(32px,4.4vw,60px);line-height:1.08;letter-spacing:-.02em;color:var(--platinum);margin-bottom:28px}
.process-title em{font-style:italic;color:var(--brass)}
.process-body{font-family:var(--body);font-size:16px;line-height:1.85;color:var(--chrome);max-width:64ch;margin:0 auto 64px}
.process-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
.process-pillar{background:var(--ink);padding:48px 36px}
.process-pillar .pp-num{font-family:var(--display);font-style:italic;font-size:34px;color:var(--brass);opacity:.5;margin-bottom:20px}
.process-pillar h4{font-family:var(--body);font-size:11px;letter-spacing:.3em;text-transform:uppercase;font-weight:600;color:var(--platinum);margin-bottom:16px}
.process-pillar p{font-family:var(--body);font-size:14px;line-height:1.7;color:var(--chrome)}
.process-finance{margin-top:50px;font-family:var(--display);font-style:italic;font-size:18px;color:var(--silver)}
.process-finance span{color:var(--brass)}
@media(max-width:860px){.process{padding:80px 0}.process-pillars{grid-template-columns:1fr}.process-inner{padding:0 24px}}

/* ============ COMPACT CONTACT CTA ============ */
.cta-band{padding:130px 24px;background:var(--obsidian);border-top:1px solid var(--line);text-align:center}
.cta-band .kicker{justify-content:center}
.cta-band .kicker::before{display:none}
.cta-title{font-family:var(--display);font-weight:400;font-size:clamp(34px,5vw,68px);line-height:1.05;letter-spacing:-.02em;color:var(--platinum);margin-bottom:40px}
.cta-title em{font-style:italic;color:var(--brass)}
.cta-phone{font-family:var(--display);font-size:clamp(30px,4vw,52px);color:var(--platinum);font-weight:400;display:inline-block;margin-bottom:36px;transition:color .3s}
.cta-phone:hover{color:var(--brass)}
.cta-actions{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}

/* ============ FOOTER SITEMAP ============ */
.footer-sitemap{display:flex;justify-content:center;gap:80px;flex-wrap:wrap;margin-bottom:60px;text-align:left}
.footer-col h5{font-family:var(--body);font-size:10px;letter-spacing:.32em;text-transform:uppercase;font-weight:600;color:var(--brass);margin-bottom:20px}
.footer-col a{display:block;font-family:var(--body);font-size:13px;letter-spacing:.04em;color:var(--chrome);padding:7px 0;transition:color .25s}
.footer-col a:hover{color:var(--platinum)}
@media(max-width:680px){.footer-sitemap{gap:40px}}


/* ============ CONSULTATION FORM (prominent, on every page) ============ */
.consult{padding:130px 24px;background:var(--steel);border-top:1px solid var(--brass-soft)}
.consult-inner{max-width:820px;margin:0 auto}
.consult-head{text-align:center;margin-bottom:56px}
.consult-eyebrow{font-family:var(--body);font-size:11px;letter-spacing:.34em;text-transform:uppercase;font-weight:600;color:var(--brass);margin-bottom:26px;display:inline-flex;align-items:center;gap:14px}
.consult-eyebrow::before,.consult-eyebrow::after{content:"";width:30px;height:1px;background:var(--brass-soft)}
.consult-title{font-family:var(--display);font-weight:400;font-size:clamp(34px,5vw,62px);line-height:1.06;letter-spacing:-.02em;color:var(--platinum);margin-bottom:24px}
.consult-title em{font-style:italic;color:var(--brass)}
.consult-sub{font-family:var(--display);font-style:italic;font-size:19px;color:var(--chrome);line-height:1.5;max-width:50ch;margin:0 auto}
.consult-card{background:var(--ink);border:1px solid var(--line-2);padding:54px 54px 46px}
.consult .form{gap:34px}
.consult .submit-btn{width:100%;padding:22px;font-size:12px;letter-spacing:.3em}
.consult-foot{text-align:center;margin-top:38px;font-family:var(--body);font-size:13px;letter-spacing:.06em;color:var(--muted)}
.consult-foot a{color:var(--silver);transition:color .25s}
.consult-foot a:hover{color:var(--brass)}
@media(max-width:680px){.consult{padding:80px 18px}.consult-card{padding:34px 22px 30px}}

/* ============ SERVICE AREA BAND (homepage) ============ */
.service-area-band{padding:120px 24px;background:var(--obsidian);border-top:1px solid var(--line);text-align:center}
.sab-title{font-family:var(--display);font-weight:400;font-size:clamp(30px,4vw,54px);line-height:1.1;letter-spacing:-.02em;color:var(--platinum);margin:30px 0 34px}
.sab-title em{font-style:italic;color:var(--brass)}
.sab-text{font-family:var(--body);font-size:16px;line-height:2;color:var(--chrome);max-width:74ch;margin:0 auto}
.sab-text strong{color:var(--silver);font-weight:500;letter-spacing:.02em}

/* keep submit enabled (no turnstile gating in preview) */
.submit-btn:disabled{opacity:1;cursor:pointer}

/* ============ FOOTER SLOGAN ============ */
.footer-slogan{font-family:var(--body);font-size:11px;letter-spacing:.3em;text-transform:uppercase;font-weight:500;color:var(--brass);margin-bottom:24px;line-height:1.6}
@media(max-width:680px){.footer-slogan{letter-spacing:.2em}}

/* ===== Service tile thumbnails ===== */
.svc-card{padding:0;min-height:0}
.svc-card-img{height:185px;background-size:cover;background-position:center;filter:grayscale(.12) brightness(.9);transition:filter .6s ease}
.svc-card:hover .svc-card-img{filter:grayscale(0) brightness(1)}
.svc-card-body{padding:38px 40px 42px;display:flex;flex-direction:column;flex:1}
.svc-card-num{margin-bottom:0}
.svc-card-name{margin:16px 0 14px}
.svc-card-link{margin-top:auto}
@media(max-width:760px){.svc-card-body{padding:30px 26px 34px}.svc-card-img{height:160px}}

/* ===== Financing band (prominent) ===== */
.finance-band{padding:20px 24px 130px;background:var(--obsidian)}
.finance-card{max-width:1080px;margin:0 auto;border:1px solid var(--brass);background:linear-gradient(135deg,rgba(184,153,104,.09) 0%,rgba(184,153,104,.02) 45%,transparent 100%);padding:76px 64px;text-align:center;position:relative}
.finance-eyebrow{font-family:var(--body);font-size:11px;letter-spacing:.34em;text-transform:uppercase;font-weight:600;color:var(--brass);margin-bottom:26px}
.finance-title{font-family:var(--display);font-weight:400;font-size:clamp(32px,4.4vw,58px);line-height:1.06;letter-spacing:-.02em;color:var(--platinum);margin-bottom:26px}
.finance-title em{font-style:italic;color:var(--brass)}
.finance-text{font-family:var(--body);font-size:16px;line-height:1.85;color:var(--chrome);max-width:62ch;margin:0 auto 40px}
@media(max-width:680px){.finance-card{padding:48px 26px}}
