/* NJSD — Editorial Modern. 2026, not 2015. */

:root{
  --ink:#0B0B0C;
  --ink-2:#1A1A1C;
  --paper:#F4F4F0;          /* cleaner neutral, less yellow */
  --paper-2:#EAEAE5;
  --paper-3:#FFFFFF;
  --muted:#5F6266;
  --rule:#1A1A1C;
  --rule-soft:#D8D8D2;
  --accent:#00C9B7;         /* electric cyan-teal — pulled from the logo */
  --accent-dark:#008A7E;
  --accent-tint:#CCF5F0;
  --magenta:#E91E63;        /* secondary pop from the logo, used sparingly */

  --maxw:1440px;
  --gutter:clamp(20px,4vw,56px);
  --radius:0;
  --radius-card:4px;

  --f-display:"Fraunces","Cormorant Garamond",Georgia,serif;
  --f-sans:"Inter","Helvetica Neue",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;

  --shadow-md:0 8px 30px rgba(11,11,12,.10);
  --shadow-lg:0 24px 60px rgba(11,11,12,.18);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--f-sans);
  font-size:18px;
  line-height:1.6;
  color:var(--ink);
  background:var(--paper);
  font-feature-settings:"kern","liga","calt","ss01";
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none;border-bottom:1px solid currentColor}
a:hover{color:var(--accent);border-color:var(--accent)}

/* Typography ---------------------------------------------- */
h1,h2,h3,h4{
  font-family:var(--f-display);
  font-weight:380;
  line-height:.96;
  letter-spacing:-0.03em;
  color:var(--ink);
  margin:0 0 .4em;
  font-variation-settings:"opsz" 144, "SOFT" 50;
  text-wrap:balance;
}
h1{font-size:clamp(3.4rem,9vw,9.5rem);font-weight:330;letter-spacing:-0.045em}
h2{font-size:clamp(2.4rem,5.6vw,5rem);font-weight:360;letter-spacing:-0.035em}
h3{font-size:clamp(1.5rem,2.4vw,2.2rem);font-weight:420;line-height:1.05;letter-spacing:-0.02em}
h4{font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-family:var(--f-sans);color:var(--accent);margin-bottom:1.2em}

p{margin:0 0 1em}
p.lead{font-size:clamp(1.1rem,1.5vw,1.4rem);line-height:1.5;color:var(--ink-2);font-weight:400;letter-spacing:-0.005em;max-width:48ch}

.eyebrow{
  display:inline-block;font-family:var(--f-sans);font-size:.72rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
  font-weight:600;margin-bottom:1.4rem;
  padding:6px 14px;border:1px solid var(--ink);border-radius:100px;
}
.eyebrow.on-dark{color:var(--paper);border-color:var(--paper)}

/* Layout primitives --------------------------------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.wrap-narrow{max-width:920px;margin:0 auto;padding:0 var(--gutter)}
.full-bleed{width:100%;padding-left:0;padding-right:0}
section{padding:clamp(80px,11vw,180px) 0;position:relative}
section.tight{padding:clamp(56px,8vw,100px) 0}

.grid{display:grid;gap:clamp(20px,2vw,32px)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-12{grid-template-columns:repeat(12,1fr);column-gap:clamp(16px,2vw,28px)}
.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-5{grid-column:span 5}
.col-8{grid-column:span 8}.col-4{grid-column:span 4}
@media (max-width:900px){
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .g-12{grid-template-columns:1fr;gap:24px}
  .col-6,.col-7,.col-5,.col-8,.col-4{grid-column:1/-1}
}

/* Buttons ------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  font-family:var(--f-sans);font-size:.95rem;font-weight:600;
  letter-spacing:.01em;text-decoration:none;border:0;border-bottom:0;
  padding:18px 32px;min-height:54px;border-radius:100px;
  transition:transform .2s ease,background .2s ease,color .2s ease,border-color .2s ease;
  cursor:pointer;line-height:1;
}
.btn:hover{border-bottom:0}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dark);color:#fff;transform:translateY(-2px)}
.btn-ink{background:var(--ink);color:var(--paper)}
.btn-ink:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}
.btn-paper{background:var(--paper);color:var(--ink)}
.btn-paper:hover{background:#fff;transform:translateY(-2px)}
.btn-ghost-light{background:transparent;color:var(--paper);border:1px solid rgba(247,244,238,.5)}
.btn-ghost-light:hover{background:var(--paper);color:var(--ink)}
.btn-arrow{display:inline-flex;align-items:center;gap:10px;font-weight:600;letter-spacing:.01em;border:0}
.btn-arrow::after{content:"→";transition:transform .2s ease}
.btn-arrow:hover{border:0;color:var(--accent)}
.btn-arrow:hover::after{transform:translateX(6px)}

/* Header --------------------------------------------------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(247,244,238,.85);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(11,11,12,.06);
}
.nav.on-dark{background:rgba(11,11,12,.4);border-bottom-color:rgba(247,244,238,.08)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:18px;padding-bottom:18px;gap:24px}
.brand{display:flex;align-items:center;gap:22px;text-decoration:none;color:var(--ink);border:0}
.brand-text{padding-left:4px}
.brand:hover{border:0;color:var(--ink)}
.brand-logo{
  height:120px;width:auto;display:block;object-fit:contain;
  background:transparent;padding:0;border-radius:0;box-shadow:none;
  transition:transform .2s ease;
}
.brand:hover .brand-logo{transform:scale(1.04)}
.brand-logo-foot{background:transparent;padding:0;border-radius:0;height:120px;width:auto;object-fit:contain}
/* Pull the nav vertical padding tighter so the bigger logo doesn't push everything down */
.nav .wrap{padding-top:8px;padding-bottom:8px}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--f-display);font-weight:500;font-size:1.4rem;letter-spacing:-0.025em}
.brand-sub{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:5px;font-weight:600}
.nav.on-dark .brand-name,.nav.on-dark .brand-sub{color:var(--paper)}
.nav.on-dark .brand-sub{color:rgba(247,244,238,.6)}

.nav-links{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
.nav-links a{
  position:relative;display:inline-block;padding:10px 14px;
  font-size:.76rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);border:0;background:transparent;border-radius:0;
  transition:color .2s ease;
}
.nav.on-dark .nav-links a{color:var(--paper)}
.nav-links a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:1px;
  background:var(--accent);transform:scaleX(0);transform-origin:left center;
  transition:transform .25s ease;
}
.nav-links a:hover::after,.nav-links a.is-active::after{transform:scaleX(1)}
.nav-links a:hover,.nav-links a.is-active{color:var(--accent);background:transparent}
.nav.on-dark .nav-links a:hover,.nav.on-dark .nav-links a.is-active{color:var(--accent);background:transparent}
.nav-links .has-sub{position:relative}
.nav-links .has-sub > a::before{content:"";position:absolute;right:4px;top:50%;width:6px;height:6px;border-right:1px solid currentColor;border-bottom:1px solid currentColor;transform:translateY(-70%) rotate(45deg);opacity:.5}
.nav-links .has-sub > a{padding-right:22px}
.submenu{
  position:absolute;top:calc(100% + 6px);left:0;min-width:280px;
  background:#fff;border:1px solid var(--rule-soft);border-radius:12px;
  box-shadow:var(--shadow-lg);padding:14px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:all .22s ease;
}
.nav-links .has-sub:hover .submenu,.nav-links .has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
/* simple submenu (fallback) — always ink text regardless of nav variant */
.submenu a{display:block;padding:12px 16px;font-size:.9rem;border-radius:6px;background:transparent;color:var(--ink) !important;border:0}
.submenu a:hover{background:var(--ink);color:var(--paper) !important}

/* MEGA-MENU --------------------------------------------- */
.submenu.mega{
  min-width:820px;left:50%;transform:translate(-50%,-6px);
  padding:20px;border-radius:14px;
}
.nav-links .has-sub:hover .submenu.mega,
.nav-links .has-sub:focus-within .submenu.mega{transform:translate(-50%,0)}
.mega-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;align-items:stretch}
.mega-card{
  display:flex;flex-direction:column;text-decoration:none;color:var(--ink) !important;
  border-radius:8px;overflow:hidden;padding:0;border:0;
  background:var(--paper-2);height:100%;
  transition:transform .2s ease, box-shadow .25s ease;
}
.mega-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);color:var(--ink) !important}
.mega-card:hover .mega-img{transform:scale(1.04)}
.mega-imgwrap{overflow:hidden;background:var(--ink);flex-shrink:0}
.mega-img{
  width:100%;aspect-ratio:16/10;background-size:cover;background-position:center;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
  filter:saturate(1.04);
}
.mega-body{padding:12px 14px 16px;display:flex;flex-direction:column;flex:1}
.mega-title{
  font-family:var(--f-display);font-size:1.05rem;font-weight:500;
  line-height:1.15;color:var(--ink);letter-spacing:-0.015em;margin-bottom:6px;
  min-height:1.2em;
}
.mega-desc{
  font-size:.78rem;line-height:1.45;color:var(--muted);
  font-family:var(--f-sans);margin:0;flex:1;
}
.mega-footer{
  margin-top:16px;padding:14px 8px 4px;border-top:1px solid var(--rule-soft);
  display:flex;justify-content:space-between;align-items:center;font-size:.78rem;
  letter-spacing:.04em;
}
.mega-footer span{font-size:.78rem;color:var(--muted)}
.mega-footer a{color:var(--accent) !important;font-weight:600;border:0;text-transform:uppercase;letter-spacing:.12em;font-size:.74rem}
.mega-footer a:hover{color:var(--accent-dark) !important}
@media (max-width:1100px){.submenu.mega{display:none}}

.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{font-family:var(--f-sans);font-size:.9rem;font-weight:600;color:var(--ink);border:0;letter-spacing:.01em}
.nav.on-dark .nav-phone{color:var(--paper)}
.nav-phone:hover{color:var(--accent);border:0}

.menu-toggle{display:none;background:transparent;border:0;width:48px;height:48px;cursor:pointer}
.menu-toggle span{display:block;width:26px;height:2px;background:var(--ink);margin:6px auto;transition:transform .2s}
.nav.on-dark .menu-toggle span{background:var(--paper)}

.nav-mobile{display:none}
@media (max-width:1100px){
  .nav-links,.nav-phone,.nav-cta{display:none}
  .menu-toggle{display:block}
  .nav-mobile.is-open{display:block}
  .nav-mobile{
    position:absolute;top:100%;left:0;right:0;
    background:var(--paper);border-bottom:1px solid var(--rule);
    box-shadow:var(--shadow-lg);padding:12px var(--gutter) 28px;
  }
  .nav-mobile a{display:block;padding:14px 6px;border-bottom:1px solid var(--rule-soft);font-weight:500;color:var(--ink)}
  .nav-mobile a:last-child{border:0}
  .nav-mobile .sub-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);padding-top:22px;border:0;font-weight:600}
}

/* No body padding — hero/page-head slide under the fixed nav (margin-top:-136px on each) so the nav's translucent bg overlays dark content, not cream body */
body{padding-top:0}

/* HERO — full-bleed photography ---------------------------- */
.hero{
  position:relative;margin-top:-136px;padding:0;
  min-height:100vh;display:block;
  background:var(--ink);color:var(--paper);overflow:hidden;
}
.hero .wrap{padding-top:200px;padding-bottom:64px;width:100%}
@media (max-width:600px){.hero{margin-top:-72px;min-height:92vh}}
.hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
}
.hero-bg::after,.hero::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg, rgba(11,11,12,.35) 0%, rgba(11,11,12,.55) 50%, rgba(11,11,12,.95) 100%);
}
.hero-video{z-index:0}
.hero .wrap{z-index:3 !important}
.hero .wrap{position:relative;z-index:2;padding-top:220px;padding-bottom:80px;width:100%}
.hero h1{color:var(--paper);font-size:clamp(2.4rem,6.5vw,6.8rem);font-weight:300;line-height:1;letter-spacing:-0.04em;max-width:18ch;margin-bottom:.4em}
.hero h1 em{font-style:italic;font-weight:330;color:var(--accent);font-variation-settings:"opsz" 144, "SOFT" 100}
.hero .lead{color:rgba(247,244,238,.86);max-width:48ch;font-size:clamp(1.15rem,1.5vw,1.35rem);margin-bottom:40px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:48px;margin-top:64px;
  padding-top:32px;border-top:1px solid rgba(247,244,238,.18);
  font-size:.82rem;letter-spacing:.04em;
}
.hero-meta div{color:rgba(247,244,238,.7)}
.hero-meta strong{display:block;color:var(--paper);font-family:var(--f-display);font-size:2.2rem;font-weight:380;letter-spacing:-0.025em;margin-bottom:6px;line-height:1}

.scroll-cue{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(247,244,238,.6);
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.scroll-cue::after{
  content:"";width:1px;height:36px;background:rgba(247,244,238,.4);animation:cue 2s ease-in-out infinite;
}
@keyframes cue{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(.6) translateY(8px)}}

/* PAGE HEADER (interior pages) — kept compact ---------------- */
.page-head{
  padding:clamp(220px,20vw,280px) 0 clamp(48px,5vw,72px);
  background:var(--ink);color:var(--paper);position:relative;overflow:hidden;
  margin-top:-136px;
}
@media (max-width:600px){.page-head{margin-top:-72px}}
.page-head.with-img{background-size:cover;background-position:center}
.page-head.with-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(11,11,12,.45) 0%, rgba(11,11,12,.85) 100%)}
.page-head .wrap{position:relative;z-index:2;max-width:1180px}
.page-head h1{color:var(--paper);margin-bottom:.4em;font-size:clamp(3rem,7vw,6.5rem);font-weight:330}
.page-head p.lead{color:rgba(247,244,238,.82);max-width:60ch}
.crumbs{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,244,238,.55);margin-bottom:32px;font-weight:600}
.crumbs a{color:rgba(247,244,238,.8);border:0}
.crumbs a:hover{color:var(--accent)}
.crumbs span{margin:0 12px;opacity:.4}

/* Trust line ---------------------------------------------- */
.trust-line{
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  padding:22px 0;font-size:.82rem;letter-spacing:.04em;color:var(--ink);
}
.trust-line .wrap{display:flex;flex-wrap:wrap;gap:18px 48px;justify-content:space-between;align-items:center}
.trust-line strong{font-weight:600}
.trust-line .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);margin:0 14px;vertical-align:middle}
@media (max-width:800px){.trust-line .wrap{justify-content:center;text-align:center}.trust-line .dot{display:none}}

/* SERVICE TILES — photo + title ---------------------------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media (max-width:1024px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.svc-grid{grid-template-columns:1fr}}

.svc{
  position:relative;display:block;overflow:hidden;
  aspect-ratio:5/4;background:var(--ink);color:var(--paper);
  border:0;text-decoration:none;
}
.svc:hover{border:0;color:var(--paper)}
.svc-img{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform .9s cubic-bezier(.2,.7,.2,1),filter .4s ease;
  filter:brightness(.78) saturate(1.05);
}
.svc:hover .svc-img{transform:scale(1.06);filter:brightness(.6) saturate(1.1)}
.svc::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(11,11,12,.85) 100%)}
.svc-body{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:36px 28px 32px;
}
.svc-num{
  font-family:var(--f-sans);font-size:.72rem;letter-spacing:.22em;
  color:rgba(247,244,238,.7);font-weight:600;margin-bottom:14px;
}
.svc h3{color:var(--paper);font-size:clamp(1.4rem,2vw,2rem);margin-bottom:8px;font-weight:380}
.svc p{color:rgba(247,244,238,.78);font-size:.95rem;margin:0;max-width:38ch}
.svc-arrow{
  position:absolute;top:24px;right:24px;z-index:2;
  width:44px;height:44px;border-radius:50%;background:rgba(247,244,238,.12);
  display:grid;place-items:center;color:var(--paper);font-size:1.1rem;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:background .25s ease,transform .25s ease;
}
.svc:hover .svc-arrow{background:var(--accent);transform:rotate(-45deg)}

/* PROJECT TILES — photo + meta ---------------------------- */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:1024px){.proj-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.proj-grid{grid-template-columns:1fr}}

.proj{
  display:block;text-decoration:none;color:var(--ink);border:0;
  background:var(--paper);
}
.proj:hover{border:0;color:var(--ink)}
.proj-img{
  width:100%;aspect-ratio:5/4;background-size:cover;background-position:center;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
  filter:saturate(1.05);
}
.proj-wrap{overflow:hidden;background:var(--ink-2)}
.proj:hover .proj-img{transform:scale(1.04)}
.proj-meta{padding:20px 0 4px;display:flex;justify-content:space-between;align-items:baseline;gap:16px}
.proj-cat{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600}
.proj-loc{font-size:.78rem;color:var(--muted);letter-spacing:.06em}
.proj h3{font-size:clamp(1.2rem,1.8vw,1.6rem);margin:6px 0 0;font-weight:430;line-height:1.1}

/* Process / Steps ---------------------------------------- */
.step{
  border-top:1px solid var(--ink);padding:48px 0;
  display:grid;grid-template-columns:1fr 4fr;gap:clamp(28px,5vw,80px);align-items:start;
}
.step:last-child{border-bottom:1px solid var(--ink)}
.step-num{
  font-family:var(--f-display);font-size:clamp(3.6rem,6vw,6rem);
  color:var(--ink);font-weight:280;line-height:.85;letter-spacing:-0.04em;
}
.step h3{font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:.3em;font-weight:380;line-height:1}
.step p{color:var(--ink-2);max-width:62ch;margin:0;font-size:1.05rem}
.step.is-x .step-num{color:var(--accent);font-weight:330}
@media (max-width:700px){.step{grid-template-columns:1fr}}

/* Big-stat row -------------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.stat{padding:48px clamp(20px,3vw,40px);text-align:left;border-right:1px solid var(--ink-2)}
.stat:last-child{border-right:0}
.stat-num{
  font-family:var(--f-display);font-size:clamp(3rem,5vw,4.6rem);
  font-weight:330;letter-spacing:-0.04em;line-height:1;color:var(--ink);margin-bottom:14px;
}
.stat-label{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
@media (max-width:900px){.stats{grid-template-columns:repeat(2,1fr)}.stat:nth-child(2){border-right:0}.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--ink-2)}}

/* Quote --------------------------------------------------- */
.quote{padding:clamp(48px,7vw,88px) 0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.quote blockquote{
  font-family:var(--f-display);font-size:clamp(1.8rem,3.8vw,3.6rem);
  line-height:1.05;font-weight:340;color:var(--ink);max-width:22ch;margin:0 0 32px;
  letter-spacing:-0.025em;
}
.quote blockquote::before{content:"“ ";color:var(--accent);font-weight:380}
.quote cite{
  font-style:normal;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);font-weight:600;display:block;
}
.quote cite span{display:block;text-transform:none;letter-spacing:0;color:var(--accent);font-weight:500;margin-top:4px;font-size:.95rem;font-family:var(--f-display)}

/* FAQ ----------------------------------------------------- */
.faq{border-top:1px solid var(--ink)}
.faq details{border-bottom:1px solid var(--ink);padding:32px 0;cursor:pointer}
.faq summary{
  list-style:none;display:flex;justify-content:space-between;align-items:flex-start;gap:24px;
  font-family:var(--f-display);font-size:clamp(1.3rem,2.2vw,1.9rem);font-weight:380;color:var(--ink);letter-spacing:-0.02em;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-family:var(--f-sans);font-size:2.2rem;color:var(--accent);font-weight:280;line-height:.6;
  transition:transform .3s ease;flex-shrink:0;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details > div{padding:24px 0 8px;color:var(--ink-2);max-width:74ch;font-size:1.05rem}

/* CTA strip ---------------------------------------------- */
.cta-strip{
  background:var(--ink);color:var(--paper);
  padding:clamp(72px,10vw,140px) 0;position:relative;overflow:hidden;
}
.cta-strip .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.6fr 1fr;gap:48px;align-items:end}
.cta-strip h2{color:var(--paper);margin:0;max-width:14ch;font-size:clamp(2.4rem,6vw,5rem)}
.cta-strip p{color:rgba(247,244,238,.78);margin:16px 0 0;max-width:54ch;font-size:1.1rem}
.cta-strip-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:flex-end}
@media (max-width:900px){.cta-strip .wrap{grid-template-columns:1fr}.cta-strip-actions{justify-content:flex-start}}

/* Inline image / Frame (legacy + photo) ------------------ */
.frame{
  position:relative;border-radius:0;overflow:hidden;
  aspect-ratio:16/10;background:var(--ink);
  background-size:cover;background-position:center;
}
.frame.wide{aspect-ratio:16/9}
.frame.square{aspect-ratio:1/1}
.frame.tall{aspect-ratio:5/4}

/* Service area chips -------------------------------------- */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.chip{
  padding:10px 18px;background:transparent;border:1px solid var(--ink);
  border-radius:100px;font-size:.85rem;color:var(--ink);
  transition:all .2s ease;border-bottom:1px solid var(--ink);
}
.chip:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Form --------------------------------------------------- */
.form{display:grid;gap:18px;background:var(--paper-3);padding:clamp(28px,4vw,48px);border:1px solid var(--ink);border-radius:0}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
.field input,.field textarea,.field select{
  font-family:var(--f-sans);font-size:1rem;padding:16px 18px;
  background:var(--paper);border:1px solid var(--rule-soft);border-radius:0;
  color:var(--ink);width:100%;transition:border-color .15s ease,background .15s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--ink);background:#fff}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:600px){.field-row{grid-template-columns:1fr}}
.form-error{background:var(--accent-tint);border:1px solid var(--accent);color:var(--accent-dark);padding:14px 18px;font-size:.92rem}

/* Footer -------------------------------------------------- */
.foot{
  background:var(--ink);color:rgba(247,244,238,.74);
  padding:100px 0 32px;font-size:.95rem;
}
.foot a{color:rgba(247,244,238,.86);border:0}
.foot a:hover{color:var(--accent);border:0}
.foot-grid{display:grid;grid-template-columns:1.6fr repeat(3,1fr);gap:48px;margin-bottom:80px;padding-bottom:64px;border-bottom:1px solid rgba(247,244,238,.12)}
@media (max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:560px){.foot-grid{grid-template-columns:1fr}}
.foot h5{font-family:var(--f-sans);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600;margin:0 0 22px}
.foot ul{list-style:none;padding:0;margin:0}
.foot li{padding:7px 0}
.foot .brand-name{color:var(--paper)}
.foot .brand-sub{color:rgba(247,244,238,.55)}
.foot-bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;font-size:.8rem;color:rgba(247,244,238,.5)}
.foot .big-tel{
  display:block;font-family:var(--f-display);font-size:clamp(2.4rem,4vw,3.6rem);
  color:var(--paper);letter-spacing:-0.025em;font-weight:340;margin-bottom:14px;
}

/* Video hero --------------------------------------------- */
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  z-index:0;
}

/* Gallery + lightbox ------------------------------------- */
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
}
@media (max-width:1100px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:700px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
.gallery-item{
  display:block;width:100%;margin:0;cursor:zoom-in;overflow:hidden;
  background:var(--ink);position:relative;aspect-ratio:1/1;
}
.gallery-item img{height:100%;object-fit:cover}
.gallery-item img{
  width:100%;height:auto;display:block;
  transition:transform .6s cubic-bezier(.2,.7,.2,1),opacity .3s ease;
  filter:saturate(1.04);
}
.gallery-item:hover img{transform:scale(1.04);filter:saturate(1.1) brightness(.95)}

.lightbox{
  position:fixed;inset:0;z-index:200;background:rgba(11,11,12,.95);
  display:none;align-items:center;justify-content:center;padding:24px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.lightbox.is-open{display:flex}
.lightbox img{max-width:96vw;max-height:90vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-close,.lb-prev,.lb-next{
  position:absolute;background:rgba(247,244,238,.1);color:var(--paper);
  border:1px solid rgba(247,244,238,.2);border-radius:50%;
  width:56px;height:56px;display:grid;place-items:center;
  font-size:1.5rem;cursor:pointer;transition:all .2s ease;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.lb-close{top:24px;right:24px}
.lb-prev{left:24px;top:50%;transform:translateY(-50%)}
.lb-next{right:24px;top:50%;transform:translateY(-50%)}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.05)}
.lb-prev:hover,.lb-next:hover{transform:translateY(-50%) scale(1.05)}
.lb-counter{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  color:rgba(247,244,238,.7);font-size:.85rem;letter-spacing:.14em;
  font-family:var(--f-sans);background:rgba(11,11,12,.5);
  padding:8px 18px;border-radius:100px;
}

/* Founder bio ------------------------------------------- */
.founder{display:grid;grid-template-columns:5fr 7fr;gap:clamp(28px,5vw,72px);align-items:center}
@media (max-width:900px){.founder{grid-template-columns:1fr}}
.founder-portrait{
  width:100%;aspect-ratio:4/5;object-fit:cover;
  filter:saturate(1.05);
}
.founder-name{font-family:var(--f-display);font-size:1.4rem;font-weight:500;margin-top:24px}
.founder-title{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-top:6px}

/* Capability cloud (real services list) ----------------- */
.cap-cloud{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;
}
.cap-cloud span{
  padding:10px 18px;background:var(--paper);border:1px solid var(--ink);
  border-radius:100px;font-size:.86rem;color:var(--ink);
  transition:all .15s ease;
}
.cap-cloud span:hover{background:var(--ink);color:var(--paper)}

/* Test badge --------------------------------------------- */
@media (max-width:900px){}

/* Sticky mobile CTA bar (mobile only) --------------------- */
.mobile-cta-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:55;
  display:flex;gap:1px;background:var(--ink);
  box-shadow:0 -8px 24px rgba(0,0,0,.18);
}
.mcb-btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 8px;font-family:var(--f-sans);font-weight:600;font-size:.92rem;
  text-decoration:none;letter-spacing:.02em;min-height:54px;
  background:#1A1A1C;color:var(--paper);border:0;
}
.mcb-btn:hover,.mcb-btn:active{background:#28282A;color:#fff;border:0}
.mcb-btn svg{flex-shrink:0;opacity:.85}
.mcb-quote{background:var(--accent);color:#fff}
.mcb-quote:hover,.mcb-quote:active{background:var(--accent-dark);color:#fff}
@media (max-width:900px){body{padding-bottom:54px}}

/* Section labels and helpers ------------------------------ */
.section-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:64px}
.section-head h2{margin:0;max-width:18ch}
.section-head p{margin:0;color:var(--ink-2)}
@media (max-width:900px){.section-head{grid-template-columns:1fr}}

.bg-ink{background:var(--ink);color:var(--paper)}
.bg-ink h2,.bg-ink h3{color:var(--paper)}
.bg-ink .eyebrow{color:var(--paper);border-color:var(--paper)}
.bg-paper-2{background:var(--paper-2)}

.center{text-align:center}
.mt-0{margin-top:0}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2.4rem}.mt-6{margin-top:4rem}
.divider{border:0;border-top:1px solid var(--ink);margin:64px 0}
