/* =========================================================
   Integris Builds — Commercial Division
   Shared stylesheet
   ========================================================= */

:root{
  --black:#0a0a0a;
  --ink:#0f0f10;
  --ink-2:#3a3d42;
  --ink-3:#6b7077;
  --gray-1:#f6f7f8;
  --gray-2:#eceef0;
  --line:#e3e5e8;
  --grid:rgba(15,15,16,.05);
  --paper:#ffffff;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:#fff;color:var(--ink);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;font-weight:400}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1280px;margin:0 auto;padding:0 32px}

h1,h2,h3,h4{font-family:'Fraunces','Inter',serif;margin:0;letter-spacing:-.018em;line-height:1.08;font-weight:400;color:var(--ink);font-variation-settings:'opsz' 96}
h1{font-weight:300;letter-spacing:-.028em}
h2{font-weight:400;letter-spacing:-.022em}
.lead{font-family:'Fraunces','Inter',serif;font-weight:300;letter-spacing:-.012em;font-style:normal;font-variation-settings:'opsz' 36}
h1{font-size:clamp(40px,5.6vw,72px)}
h2{font-size:clamp(28px,3.2vw,42px);line-height:1.12}
h3{font-size:22px;font-weight:500;letter-spacing:0;line-height:1.25}
h4{font-size:14px;font-weight:600;letter-spacing:.04em}
p{line-height:1.65;color:var(--ink-2);margin:0;font-size:16px}
.lead{font-size:18px;line-height:1.6;color:var(--ink-2)}
.eyebrow{font-family:'Inter';font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-3);font-weight:500;display:inline-block}
.eyebrow.light{color:rgba(255,255,255,.65)}

section{padding:96px 0;position:relative}
.grid-bg{
  background:
    linear-gradient(to right, var(--grid) 1px, transparent 1px) 0 0/72px 72px,
    linear-gradient(to bottom, var(--grid) 1px, transparent 1px) 0 0/72px 72px,
    #fff;
}

/* HEADER */
header.top{background:#fff;color:var(--ink);position:sticky;top:0;z-index:30;border-bottom:1px solid var(--line);transition:all .2s ease}
header.top.scrolled{box-shadow:0 1px 0 var(--line),0 8px 20px rgba(0,0,0,.04)}
.top-row{display:flex;align-items:center;justify-content:space-between;min-height:76px;transition:min-height .2s ease}
header.top.scrolled .top-row{min-height:64px}
.logo{display:flex;align-items:center;gap:10px;height:100%}
.logo img{height:38px;width:auto;transition:height .2s ease}
header.top.scrolled .logo img{height:32px}
.menu{display:flex;align-items:center;gap:2px}
.menu a{padding:10px 16px;font-size:13px;font-weight:500;letter-spacing:.02em;color:var(--ink);transition:color .15s}
.menu a:hover{color:var(--ink-3)}
.menu a.active{color:var(--ink);position:relative}
.menu a.active::after{content:'';position:absolute;left:16px;right:16px;bottom:6px;height:1px;background:var(--ink)}
.menu a.cta{background:var(--black);color:#fff;padding:12px 22px;font-weight:600;letter-spacing:.04em;margin-left:8px;transition:background .15s}
.menu a.cta:hover{background:#1f2126}
.menu a.cta::after{display:none}
.menu .hamb{display:none;width:42px;height:42px;align-items:center;justify-content:center;font-size:20px;background:none;border:0;cursor:pointer;color:var(--ink)}

/* MOBILE MENU PANEL */
.mobile-panel{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;z-index:35;padding:24px;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.mobile-panel.open{display:flex}
.mobile-panel .close{align-self:flex-end;background:none;border:0;font-size:28px;cursor:pointer;color:var(--ink);padding:8px;line-height:1}
.mobile-panel nav{display:flex;flex-direction:column;gap:0;margin-top:24px}
.mobile-panel nav a{padding:18px 4px;border-bottom:1px solid var(--line);font-size:18px;font-weight:500;color:var(--ink)}
.mobile-panel nav a.active{color:var(--ink);font-weight:600}
.mobile-panel .panel-cta{margin-top:32px;background:var(--black);color:#fff;padding:18px;text-align:center;font-weight:600;letter-spacing:.04em;font-size:14px}
.mobile-panel .panel-foot{margin-top:auto;padding-top:24px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-3);line-height:1.7}
.mobile-panel .panel-foot a{color:var(--ink);font-weight:500}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:'Inter',sans-serif;letter-spacing:.02em;font-size:14px;padding:14px 24px;cursor:pointer;border:0;font-weight:600;transition:all .18s;text-decoration:none}
.btn-light{background:#fff;color:var(--black)}
.btn-light:hover{background:var(--gray-2)}
.btn-outline-light{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.55)}
.btn-outline-light:hover{background:#fff;color:var(--black);border-color:#fff}
.btn-dark{background:var(--black);color:#fff}
.btn-dark:hover{background:#1f2126}
.btn-outline-dark{background:transparent;color:var(--black);border:1px solid var(--ink)}
.btn-outline-dark:hover{background:var(--black);color:#fff}

/* HERO (home) */
.hero{position:relative;min-height:78vh;display:flex;align-items:center;color:#fff;
  background:linear-gradient(180deg,rgba(0,0,0,.55) 0%, rgba(0,0,0,.35) 45%, rgba(0,0,0,.75) 100%),url('../img/modern-commercial.jpg') center/cover;
  padding:60px 0}
.hero .container{position:relative;z-index:1}
.hero .eyebrow.light{margin-bottom:22px;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.hero h1{color:#fff;max-width:920px;letter-spacing:-.015em;line-height:1.05;font-weight:500;text-shadow:0 2px 24px rgba(0,0,0,.45)}
.hero .sub{max-width:600px;color:rgba(255,255,255,.92);font-size:19px;margin-top:24px;line-height:1.55;text-shadow:0 1px 12px rgba(0,0,0,.5)}
.hero .btn-row{margin-top:36px;display:flex;gap:12px;flex-wrap:wrap}

/* PAGE HERO (inner pages) */
.page-hero{background:#0a0a0a;color:#fff;padding:120px 0 80px;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to right, var(--grid) 1px, transparent 1px) 0 0/72px 72px,linear-gradient(to bottom, var(--grid) 1px, transparent 1px) 0 0/72px 72px;opacity:.08;pointer-events:none}
.page-hero .container{position:relative;z-index:1;max-width:880px}
.page-hero .eyebrow.light{margin-bottom:20px}
.page-hero h1{color:#fff;font-size:clamp(38px,4.8vw,60px);font-weight:500;letter-spacing:-.015em;line-height:1.1}
.page-hero p.lead{color:rgba(255,255,255,.78);margin-top:22px;max-width:680px;font-size:18px}

/* Page hero with photo background */
.page-hero.has-image{background:#0a0a0a}
.page-hero.has-image .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.page-hero.has-image::after{background:linear-gradient(180deg,rgba(0,0,0,.45) 0%, rgba(0,0,0,.30) 40%, rgba(0,0,0,.70) 100%);opacity:1;z-index:1}
.page-hero.has-image .container{position:relative;z-index:2}

/* 5-star unicode rating used on review cards */
.stars-5{display:inline-block;color:#0f0f10;font-size:14px;letter-spacing:2px;line-height:1;font-family:Arial,sans-serif}

/* City page — What we build grid (clean image-on-top, text-below cards) */
.city-build-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.city-build-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:0;overflow:hidden;text-decoration:none;color:inherit;transition:box-shadow .2s ease,transform .2s ease}
.city-build-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.08);transform:translateY(-2px)}
.city-build-img{width:100%;height:160px;background-size:cover;background-position:center;background-color:#eaeaea}
.city-build-body{padding:18px 18px 22px;display:flex;flex-direction:column;gap:6px}
.city-build-body strong{font-weight:600;font-size:15px;letter-spacing:.01em;color:var(--ink)}
.city-build-body span{color:var(--ink-3);font-size:13.5px;line-height:1.5}
@media(max-width:900px){.city-build-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.city-build-grid{grid-template-columns:1fr;gap:16px}.city-build-img{height:180px}}

/* TRUST STRIP */
.trust{padding:36px 0;background:var(--gray-1);border-bottom:1px solid var(--line)}
.trust-row{display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}
.trust-item{display:flex;flex-direction:column;gap:4px}
.trust-item .num{font-size:28px;font-weight:500;color:var(--ink);letter-spacing:-.01em}
.trust-item .lbl{font-size:12px;color:var(--ink-3);letter-spacing:.05em}
.trust-tag{font-size:13px;color:var(--ink-2);line-height:1.5;max-width:280px}

/* INTRO */
.intro{padding:96px 0}
.intro-row{display:grid;grid-template-columns:.85fr 1.15fr;gap:80px;align-items:center}
.intro-img{aspect-ratio:5/6;background:url('../img/new-build.jpg') center/cover}
.intro h2{margin-bottom:22px;font-weight:500}
.intro .lead{margin-bottom:20px}
.intro ul.bullets{list-style:none;padding:0;margin:24px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:14px 28px}
.intro ul.bullets li{position:relative;padding-left:22px;font-size:15px;color:var(--ink-2);line-height:1.5}
.intro ul.bullets li::before{content:'';position:absolute;left:0;top:8px;width:10px;height:1px;background:var(--ink)}

/* SECTION HEAD */
.sec-head{max-width:760px;margin-bottom:48px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head .eyebrow{margin-bottom:14px}
.sec-head h2{margin-bottom:18px;font-weight:500}
.sec-head p{font-size:17px}

/* SERVICES */
.services{background:#fff;padding:96px 0;border-top:1px solid var(--line)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.svc{background:#fff;padding:32px 28px;display:flex;flex-direction:column;gap:14px;transition:background .15s}
.svc:hover{background:var(--gray-1)}
.svc .ico{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--ink);margin-bottom:6px}
.svc h3{font-size:19px;font-weight:600;letter-spacing:-.005em}
.svc p{font-size:14.5px;line-height:1.6;color:var(--ink-2)}
.svc .scope{font-size:13px;color:var(--ink-3);margin-top:8px;line-height:1.55}
.svc .scope strong{color:var(--ink);font-weight:500}
/* ──────────────────────────────────────────────────────────────────────────────
   SCROLL REVEAL ANIMATIONS
   .reveal           → fades + slides up when entering viewport
   .reveal.from-left → slides in from the left instead of from below
   .reveal.from-right→ slides in from the right
   .reveal-stagger > .reveal → children animate one after another
   .is-visible       → applied by JS once element enters viewport
   Respects prefers-reduced-motion.
   ────────────────────────────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.22,.61,.36,1),transform .9s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform}
.reveal.from-left{transform:translateX(-36px)}
.reveal.from-right{transform:translateX(36px)}
.reveal.from-scale{transform:scale(.96)}
.reveal.is-visible{opacity:1;transform:translate(0,0) scale(1)}
.reveal-stagger > .reveal{transition-delay:0s}
.reveal-stagger > .reveal.is-visible:nth-child(1){transition-delay:.05s}
.reveal-stagger > .reveal.is-visible:nth-child(2){transition-delay:.15s}
.reveal-stagger > .reveal.is-visible:nth-child(3){transition-delay:.25s}
.reveal-stagger > .reveal.is-visible:nth-child(4){transition-delay:.35s}
.reveal-stagger > .reveal.is-visible:nth-child(5){transition-delay:.45s}
.reveal-stagger > .reveal.is-visible:nth-child(6){transition-delay:.55s}
.reveal-stagger > .reveal.is-visible:nth-child(7){transition-delay:.65s}
.reveal-stagger > .reveal.is-visible:nth-child(8){transition-delay:.75s}
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal.from-left,.reveal.from-right,.reveal.from-scale{opacity:1 !important;transform:none !important;transition:none !important}
}

/* Hero subtle kenburns pan + zoom for that "video-like" feel */
@keyframes hero-kenburns{
  0%{transform:scale(1.05) translate3d(0,0,0)}
  100%{transform:scale(1.15) translate3d(-1.5%, -1%, 0)}
}
.hero{position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:-2%;background-image:inherit;background-size:cover;background-position:center;animation:hero-kenburns 22s ease-in-out infinite alternate;z-index:0}
.hero > *{position:relative;z-index:1}
@media (prefers-reduced-motion: reduce){
  .hero::before{animation:none}
}

/* HERO SLIDER (homepage) — overrides single-image hero when .hero-slider present */
.hero-slider{background:#111 !important}
.hero-slider::before{display:none !important}
.hero-slides{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease-in-out;will-change:opacity,transform}
video.hero-slide{width:100%;height:100%;object-fit:cover;object-position:center;background:#111}
video.hero-slide.is-active{animation:none}
.hero-video .hero-slide{transition:opacity 1.8s ease-in-out}
.hero-slide.is-active{opacity:1;animation:hero-kenburns 5s ease-in-out forwards}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%, rgba(0,0,0,.10) 40%, rgba(0,0,0,.55) 100%);pointer-events:none}
.hero-slide{filter:saturate(1.05) contrast(1.02)}
.hero-slider .container{position:relative;z-index:2}
.hero-dots{position:absolute;left:0;right:0;bottom:24px;z-index:3;display:flex;gap:10px;justify-content:center;padding:0 24px}
.hero-dot{appearance:none;border:none;background:rgba(255,255,255,.45);width:34px;height:4px;border-radius:2px;padding:0;cursor:pointer;transition:background .25s ease,width .25s ease}
.hero-dot:hover{background:rgba(255,255,255,.75)}
.hero-dot.is-active{background:#fff;width:48px}
@media (prefers-reduced-motion: reduce){
  .hero-slide.is-active{animation:none}
}
@media(max-width:600px){
  .hero-dot{width:24px}
  .hero-dot.is-active{width:34px}
  .hero-dots{bottom:14px}
  .city-why-grid{grid-template-columns:1fr !important}
}

/* Google rating badge (used on Reviews page hero + Home reviews teaser) */
.google-rating-badge{display:inline-flex;align-items:center;gap:10px;background:#fff;color:#1a1a1a;padding:10px 18px;border-radius:999px;font-size:14px;margin-top:18px;box-shadow:0 1px 2px rgba(0,0,0,.05),0 6px 24px rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.06)}
.google-rating-badge .g-stars{color:#fbbc05;letter-spacing:1px;font-size:15px}
.google-rating-badge .g-text{color:#374151;font-weight:500}
.google-rating-badge .g-text strong{color:#1a1a1a;font-weight:700}
.reviews-teaser{background:#fafafa;padding:96px 0;border-top:1px solid var(--line)}
.reviews-teaser-grid{grid-template-columns:repeat(3,1fr) !important;gap:24px !important}
@media(max-width:900px){.reviews-teaser-grid{grid-template-columns:1fr !important}}
.review-source{display:block;margin-top:6px;font-size:12px;color:var(--ink-3);letter-spacing:.02em;text-transform:uppercase}
.reviews-source-note{margin-top:48px;text-align:center;font-size:14px;color:var(--ink-3);line-height:1.6}
.reviews-source-note a{color:var(--ink);text-decoration:underline;text-underline-offset:3px}

/* Service card with photo */
.svc.has-img{padding:0;overflow:hidden}
.svc.has-img .svc-img{width:100%;aspect-ratio:4/3;background-size:cover;background-position:center;background-color:#e5e7eb;transition:transform .4s ease}
.svc.has-img:hover .svc-img{transform:scale(1.03)}
.svc.has-img .svc-body{padding:24px 24px 28px;display:flex;flex-direction:column;gap:12px}
.svc.has-img .svc-body h3{font-size:19px;font-weight:600;letter-spacing:-.005em}
.svc.has-img .svc-body p{font-size:14.5px;line-height:1.6;color:var(--ink-2)}
.svc.has-img .svc-body .scope{font-size:13px;color:var(--ink-3);margin-top:6px;line-height:1.55}

/* WORK / CASES */
.work{background:var(--gray-1);padding:96px 0}
.work-list{display:grid;grid-template-columns:1fr;gap:24px}
.case{display:grid;grid-template-columns:1.1fr 1fr;gap:0;background:#fff;overflow:hidden;border:1px solid var(--line)}
.case:nth-child(even){grid-template-columns:1fr 1.1fr}
.case:nth-child(even) .case-img{order:2}
.case-img{min-height:380px;background-size:cover;background-position:center}
.case-content{padding:44px 44px;display:flex;flex-direction:column;justify-content:center}
.case-content .tag{font-size:11px;letter-spacing:.18em;color:var(--ink-3);text-transform:uppercase;font-weight:500;margin-bottom:14px}
.case-content h3{font-size:26px;font-weight:500;letter-spacing:-.005em;margin-bottom:14px;line-height:1.2}
.case-content p{font-size:15px;line-height:1.65}
.case-meta{display:flex;gap:32px;margin-top:24px;padding-top:22px;border-top:1px solid var(--line)}
.case-meta div{display:flex;flex-direction:column;gap:4px}
.case-meta .num{font-size:22px;font-weight:500;color:var(--ink);letter-spacing:-.005em}
.case-meta .lbl{font-size:11px;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase}

/* INDUSTRIES */
.industries{padding:96px 0;background:#fff;border-top:1px solid var(--line)}
.ind-row{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.ind-img{aspect-ratio:4/3;background:url('../img/multi-building.jpg') center/cover}
.ind-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.ind-chips span{font-size:13px;padding:8px 16px;border:1px solid var(--line);background:var(--gray-1);color:var(--ink);font-weight:500}

/* PROCESS */
.process{padding:96px 0;background:var(--gray-1);border-top:1px solid var(--line)}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:48px;border-top:2px solid var(--ink)}
.step{padding:28px 22px 0 0;border-right:1px solid var(--line)}
.step:last-child{border-right:0}
.step .num{font-size:11px;font-weight:600;letter-spacing:.18em;color:var(--ink-3);margin-bottom:10px;text-transform:uppercase}
.step h4{font-size:15px;font-weight:600;margin-bottom:8px;letter-spacing:-.005em}
.step p{font-size:13.5px;line-height:1.55}

/* WHY */
.why{padding:96px 0;background:#fff;border-top:1px solid var(--line)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.why-card{padding:32px 28px;background:var(--gray-1);display:flex;flex-direction:column;gap:14px}
.why-card .ico{width:32px;height:32px;color:var(--ink)}
.why-card h3{font-size:19px;font-weight:600;letter-spacing:-.005em}
.why-card p{font-size:14.5px;line-height:1.6}

/* TEAM TEASER (home) */
.team-teaser{padding:96px 0;background:var(--gray-1);border-top:1px solid var(--line)}
.team-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.team-card{background:#fff;display:flex;flex-direction:column;border:1px solid var(--line)}
.team-card .photo{aspect-ratio:1/1;background:#fff;background-size:contain;background-position:center;background-repeat:no-repeat;position:relative;padding:8px}
.team-card .photo.placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#dee0e3 0%,#c8cbcf 100%)}
.team-card .photo.placeholder svg{width:60%;height:60%;color:#9ea1a5}
.team-card .info{padding:24px 26px 26px}
.team-card .info .name{font-size:18px;font-weight:600;color:var(--ink);letter-spacing:-.005em}
.team-card .info .role{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-top:6px;font-weight:500}
.team-card .info .bio{font-size:14px;line-height:1.6;margin-top:14px;color:var(--ink-2)}

/* ABOUT */
.about{padding:96px 0;background:var(--gray-1);border-top:1px solid var(--line)}
.about-row{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.about-img{aspect-ratio:4/5;background:url('../img/team-portrait.jpg') center/cover}
.about h2{margin-bottom:18px;font-weight:500}
.about .lead{margin-bottom:20px}

/* CTA BAND */
.cta-band{background:var(--black);color:#fff;padding:72px 0;text-align:center}
.cta-band h2{color:#fff;font-weight:500;font-size:clamp(28px,3.2vw,40px);max-width:760px;margin:0 auto 18px}
.cta-band p{color:rgba(255,255,255,.7);max-width:560px;margin:0 auto 30px}
.cta-band .btn-row{justify-content:center;display:flex;gap:12px;flex-wrap:wrap}

/* CONTACT */
.contact-section{background:var(--black);color:#fff;padding:96px 0}
.contact-section .eyebrow.light{margin-bottom:14px}
.contact-section h2{color:#fff;font-weight:500;font-size:clamp(28px,3.2vw,42px);max-width:760px;margin-bottom:20px}
.contact-section .lead{color:rgba(255,255,255,.78);max-width:600px;margin-bottom:48px}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start}
.contact-info{display:grid;grid-template-columns:1fr;gap:32px}
.info-card{padding-top:24px;border-top:1px solid rgba(255,255,255,.15)}
.info-card .lbl{font-size:11px;letter-spacing:.22em;color:rgba(255,255,255,.6);text-transform:uppercase;margin-bottom:14px;font-weight:500}
.info-card .name{font-size:16px;font-weight:600;letter-spacing:-.005em;color:#fff}
.info-card .role{font-size:12px;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.06em;margin:4px 0 14px}
.info-card .line{font-size:14px;color:rgba(255,255,255,.92);line-height:1.7}
.info-card a:hover{color:#fff;text-decoration:underline}

form.inq{display:grid;grid-template-columns:1fr 1fr;gap:10px}
form.inq .full{grid-column:span 2}
form.inq input,form.inq select,form.inq textarea{width:100%;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.05);height:48px;padding:0 14px;font-family:'Inter';font-size:14px;color:#fff;border-radius:0}
form.inq textarea{height:120px;padding:14px;resize:vertical}
form.inq input::placeholder,form.inq textarea::placeholder{color:rgba(255,255,255,.5)}
form.inq select{color:rgba(255,255,255,.7)}
form.inq select option{color:#111}
form.inq input:focus,form.inq select:focus,form.inq textarea:focus{outline:none;border-color:#fff;background:rgba(255,255,255,.08)}
form.inq button{grid-column:span 2;background:#fff;color:var(--black);border:0;padding:16px;font-family:'Inter';font-size:14px;letter-spacing:.02em;font-weight:600;cursor:pointer;transition:background .15s}
form.inq button:hover{background:var(--gray-2)}

/* FOOTER */
footer{background:#0a0a0a;color:#9aa0a6;padding:64px 0 28px;font-size:13.5px;border-top:1px solid #1c1c1c}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
footer .brand img{height:36px;width:auto;margin-bottom:14px}
footer .brand p{color:#9aa0a6;line-height:1.65;margin-top:8px;max-width:320px}
footer h4{color:#fff;font-size:12px;letter-spacing:.08em;margin:0 0 16px;font-weight:600;text-transform:uppercase}
footer ul{list-style:none;padding:0;margin:0;line-height:2.1}
footer ul a{color:#9aa0a6}
footer ul a:hover{color:#fff}
.foot-bottom{border-top:1px solid #1f1f1f;padding-top:22px;display:flex;justify-content:space-between;color:#6f747a;font-size:12px}

/* FLOATING CTA */
.float-cta{position:fixed;right:20px;bottom:20px;z-index:40;background:var(--black);color:#fff;font-family:'Inter';letter-spacing:.02em;font-size:14px;padding:14px 22px;font-weight:600;box-shadow:0 12px 30px rgba(0,0,0,.35);opacity:0;pointer-events:none;transform:translateY(10px);transition:all .22s ease;cursor:pointer}
.float-cta.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.float-cta:hover{background:#1f2126}

/* TEAM PAGE (full) */
.team-full{padding:96px 0;background:#fff}
.team-block{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;margin-bottom:96px;align-items:start}
.team-block:last-child{margin-bottom:0}
.team-block:nth-child(even){grid-template-columns:1.1fr .9fr}
.team-block:nth-child(even) .team-photo{order:2}
.team-photo{aspect-ratio:1/1;background-size:cover;background-position:center center;background-repeat:no-repeat;background-color:#e8e8e8;border-radius:50%;overflow:hidden}
.team-photo.placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#dee0e3 0%,#c8cbcf 100%)}
.team-photo.placeholder svg{width:50%;height:50%;color:#9ea1a5}
.team-body .eyebrow{margin-bottom:12px}
.team-body h2{font-size:34px;font-weight:500;letter-spacing:-.005em;margin-bottom:6px;line-height:1.15}
.team-body .role-line{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font-weight:500;margin-bottom:24px}
.team-body p{font-size:16px;line-height:1.7;margin-bottom:14px}
/* Bio toggle button — hidden on desktop; bios show inline. Visible on mobile only. */
.bio-toggle{display:none}
.bio-content{margin-top:0;overflow:visible}
.bio-content[hidden]{display:block !important}
.bio-content p:first-child{margin-top:0}

@media (max-width: 760px){
  .bio-toggle{display:inline-flex;align-items:center;gap:14px;background:transparent;border:1px solid var(--ink);color:var(--ink);font-family:inherit;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;padding:13px 22px;cursor:pointer;transition:background .18s ease,color .18s ease;border-radius:0;margin-top:4px}
  .bio-toggle:hover{background:var(--ink);color:#fff}
  .bio-toggle-icon{font-family:inherit;font-size:18px;line-height:1;font-weight:400;display:inline-block;transition:transform .25s ease;transform-origin:center}
  .bio-toggle[aria-expanded="true"] .bio-toggle-icon{transform:rotate(45deg)}
  .bio-content{margin-top:24px;overflow:hidden}
  .bio-content[hidden]{display:none !important}
  .bio-content.is-animating{display:block !important}
}
.team-body .contact-row{display:flex;flex-wrap:wrap;gap:24px;margin-top:24px;padding-top:24px;border-top:1px solid var(--line);font-size:14px;color:var(--ink-2)}
.team-body .contact-row a{color:var(--ink);font-weight:500}
.team-body .contact-row a:hover{text-decoration:underline}

/* RESPONSIVE */

/* ---------------- 3D STUDIO ---------------- */
/* Home page teaser */
.studio-teaser{background:var(--gray-1);padding:96px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.studio-teaser-row{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.studio-teaser-copy .eyebrow{margin-bottom:14px}
.studio-teaser-copy h2{font-weight:500;font-size:clamp(28px,3.2vw,42px);letter-spacing:-.015em;line-height:1.12;margin-bottom:14px}
.studio-teaser-copy .lead{font-size:17px;color:var(--ink-2);max-width:520px}
.studio-teaser-visual{position:relative}
.studio-thumb{aspect-ratio:4/3;background-size:cover;background-position:center;position:relative;box-shadow:0 30px 60px -20px rgba(0,0,0,.25)}
.studio-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.35) 100%)}
.studio-thumb-badge{position:absolute;left:18px;top:18px;background:#fff;padding:12px 16px;display:flex;flex-direction:column;gap:4px;box-shadow:0 8px 24px rgba(0,0,0,.18);z-index:2}
.studio-thumb-badge .badge-eye{font-family:'Inter';font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.studio-thumb-badge .badge-lbl{font-family:'Inter';font-size:13px;font-weight:600;color:var(--black);letter-spacing:.01em}

/* Services page CTA band */
.studio-cta-band{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:72px 0}
.studio-cta-row{display:grid;grid-template-columns:1.4fr .6fr;gap:48px;align-items:center}
.studio-cta-row .eyebrow{margin-bottom:12px}
.studio-cta-row h2{font-weight:500;font-size:clamp(26px,2.8vw,36px);letter-spacing:-.015em;line-height:1.15;margin-bottom:12px}
.studio-cta-row .lead{font-size:16px;color:var(--ink-2);max-width:620px}
.studio-cta-action{display:flex;justify-content:flex-end}

/* Dedicated studio page */
.page-hero-compact{padding:96px 0 48px}
.page-hero-compact h1{font-size:clamp(32px,3.6vw,44px)}
.page-hero-compact .lead{font-size:16px;margin-top:16px}
.studio-frame-section{padding:0 0 64px;background:#fff}
.studio-page-frame{width:100%;background:#0a0a0a;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative}
.studio-page-frame iframe{display:block;width:100%;height:calc(100vh - 90px);min-height:720px;border:0;background:#0a0a0a}
.studio-fallback{display:none;position:absolute;inset:0;background:#0a0a0a;color:#fff;align-items:center;justify-content:center;text-align:center;padding:40px}
.studio-fallback-inner{max-width:520px}
.studio-fallback-inner .eyebrow{color:rgba(255,255,255,.6);font-family:'Inter';font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:600;margin-bottom:14px;display:block}
.studio-fallback-inner h3{font-weight:500;font-size:24px;letter-spacing:-.01em;line-height:1.2;margin-bottom:12px;color:#fff}
.studio-fallback-inner p{color:rgba(255,255,255,.75);font-size:15px;line-height:1.55;margin-bottom:22px}
.studio-fallback-inner .btn-dark{background:#fff;color:#0a0a0a}
.studio-fallback-inner .btn-dark:hover{background:var(--gray-2)}
.studio-frame-note{margin-top:20px;font-size:13px;color:var(--ink-3);text-align:center}
.studio-frame-note a{color:var(--black);text-decoration:underline;text-underline-offset:3px;margin-left:6px}
.studio-how{padding:96px 0;background:var(--gray-1);border-top:1px solid var(--line)}
.studio-how .section-head{text-align:center;max-width:760px;margin:0 auto 56px}
.studio-how .section-head .eyebrow{margin-bottom:14px}
.studio-how .section-head h2{font-weight:500;font-size:clamp(28px,3.2vw,42px);letter-spacing:-.015em;line-height:1.12}
.studio-how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.studio-how-card{background:#fff;padding:32px 28px;border:1px solid var(--line);position:relative}
.studio-how-num{font-family:'Inter';font-size:12px;letter-spacing:.28em;color:var(--ink-3);font-weight:600;margin-bottom:18px}
.studio-how-card h3{font-weight:500;font-size:19px;letter-spacing:-.005em;margin-bottom:10px}
.studio-how-card p{font-size:14.5px;color:var(--ink-2);line-height:1.55}



/* ---------------- SERVICE CARDS WITH IMAGES ---------------- */
.svc.has-img{padding:0;overflow:hidden}
.svc.has-img:hover{background:#fff}
.svc.has-img .svc-img{width:100%;aspect-ratio:16/10;background-size:cover;background-position:center;background-color:var(--gray-2);transition:transform .5s ease}
.svc.has-img:hover .svc-img{transform:scale(1.03)}
.svc.has-img .svc-body{padding:24px 26px 28px;display:flex;flex-direction:column;gap:12px;flex:1}
.svc.has-img .svc-body h3{margin-bottom:2px}
.svc.has-img .svc-body p{font-size:14.5px;line-height:1.6;color:var(--ink-2)}
.svc.has-img .svc-body .scope{font-size:13px;color:var(--ink-3);margin-top:6px;line-height:1.55}
.svc.has-img .svc-body .scope strong{color:var(--ink);font-weight:500}

/* CTA card filling the empty grid cell */
.svc.svc-cta{background:var(--black);color:#fff;padding:36px 30px;justify-content:space-between;text-decoration:none;transition:background .18s;min-height:340px}
.svc.svc-cta:hover{background:#1f2126}
.svc.svc-cta .svc-cta-eye{font-family:'Inter';font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:500;display:block;margin-bottom:auto}
.svc.svc-cta .svc-cta-title{display:block;font-size:23px;font-weight:500;line-height:1.2;letter-spacing:-.015em;color:#fff;margin:16px 0 36px}
.svc.svc-cta .svc-cta-arrow{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.02em;color:#fff;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:4px;align-self:flex-start}

@media (max-width:1100px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(3,1fr)}
  .step{border-bottom:1px solid var(--line);padding:22px 22px 22px 0}
  .why-grid{grid-template-columns:1fr 1fr}
  .menu a:not(.cta){display:none}
  .menu .hamb{display:inline-flex}
  .team-row{grid-template-columns:1fr}
}
@media (max-width:780px){
  .container{padding:0 20px}
  section,.intro,.services,.work,.industries,.process,.why,.about,.contact-section,.team-teaser,.team-full,.cta-band{padding:56px 0}
  h1{font-size:36px;line-height:1.1}
  h2{font-size:26px;line-height:1.18}
  .hero{min-height:560px;padding:60px 0}
  .hero .sub{font-size:16px}
  .hero .btn-row{flex-direction:column;align-items:stretch}
  .hero .btn-row .btn{justify-content:center}
  .page-hero{padding:80px 0 60px}
  .top-row{min-height:60px}
  .menu a.cta{display:none}
  .trust-row{flex-direction:column;align-items:flex-start;gap:18px}
  .intro-row,.ind-row,.about-row{grid-template-columns:1fr;gap:36px}
  .intro ul.bullets{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .case,.case:nth-child(even){grid-template-columns:1fr !important}
  .case-img{min-height:240px;order:0 !important}
  .case-content{padding:28px;order:1 !important}
  .case-meta{gap:24px}
  .steps{grid-template-columns:1fr}
  .step{border-right:0;padding:22px 0}
  .why-grid{grid-template-columns:1fr}
  .team-row{grid-template-columns:1fr}
  .team-block,.team-block:nth-child(even){grid-template-columns:1fr;gap:32px;margin-bottom:64px}
  .team-block:nth-child(even) .team-photo{order:0}
  .team-body h2{font-size:28px}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  form.inq{grid-template-columns:1fr}
  form.inq .full{grid-column:span 1}
  form.inq button{grid-column:span 1}
  .foot-top{grid-template-columns:1fr;gap:32px;margin-bottom:28px}
  .foot-bottom{flex-direction:column;gap:8px;align-items:flex-start}
  .float-cta{right:12px;bottom:12px;font-size:13px;padding:11px 16px}
  .studio-teaser{padding:64px 0}
  .studio-teaser-row{grid-template-columns:1fr;gap:36px}
  .studio-teaser-copy .lead{max-width:none}
  .studio-cta-band{padding:56px 0}
  .studio-cta-row{grid-template-columns:1fr;gap:24px}
  .studio-cta-action{justify-content:flex-start}
  .studio-frame-section{padding:32px 0 64px}
  .studio-page-frame iframe{height:calc(100vh - 70px);min-height:560px}
  .studio-how{padding:64px 0}
  .studio-how .section-head{margin-bottom:36px}
  .studio-how-grid{grid-template-columns:1fr;gap:14px}
  .studio-how-card{padding:24px}
}

/* =========================================================
   DROPDOWN NAV — desktop
   ========================================================= */
.menu .nav-item{position:relative;display:flex;align-items:center}
.menu .nav-link{padding:10px 16px;font-size:13px;font-weight:500;letter-spacing:.02em;color:var(--ink);transition:color .15s;cursor:pointer;display:flex;align-items:center;gap:5px}
.menu .nav-link.plain{padding:10px 16px;font-size:13px;font-weight:500;letter-spacing:.02em;color:var(--ink);transition:color .15s}
.menu .nav-link:hover,.menu .nav-link.plain:hover{color:var(--ink-3)}
.menu .nav-item.active > .nav-link{color:var(--ink);position:relative}
.menu .nav-item.active > .nav-link::after{content:'';position:absolute;left:16px;right:16px;bottom:6px;height:1px;background:var(--ink)}
.menu .has-dropdown > .nav-link::before{content:'';display:inline-block;width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin-left:2px;transition:transform .15s;position:relative;top:-1px}
.menu .has-dropdown:hover > .nav-link::before,.menu .has-dropdown:focus-within > .nav-link::before{transform:rotate(-135deg)}

.dropdown{display:none;position:absolute;top:calc(100% + 1px);left:0;min-width:220px;max-width:280px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 24px rgba(0,0,0,.10);z-index:50;transform:translateY(-4px);opacity:0;transition:transform .15s ease,opacity .15s ease;pointer-events:none}
.nav-item:hover .dropdown,.nav-item:focus-within .dropdown{display:block;transform:translateY(0);opacity:1;pointer-events:auto}
.dropdown a{display:block;padding:11px 16px;font-size:13px;font-weight:500;color:var(--ink);letter-spacing:.01em;border-bottom:1px solid var(--line);transition:background .12s}
.dropdown a:last-child{border-bottom:0}
.dropdown a:hover{background:var(--gray-1)}

/* Mobile nav sub-items */
.mob-sub-head{display:block;font-size:12px;color:var(--ink-3);letter-spacing:.1em;text-transform:uppercase;padding:8px 4px 4px;border-bottom:1px solid var(--line)}
.mobile-panel nav .mob-sub{padding:14px 4px 14px 20px;font-size:16px;border-bottom:1px solid var(--line);color:var(--ink-2)}

/* =========================================================
   UPDATED FOOTER — 3-col layout
   ========================================================= */
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;margin-bottom:48px}
.foot-bottom a{color:#6f747a;transition:color .15s}
.foot-bottom a:hover{color:#fff}

/* =========================================================
   REVIEWS PAGE
   ========================================================= */
.reviews-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.review-card{background:var(--gray-1);padding:32px 28px;border:1px solid var(--line);display:flex;flex-direction:column;gap:16px}
.review-stars{line-height:1}
.review-text{font-size:15px;line-height:1.7;color:var(--ink-2);font-style:italic}
.review-meta{font-size:13px;color:var(--ink-3);font-weight:500}
@media(max-width:780px){.reviews-grid{grid-template-columns:1fr}}

/* =========================================================
   FAQ PAGE
   ========================================================= */
.faq-item{padding:28px 0;border-bottom:1px solid var(--line)}
.faq-item:last-child{border-bottom:0}
.faq-q{font-size:18px;font-weight:500;margin-bottom:12px;letter-spacing:-.005em;line-height:1.3}
.faq-a{font-size:15px;line-height:1.7;color:var(--ink-2)}

/* =========================================================
   LOCATIONS PAGE
   ========================================================= */
.locations-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px 16px;margin-top:8px}
.location-link{font-size:14px;font-weight:500;color:var(--ink);padding:10px 0;border-bottom:1px solid var(--line);transition:color .15s}
.location-link:hover{color:var(--ink-3)}
@media(max-width:780px){
  .locations-grid{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr;gap:32px;margin-bottom:28px}
}

/* Responsive tweaks for dropdown */
@media(max-width:860px){
  .menu .nav-item.has-dropdown{display:none}
  .menu .nav-link.plain{display:none}
  .menu .hamb{display:inline-flex}
  .menu .cta{display:none}
}
@media(max-width:780px){
  .menu .hamb{display:inline-flex}
}
