/* =========================================================================
   CREO STUDIO — design system
   Editorial interior-design aesthetic · Inter · navy + burnt orange + cream
   ========================================================================= */

:root{
  --ink:#283050;          /* logo navy */
  --ink-deep:#1d2440;
  --accent:#e85818;       /* burnt orange C-mark */
  --accent-soft:#f4a16f;
  --steel:#2b5672;
  --paper:#fbf8f4;        /* warm cream page */
  --paper-2:#f4eee6;      /* warmer panel */
  --paper-3:#efe7db;
  --text:#2b2b31;
  --muted:#6c6c75;
  --line:#e4ddd2;
  --line-ink:rgba(40,48,80,.12);
  --white:#ffffff;

  --maxw:1280px;
  --gutter:clamp(20px,5vw,72px);
  --radius:2px;

  --serif:"Inter",system-ui,sans-serif; /* (all Inter per brief) */
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;

  --t-fast:.25s cubic-bezier(.4,0,.2,1);
  --t-med:.5s cubic-bezier(.22,1,.36,1);
  --t-slow:.9s cubic-bezier(.22,1,.36,1);

  --shadow-sm:0 2px 14px rgba(28,28,40,.06);
  --shadow:0 18px 50px -20px rgba(28,30,55,.28);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--sans);background:var(--paper);color:var(--text);
  font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--accent);color:#fff}

/* ---- type ---- */
h1,h2,h3,h4{margin:0;font-weight:600;line-height:1.06;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.6rem,6.6vw,5.6rem);font-weight:600}
h2{font-size:clamp(2rem,4.4vw,3.4rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.85rem);letter-spacing:-.015em}
p{margin:0 0 1.1em}
.lead{font-size:clamp(1.12rem,1.7vw,1.45rem);line-height:1.55;color:#43434c;font-weight:400;letter-spacing:-.01em}
.display{font-weight:600}
.serif{font-family:var(--serif)}

.eyebrow{
  font-size:.72rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent);display:inline-flex;align-items:center;gap:.7em;margin:0 0 1.3rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block}
.eyebrow.center{justify-content:center}
.eyebrow.muted{color:var(--steel)}
.eyebrow.muted::before{background:var(--steel)}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.wrap-wide{max-width:1500px;margin:0 auto;padding-inline:var(--gutter)}
section{position:relative}
.section{padding:clamp(72px,11vw,150px) 0}
.section-sm{padding:clamp(54px,8vw,96px) 0}
.bg-paper2{background:var(--paper-2)}
.bg-ink{background:var(--ink);color:#e9eaf1}
.bg-ink h1,.bg-ink h2,.bg-ink h3{color:#fff}

/* ================= NAV ================= */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gutter);transition:background var(--t-fast),padding var(--t-fast),box-shadow var(--t-fast);
}
.nav__logo{display:flex;align-items:center;gap:12px;z-index:2}
.nav__logo img{height:30px;width:auto;transition:opacity var(--t-fast)}
.nav__logo .logo-dark{position:absolute;opacity:0}
.nav__links{display:flex;align-items:center;gap:38px}
.nav__links a{
  position:relative;font-size:.82rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:#fff;opacity:.92;padding:4px 0;transition:opacity var(--t-fast),color var(--t-fast);
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--accent);transition:width var(--t-med)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after,.nav__links a[aria-current="page"]::after{width:100%}
.nav__links a[aria-current="page"]{color:var(--accent);opacity:1}
.nav__cta{
  border:1px solid rgba(255,255,255,.5);color:#fff;padding:11px 24px;border-radius:100px;
  font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;
  margin-left:14px;transition:all var(--t-fast);
}
.nav__cta:hover{background:#fff;color:var(--ink);border-color:#fff}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;z-index:2}
.nav__burger span{width:26px;height:2px;background:#fff;display:block;transition:var(--t-fast)}

/* scrolled / solid nav */
.nav.solid{background:rgba(251,248,244,.92);backdrop-filter:saturate(1.6) blur(14px);box-shadow:0 1px 0 var(--line);padding-top:13px;padding-bottom:13px}
.nav.solid .nav__logo .logo-light{opacity:0}
.nav.solid .nav__logo .logo-dark{opacity:1;position:static}
.nav.solid .nav__logo .logo-light{position:absolute}
.nav.solid .nav__links a{color:var(--ink)}
.nav.solid .nav__links a[aria-current="page"]{color:var(--accent)}
.nav.solid .nav__cta{border-color:var(--line-ink);color:var(--ink)}
.nav.solid .nav__cta:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.nav.solid .nav__burger span{background:var(--ink)}
/* pages with light hero use solid from start */
body.nav-solid .nav{background:rgba(251,248,244,.92);backdrop-filter:saturate(1.6) blur(14px);box-shadow:0 1px 0 var(--line)}
body.nav-solid .nav .nav__logo .logo-light{opacity:0;position:absolute}
body.nav-solid .nav .nav__logo .logo-dark{opacity:1;position:static}
body.nav-solid .nav__links a{color:var(--ink)}
body.nav-solid .nav__cta{border-color:var(--line-ink);color:var(--ink)}
body.nav-solid .nav__burger span{background:var(--ink)}

/* ================= BUTTONS ================= */
.btn{
  display:inline-flex;align-items:center;gap:.7em;border:0;border-radius:100px;
  padding:16px 30px;font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  transition:all var(--t-fast);white-space:nowrap;
}
.btn svg{width:15px;height:15px;transition:transform var(--t-fast)}
.btn:hover svg{transform:translateX(4px)}
.btn--accent{background:var(--accent);color:#fff;box-shadow:0 12px 30px -12px rgba(232,88,24,.7)}
.btn--accent:hover{background:#d24c11;transform:translateY(-2px)}
.btn--ink{background:var(--ink);color:#fff}
.btn--ink:hover{background:var(--ink-deep);transform:translateY(-2px)}
.btn--ghost{background:transparent;border:1px solid var(--line-ink);color:var(--ink)}
.btn--ghost:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.btn--light{background:#fff;color:var(--ink)}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.link-arrow{display:inline-flex;align-items:center;gap:.55em;font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.link-arrow svg{width:16px;height:16px;transition:transform var(--t-fast)}
.link-arrow:hover{color:var(--accent)}
.link-arrow:hover svg{transform:translateX(5px)}

/* ================= HERO ================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:heroZoom 9s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,24,42,.55) 0%,rgba(20,24,42,.12) 32%,rgba(20,24,42,.35) 72%,rgba(16,18,34,.86) 100%)}
.hero__inner{position:relative;z-index:1;width:100%;padding-bottom:clamp(48px,8vw,96px)}
.hero h1{color:#fff;max-width:16ch}
.hero__sub{color:rgba(255,255,255,.86);max-width:46ch;margin-top:1.4rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:2.3rem}
.hero__btn2{background:rgba(18,20,34,.30);border:1px solid rgba(255,255,255,.85);color:#fff}
.hero__btn2:hover{background:#fff;border-color:#fff;color:var(--ink)}
.hero__meta{position:absolute;right:var(--gutter);bottom:clamp(48px,8vw,96px);z-index:1;text-align:right;display:none}
.hero__scroll{position:absolute;left:var(--gutter);bottom:26px;z-index:1;color:rgba(255,255,255,.7);font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;display:flex;align-items:center;gap:10px}
.hero__scroll::after{content:"";width:1px;height:34px;background:rgba(255,255,255,.5);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{transform:scaleY(.5);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* page hero (interior pages) */
.phero{padding:clamp(150px,20vw,230px) 0 clamp(40px,6vw,72px);background:var(--paper);position:relative}
.phero .eyebrow{margin-bottom:1.5rem}
.phero h1{max-width:18ch}
.phero__lead{max-width:54ch;margin-top:1.5rem}

/* ================= MARQUEE (two-direction portfolio ribbon) ================= */
.marquee{padding:clamp(40px,6vw,72px) 0;overflow:hidden;background:var(--ink)}
.marquee__row{display:flex;gap:18px;width:max-content;will-change:transform}
.marquee__row.r1{animation:scrollL 60s linear infinite}
.marquee__row.r2{animation:scrollR 60s linear infinite;margin-top:18px}
.marquee:hover .marquee__row{animation-play-state:paused}
@keyframes scrollL{to{transform:translateX(-50%)}}
@keyframes scrollR{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.marquee__item{flex:0 0 auto;width:clamp(220px,26vw,360px);aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;position:relative}
.marquee__item img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.marquee__item:hover img{transform:scale(1.07)}

/* word marquee (credentials) */
.wordmarquee{background:var(--accent);color:#fff;overflow:hidden;padding:14px 0;border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12)}
.wordmarquee__row{display:flex;gap:0;width:max-content;animation:scrollL 38s linear infinite}
.wordmarquee span{font-size:1.05rem;font-weight:600;letter-spacing:.04em;padding:0 28px;display:inline-flex;align-items:center;gap:28px;white-space:nowrap}
.wordmarquee span::after{content:"✦";font-size:.7rem;opacity:.7}

/* ================= INTRO / SPLIT ================= */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center}
.split--img-r{grid-template-columns:1.05fr .95fr}
.split__media{position:relative}
.split__media img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow)}
.split__media .stamp{position:absolute;bottom:-26px;right:-10px;background:var(--accent);color:#fff;
  width:128px;height:128px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:var(--shadow);transform:rotate(-6deg)}
.split__media .stamp b{font-size:2rem;line-height:1}
.split__media .stamp small{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;margin-top:4px;opacity:.92}

.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-top:3rem}
.pillar{background:var(--paper);padding:34px 30px;transition:background var(--t-fast)}
.pillar:hover{background:var(--paper-2)}
.pillar .n{font-size:.72rem;letter-spacing:.2em;color:var(--accent);font-weight:700}
.pillar h3{margin:14px 0 8px;font-size:1.3rem}
.pillar p{font-size:.95rem;color:var(--muted);margin:0}

/* ================= STATS ================= */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px)}
.stat{text-align:center;padding:10px}
.stat b{display:block;font-size:clamp(2.6rem,5vw,4rem);font-weight:600;color:var(--ink);letter-spacing:-.03em;line-height:1}
.stat .u{color:var(--accent)}
.stat span{display:block;margin-top:.7rem;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* ================= SERVICES ================= */
.services{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-ink);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-ink)}
.service{background:var(--paper);padding:clamp(28px,4vw,48px);transition:background var(--t-med);position:relative}
.service:hover{background:#fff}
.service__no{font-size:.78rem;font-weight:700;letter-spacing:.18em;color:var(--accent)}
.service h3{margin:18px 0 12px;font-size:1.5rem}
.service p{color:var(--muted);margin:0;font-size:.98rem}
.service__ico{width:44px;height:44px;margin-bottom:6px;color:var(--ink)}

/* ================= PROJECTS GRID ================= */
.workgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.4vw,32px)}
.pcard{position:relative;display:block;border-radius:var(--radius);overflow:hidden;background:#11131f;cursor:pointer}
.pcard__img{aspect-ratio:4/3;overflow:hidden;position:relative}
.pcard__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.22,1,.36,1);transform:scale(1.01)}
.pcard:hover .pcard__img img{transform:scale(1.08)}
.pcard__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,17,30,0) 38%,rgba(15,17,30,.82) 100%);transition:opacity var(--t-med)}
.pcard__body{position:absolute;left:0;right:0;bottom:0;padding:clamp(20px,3vw,34px);z-index:2;color:#fff;transform:translateY(8px);transition:transform var(--t-med)}
.pcard:hover .pcard__body{transform:translateY(0)}
.pcard__meta{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-soft);margin-bottom:.5rem}
.pcard h3{color:#fff;font-size:clamp(1.3rem,2.2vw,1.9rem)}
.pcard__desc{font-size:.92rem;color:rgba(255,255,255,.8);margin:.5rem 0 0;max-width:42ch;opacity:0;max-height:0;transition:opacity var(--t-med),max-height var(--t-med)}
.pcard:hover .pcard__desc{opacity:1;max-height:80px}
.pcard__tag{position:absolute;top:18px;left:18px;z-index:2;display:inline-flex;align-items:center;gap:7px;background:rgba(251,248,244,.92);color:var(--ink);font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:7px 13px;border-radius:100px}
.pcard__count{position:absolute;top:18px;right:18px;z-index:2;background:rgba(20,22,38,.6);backdrop-filter:blur(6px);color:#fff;font-size:.72rem;font-weight:600;padding:6px 12px;border-radius:100px;display:flex;align-items:center;gap:6px}
.pcard--tall .pcard__img{aspect-ratio:3/4}
.pcard--wide{grid-column:span 2}
.pcard--wide .pcard__img{aspect-ratio:16/8}
@media(max-width:760px){.pcard--wide{grid-column:span 1}.pcard--wide .pcard__img{aspect-ratio:4/3}}

/* ================= PROCESS / SKETCH ================= */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.5vw,30px);counter-reset:step}
.pstep{position:relative}
.pstep__n{font-size:.78rem;letter-spacing:.2em;color:var(--accent);font-weight:700;margin-bottom:14px}
.pstep h3{font-size:1.2rem;margin-bottom:8px}
.pstep p{font-size:.92rem;color:var(--muted);margin:0}
.pstep::before{content:"";position:absolute;top:6px;right:-15px;width:30px;height:1px;background:var(--line);display:none}
.sketchband{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:3.4rem}
.sketchband figure{margin:0;border-radius:var(--radius);overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.sketchband img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform var(--t-slow)}
.sketchband figure:hover img{transform:scale(1.05)}

/* ================= CTA BAND ================= */
.ctaband{background:var(--ink);color:#fff;border-radius:var(--radius);padding:clamp(44px,7vw,90px);position:relative;overflow:hidden;text-align:center}
.ctaband::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 140% at 50% -20%,rgba(232,88,24,.28),transparent 60%)}
.ctaband__mark{position:absolute;right:-40px;bottom:-60px;width:280px;opacity:.06;pointer-events:none}
.ctaband > *{position:relative;z-index:1}
.ctaband h2{color:#fff;max-width:18ch;margin:0 auto}
.ctaband p{color:rgba(255,255,255,.78);max-width:50ch;margin:1.2rem auto 2.2rem}

/* ================= FOOTER ================= */
.footer{background:var(--ink-deep);color:#aab0c6;padding:clamp(60px,8vw,96px) 0 34px}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(30px,4vw,60px)}
.footer__brand img{height:34px;margin-bottom:20px}
.footer__brand p{color:#9097ae;font-size:.95rem;max-width:34ch}
.footer h4{color:#fff;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;margin:0 0 18px}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.footer ul a,.footer address a{color:#aab0c6;font-size:.95rem;transition:color var(--t-fast)}
.footer ul a:hover,.footer address a:hover{color:#fff}
.footer address{font-style:normal;color:#9097ae;font-size:.95rem;line-height:1.8}
.footer__social{display:flex;gap:12px;margin-top:18px}
.footer__social a{width:40px;height:40px;border:1px solid rgba(255,255,255,.16);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}
.footer__social a:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px)}
.footer__social svg{width:17px;height:17px}
.footer__bottom{margin-top:clamp(40px,6vw,64px);padding-top:26px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:.82rem;color:#7c829c}
.footer__bottom a{color:#aeb4c9;font-weight:500}
.footer__bottom a:hover{color:var(--accent)}

/* ================= FORM ================= */
.contactgrid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,6vw,80px)}
.cinfo__block{margin-bottom:30px}
.cinfo__block h4{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin:0 0 8px}
.cinfo__block p,.cinfo__block a{margin:0;color:var(--text);font-size:1.05rem}
.cinfo__block a:hover{color:var(--accent)}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(26px,4vw,46px);box-shadow:var(--shadow-sm)}
.field{margin-bottom:20px}
.field label{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);font-weight:600;margin-bottom:9px}
.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--paper);font-family:inherit;font-size:1rem;color:var(--text);transition:border var(--t-fast),box-shadow var(--t-fast);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(232,88,24,.12);background:#fff}
.field textarea{resize:vertical;min-height:130px}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form__note{font-size:.82rem;color:var(--muted);margin:6px 0 0}
.form__success{display:none;text-align:center;padding:20px}
.form__success.show{display:block}
.form__success .tick{width:64px;height:64px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.err{border-color:#d8472f!important}
.field small.error{display:none;color:#d8472f;font-size:.78rem;margin-top:6px}
.field small.error.show{display:block}

/* map / address strip */
.addrcard{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.addrcard iframe{width:100%;height:280px;border:0;filter:grayscale(.3) contrast(1.05)}

/* ================= REVEAL ================= */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s var(--t-slow),transform .8s cubic-bezier(.22,1,.36,1)}
[data-reveal].in{opacity:1;transform:none}
/* hero content reveals on load via CSS — independent of JS, never an empty hero */
.hero [data-reveal]{animation:heroRise .9s cubic-bezier(.22,1,.36,1) both}
.hero [data-reveal][data-delay="1"]{animation-delay:.12s}
.hero [data-reveal][data-delay="2"]{animation-delay:.24s}
.hero [data-reveal][data-delay="3"]{animation-delay:.36s}
@keyframes heroRise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1!important;transform:none!important}.hero__media img{animation:none;transform:none}}

/* ================= LIGHTBOX ================= */
.lb{position:fixed;inset:0;z-index:120;background:rgba(16,17,28,.97);display:none;opacity:0;transition:opacity var(--t-fast)}
.lb.open{display:block;opacity:1}
.lb-active .nav{opacity:0;pointer-events:none;transition:opacity var(--t-fast)}
.lb__head{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:22px clamp(18px,4vw,46px);z-index:3;color:#fff}
.lb__title{font-size:.86rem;letter-spacing:.14em;text-transform:uppercase}
.lb__title b{color:#fff;font-weight:600}
.lb__title span{color:var(--accent-soft);margin-left:10px}
.lb__close{background:none;border:0;color:#fff;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background var(--t-fast)}
.lb__close:hover{background:rgba(255,255,255,.12)}
.lb__stage{position:absolute;inset:70px 0 84px;display:flex;align-items:center;justify-content:center;padding:0 clamp(8px,6vw,80px)}
.lb__img{max-width:100%;max-height:100%;object-fit:contain;border-radius:2px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:0;color:#fff;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background var(--t-fast);z-index:3}
.lb__nav:hover{background:var(--accent)}
.lb__prev{left:clamp(10px,3vw,34px)}.lb__next{right:clamp(10px,3vw,34px)}
.lb__thumbs{position:absolute;left:0;right:0;bottom:0;display:flex;gap:8px;justify-content:center;padding:14px;overflow-x:auto;z-index:3}
.lb__thumbs img{height:54px;width:74px;object-fit:cover;border-radius:2px;opacity:.45;cursor:pointer;transition:opacity var(--t-fast);border:2px solid transparent}
.lb__thumbs img.active{opacity:1;border-color:var(--accent)}
.lb__count{position:absolute;bottom:96px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:.8rem;letter-spacing:.1em;z-index:3}

/* ================= RESPONSIVE ================= */
@media (min-width:1100px){.pstep::before{display:block}.pstep:last-child::before{display:none}}
@media (max-width:980px){
  .footer__top{grid-template-columns:1fr 1fr}
  .process{grid-template-columns:repeat(2,1fr);gap:30px}
  .contactgrid{grid-template-columns:1fr;gap:40px}
}
@media (max-width:860px){
  /* backdrop-filter makes .nav a containing block for fixed children, which
     would trap the full-screen menu to the header height — disable on mobile
     and use a near-opaque bg so page content never bleeds through the bar */
  .nav.solid,body.nav-solid .nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(251,248,244,.99)}
  .nav__links{position:fixed;top:0;left:0;right:0;bottom:0;height:100dvh;width:100%;z-index:55;
    flex-direction:column;justify-content:center;gap:30px;
    background:var(--ink);transform:translateY(-100%);transition:transform var(--t-med);padding:40px}
  .nav__links.open{transform:none}
  .nav__links a{color:#fff!important;font-size:1.15rem;opacity:1}
  .nav__links .nav__cta{color:#fff;border-color:rgba(255,255,255,.5);margin-left:0;margin-top:8px}
  .nav__logo,.nav__burger{z-index:60}
  .nav__burger{display:flex}
  body.menu-open{overflow:hidden}
  .nav__burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__burger.x span:nth-child(2){opacity:0}
  .nav__burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .split{grid-template-columns:1fr;gap:40px}
  .split--img-r .split__media{order:-1}
  .stats{grid-template-columns:repeat(2,1fr);gap:34px 20px}
  .services{grid-template-columns:1fr}
  .pillars{grid-template-columns:1fr}
  .sketchband{grid-template-columns:1fr;gap:14px}
}
@media (max-width:680px){
  body{font-size:16px}
  .workgrid{grid-template-columns:1fr}
  .pcard--tall .pcard__img,.pcard__img{aspect-ratio:4/3}
  .field--row{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;text-align:center;gap:10px}
  .hero__cta{flex-direction:column}
  .hero__cta .btn{width:100%;justify-content:center}
  .nav__burger.x span{background:#fff}
}
