*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --sky:#D9F5FC;--white:#FAFCFC;--steel:#5D7D87;
  --navy:#293842;--forest:#324D46;
  --line:rgba(93,125,135,.15);--ink:#1a2730;
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--white);color:var(--navy);font-family:'Inter',sans-serif;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--white)}::-webkit-scrollbar-thumb{background:var(--steel)}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:900;display:flex;align-items:center;justify-content:space-between;padding:30px 64px;transition:padding .5s,background .5s,border-color .5s;border-bottom:1px solid transparent}
.nav.on{background:rgba(250,252,252,.96);backdrop-filter:blur(20px);padding:16px 64px;border-bottom-color:var(--line);box-shadow:0 1px 24px rgba(41,56,66,.06)}
.nav-logo{font-family:'Syne',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--white);text-decoration:none;transition:color .4s}
.nav.on .nav-logo{color:var(--navy)}
.nav-logo sup{font-size:.45em;font-weight:400;vertical-align:super;color:var(--steel);margin-left:4px}
.nav-r{display:flex;align-items:center;gap:44px}
.nav-link{font-family:'Inter',sans-serif;font-size:.68rem;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);background:none;border:none;cursor:pointer;padding:0;transition:color .25s}
.nav.on .nav-link{color:rgba(41,56,66,.5)}
.nav-link:hover{color:#fff}.nav.on .nav-link:hover{color:var(--navy)}
.nav-cta{font-family:'Inter',sans-serif;font-size:.66rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;padding:11px 26px;border:1px solid rgba(255,255,255,.35);background:none;color:rgba(255,255,255,.9);transition:all .3s}
.nav.on .nav-cta{border-color:var(--navy);color:var(--navy)}
.nav-cta:hover{background:var(--white);color:var(--navy);border-color:var(--white)}
.nav.on .nav-cta:hover{background:var(--navy);color:var(--white)}

/* HERO */
.hero{position:relative;height:100vh;min-height:700px;overflow:hidden;display:flex;align-items:flex-end;background:var(--navy)}
.hero-photo{position:absolute;inset:0}
.hero-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center}
.hero-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(12,20,26,.92) 0%,rgba(12,20,26,.55) 38%,rgba(12,20,26,.2) 70%,rgba(12,20,26,.35) 100%),linear-gradient(to right,rgba(12,20,26,.25) 0%,transparent 55%)}
.hero-top-line{position:absolute;top:0;left:0;right:0;height:3px;z-index:2;background:linear-gradient(to right,var(--sky) 0%,var(--steel) 45%,transparent 100%)}
.hero-body{position:relative;z-index:3;width:100%;padding:0 72px 96px;display:grid;grid-template-columns:1fr auto;align-items:flex-end;gap:80px}
.hero-kicker{font-family:'Inter',sans-serif;font-size:.62rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--sky);display:flex;align-items:center;gap:14px;margin-bottom:28px}
.hero-kicker::before{content:'';width:28px;height:1px;background:var(--sky);display:block}
.hero-h1{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(3.8rem,8.5vw,9.5rem);line-height:.88;letter-spacing:-.035em;color:var(--white);margin-bottom:40px}
.hero-sub{font-family:'Inter',sans-serif;font-size:.9rem;font-weight:300;line-height:1.85;color:rgba(217,245,252,.58);max-width:420px;margin-bottom:40px}
.hero-btns{display:flex;gap:14px;align-items:center}
.btn-sky{font-family:'Inter',sans-serif;font-size:.66rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;padding:16px 36px;background:var(--sky);border:2px solid var(--sky);color:var(--navy);transition:all .3s}
.btn-sky:hover{background:transparent;color:var(--sky)}
.btn-ghost{font-family:'Inter',sans-serif;font-size:.66rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;padding:16px 36px;background:none;border:1px solid rgba(217,245,252,.28);color:rgba(217,245,252,.8);transition:all .3s}
.btn-ghost:hover{border-color:rgba(217,245,252,.7);color:var(--sky)}
.hero-stats{
  display:flex;flex-direction:column;gap:0;
  width:180px;flex-shrink:0;
}
.hs-item{
  padding:18px 0;
  border-bottom:1px solid rgba(217,245,252,.08);
  display:flex;flex-direction:column;align-items:flex-end;
}
.hs-item:first-child{padding-top:0}
.hs-item:last-child{padding-bottom:0;border-bottom:none}
.hs-n{
  font-family:'Syne',sans-serif;font-weight:700;font-size:2.2rem;
  letter-spacing:-.03em;color:var(--sky);line-height:1;
  display:block;width:100%;text-align:right;
}
.hs-l{
  font-family:'Inter',sans-serif;font-size:.5rem;font-weight:400;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(217,245,252,.32);margin-top:5px;
  display:block;width:100%;text-align:right;
}
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px}
.hero-scroll-bar{width:1px;height:52px;background:linear-gradient(to bottom,rgba(217,245,252,.5),transparent);animation:pulse 2.2s ease infinite}
.hero-scroll-lbl{font-family:'Inter',sans-serif;font-size:.5rem;font-weight:400;letter-spacing:.24em;text-transform:uppercase;color:rgba(217,245,252,.28)}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:.9}}

/* BAND */
.band{background:var(--navy);padding:52px 64px;display:flex;align-items:center;justify-content:space-between;gap:40px;border-bottom:1px solid rgba(93,125,135,.2)}
.band-txt{font-family:'Syne',sans-serif;font-weight:500;font-size:1.06rem;color:rgba(217,245,252,.7);max-width:680px;line-height:1.65}
.band-txt em{font-style:normal;color:var(--sky)}
.band-tags{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap}
.btag{font-family:'Inter',sans-serif;font-size:.58rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:rgba(93,125,135,.7);padding:8px 16px;border:1px solid rgba(93,125,135,.25);white-space:nowrap}

/* SHARED */
.sec{padding:140px 64px}
.inner{max-width:1360px;margin:0 auto}
.tag{font-family:'Inter',sans-serif;font-size:.58rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--steel);display:flex;align-items:center;gap:12px;margin-bottom:18px}
.tag::before{content:'';width:20px;height:1px;background:var(--steel);display:block}
.tag.lt{color:var(--sky)}.tag.lt::before{background:var(--sky)}
.R{opacity:0;transform:translateY(28px);transition:opacity .85s cubic-bezier(.16,1,.3,1),transform .85s cubic-bezier(.16,1,.3,1)}
.R.on{opacity:1;transform:none}

/* ABOUT */
.about{background:var(--white);padding:0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;min-height:82vh}
.about-img{position:relative;overflow:hidden;background:#b8cdd3}
.about-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 60%;transition:transform .9s cubic-bezier(.16,1,.3,1)}
.about-img:hover img{transform:scale(1.04)}
.about-img-shade{position:absolute;inset:0;background:linear-gradient(to right,transparent 55%,var(--white) 100%),linear-gradient(to top,rgba(41,56,66,.35) 0%,transparent 35%)}
.about-img-cap{position:absolute;bottom:40px;left:40px;background:rgba(41,56,66,.88);backdrop-filter:blur(8px);padding:14px 20px}
.about-img-cap span{font-family:'Inter',sans-serif;font-size:.54rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--sky);display:block;margin-bottom:2px}
.about-img-cap p{font-family:'Inter',sans-serif;font-size:.8rem;font-weight:300;color:rgba(255,255,255,.72)}
.about-text{display:flex;flex-direction:column;justify-content:center;padding:100px 88px 100px 80px;background:var(--white);position:relative}
.about-yr{font-family:'Syne',sans-serif;font-weight:800;font-size:9rem;line-height:1;color:rgba(93,125,135,.06);letter-spacing:-.04em;margin-bottom:-24px;pointer-events:none;user-select:none}
.about-h{font-family:'Syne',sans-serif;font-weight:700;font-size:clamp(2.6rem,3.8vw,4.2rem);line-height:.92;letter-spacing:-.025em;color:var(--navy);margin-bottom:36px}
.about-h em{font-style:italic;font-weight:400;color:var(--steel);display:block;margin-top:5px}
.about-rule{width:36px;height:2px;background:var(--steel);margin-bottom:26px}
.about-p{font-family:'Inter',sans-serif;font-size:.9rem;font-weight:300;line-height:2.05;color:rgba(41,56,66,.62);max-width:440px;margin-bottom:56px}
.figs{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;padding-top:44px;border-top:1px solid var(--line);
}
.figs > div{
  padding-right:32px;border-right:1px solid var(--line);
}
.figs > div:last-child{border-right:none;padding-right:0;padding-left:32px}
.figs > div:nth-child(2){padding-left:32px}
.fn{
  font-family:'Syne',sans-serif;font-weight:700;font-size:2.8rem;
  letter-spacing:-.03em;color:var(--navy);line-height:1;
  margin-bottom:8px;display:block;
}
.fl{
  font-family:'Inter',sans-serif;font-size:.54rem;font-weight:400;
  letter-spacing:.18em;text-transform:uppercase;color:rgba(93,125,135,.6);
  display:block;
}

/* SERVICES */
.services{background:var(--navy)}
.svc-head{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;margin-bottom:96px}
.svc-h{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(3.2rem,5.5vw,6rem);line-height:.9;letter-spacing:-.03em;color:var(--white)}
.svc-h span{display:block;-webkit-text-stroke:1px rgba(217,245,252,.18);color:transparent}
.svc-intro{font-family:'Inter',sans-serif;font-size:.86rem;font-weight:300;line-height:2;color:rgba(217,245,252,.36);max-width:380px}
.svc-row{display:grid;grid-template-columns:60px 1fr 1fr auto;align-items:center;gap:40px;padding:32px 0;border-top:1px solid rgba(93,125,135,.18);cursor:pointer;position:relative;overflow:hidden;transition:padding-left .4s cubic-bezier(.16,1,.3,1)}
.svc-row:last-child{border-bottom:1px solid rgba(93,125,135,.18)}
.svc-row::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:rgba(217,245,252,.025);transition:width .45s cubic-bezier(.16,1,.3,1)}
.svc-row:hover{padding-left:18px}.svc-row:hover::before{width:100%}
.svc-n{font-family:'Syne',sans-serif;font-weight:400;font-size:.68rem;letter-spacing:.18em;color:rgba(93,125,135,.4);transition:color .3s}
.svc-row:hover .svc-n{color:var(--sky)}
.svc-name{font-family:'Syne',sans-serif;font-weight:600;font-size:clamp(1.4rem,2.4vw,2.1rem);letter-spacing:-.015em;color:var(--white);transition:color .3s}
.svc-row:hover .svc-name{color:var(--sky)}
.svc-desc{font-family:'Inter',sans-serif;font-size:.76rem;font-weight:300;line-height:1.7;color:rgba(217,245,252,.26);transition:color .3s}
.svc-row:hover .svc-desc{color:rgba(217,245,252,.52)}
.svc-arr{font-size:1rem;color:rgba(93,125,135,.25);opacity:0;transform:translateX(-8px);transition:all .35s cubic-bezier(.16,1,.3,1)}
.svc-row:hover .svc-arr{opacity:1;transform:none;color:var(--sky)}

/* PROJECTS */
.projects{background:var(--white);padding:140px 0}
.proj-head{padding:0 64px;margin-bottom:72px;display:flex;justify-content:space-between;align-items:flex-end}
.proj-head-h{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(3rem,5vw,5.5rem);line-height:.9;letter-spacing:-.03em;color:var(--navy)}
.proj-head-sub{font-family:'Inter',sans-serif;font-size:.76rem;font-weight:300;color:rgba(41,56,66,.42);max-width:300px;line-height:1.82;text-align:right}
.proj-feat{position:relative;overflow:hidden;margin:0 64px;height:68vh;min-height:520px;max-height:700px;background:#b0c4cc}
.proj-feat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;filter:brightness(.85);transition:transform .9s cubic-bezier(.16,1,.3,1),filter .5s}
.proj-feat:hover img{transform:scale(1.03);filter:brightness(.9)}
.proj-feat-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(41,56,66,.94) 0%,rgba(41,56,66,.28) 50%,transparent 100%)}
.proj-feat-label{position:absolute;top:36px;left:36px;font-family:'Inter',sans-serif;font-size:.56rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;background:var(--sky);color:var(--navy);padding:6px 14px}
.proj-feat-body{position:absolute;bottom:0;left:0;right:0;padding:52px;display:flex;align-items:flex-end;justify-content:space-between;gap:40px}
.proj-feat-name{font-family:'Syne',sans-serif;font-weight:700;font-size:clamp(2.4rem,4vw,4.4rem);letter-spacing:-.025em;color:var(--white);line-height:.92}
.proj-feat-meta{display:flex;flex-direction:column;align-items:flex-end;gap:14px;flex-shrink:0}
.pmi-l{font-family:'Inter',sans-serif;font-size:.5rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--sky);opacity:.65;margin-bottom:2px}
.pmi-v{font-family:'Inter',sans-serif;font-size:.82rem;font-weight:300;color:rgba(255,255,255,.62);text-align:right}
.proj-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;margin:3px 64px 0}
.pgc{position:relative;overflow:hidden;cursor:pointer;background:#b0c4cc;aspect-ratio:4/3}
.pgc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.78) saturate(.85);transition:transform .7s cubic-bezier(.16,1,.3,1),filter .45s}
.pgc:hover img{transform:scale(1.07);filter:brightness(.88) saturate(1)}
.pgc:nth-child(1) img{object-position:center 30%}
.pgc:nth-child(2) img{object-position:center 20%}
.pgc:nth-child(3) img{object-position:center 35%}
.pgc:nth-child(4) img{object-position:center 25%}
.pgc-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(41,56,66,.9) 0%,transparent 55%);transition:background .4s}
.pgc:hover .pgc-shade{background:linear-gradient(to top,rgba(41,56,66,.95) 0%,rgba(41,56,66,.15) 60%,transparent 100%)}
.pgc-top{position:absolute;top:0;left:0;right:0;height:2px;background:var(--sky);transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.pgc:hover .pgc-top{transform:scaleX(1)}
.pgc-info{position:absolute;bottom:0;left:0;right:0;padding:22px;transform:translateY(4px);transition:transform .35s ease}
.pgc:hover .pgc-info{transform:none}
.pgc-tag{font-family:'Inter',sans-serif;font-size:.5rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--sky);margin-bottom:6px;display:block;opacity:0;transform:translateY(6px);transition:all .35s .05s}
.pgc:hover .pgc-tag{opacity:1;transform:none}
.pgc-name{font-family:'Syne',sans-serif;font-weight:600;font-size:.98rem;letter-spacing:-.01em;color:var(--white);line-height:1.2}
.pgc-yr{font-family:'Inter',sans-serif;font-size:.5rem;font-weight:300;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-top:4px}

/* SHOWCASE */
.showcase{background:var(--navy);display:grid;grid-template-columns:1fr 1fr;min-height:68vh}
.showcase-img{position:relative;overflow:hidden;background:var(--forest)}
.showcase-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 40%;opacity:.7;transition:transform .9s ease,opacity .5s}
.showcase-img:hover img{transform:scale(1.04);opacity:.8}
.showcase-img-blend{position:absolute;inset:0;background:linear-gradient(to right,transparent 40%,var(--navy) 100%),linear-gradient(to top,rgba(41,56,66,.4) 0%,transparent 40%)}
.showcase-body{display:flex;flex-direction:column;justify-content:center;padding:100px 80px;background:var(--navy)}
.showcase-h{font-family:'Syne',sans-serif;font-weight:700;font-size:clamp(2.4rem,4vw,4rem);line-height:.92;letter-spacing:-.025em;color:var(--white);margin-bottom:36px}
.showcase-h em{font-style:italic;font-weight:400;color:var(--sky);display:block;margin-top:6px}
.showcase-p{font-family:'Inter',sans-serif;font-size:.86rem;font-weight:300;line-height:2;color:rgba(217,245,252,.4);max-width:420px;margin-bottom:52px}
.spec-row{display:flex;align-items:center;justify-content:space-between;padding:17px 0;border-bottom:1px solid rgba(93,125,135,.15)}
.spec-row:first-child{border-top:1px solid rgba(93,125,135,.15)}
.spec-name{font-family:'Syne',sans-serif;font-weight:500;font-size:.86rem;letter-spacing:.01em;color:rgba(217,245,252,.68)}
.spec-lbl{font-family:'Inter',sans-serif;font-size:.54rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:rgba(93,125,135,.6)}

/* WHY */
.why{background:var(--sky);padding:140px 64px}
.why-top{display:grid;grid-template-columns:1fr 1fr;gap:120px;margin-bottom:96px;align-items:end}
.why-h{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(3rem,5.5vw,5.8rem);line-height:.9;letter-spacing:-.03em;color:var(--navy)}
.why-h span{display:block;-webkit-text-stroke:2px rgba(41,56,66,.16);color:transparent}
.why-quote{font-family:'Inter',sans-serif;font-style:italic;font-size:1.12rem;font-weight:300;line-height:1.72;color:rgba(41,56,66,.58);border-left:2px solid var(--steel);padding-left:22px;margin-bottom:26px}
.why-cite{font-family:'Inter',sans-serif;font-size:.56rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:rgba(93,125,135,.65);display:flex;align-items:center;gap:14px}
.why-cite::before{content:'';width:20px;height:1px;background:var(--steel);display:block}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(93,125,135,.14)}
.wc{background:var(--sky);padding:52px 44px;position:relative;overflow:hidden;transition:background .35s}
.wc::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--navy);transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.wc:hover::after{transform:scaleX(1)}.wc:hover{background:rgba(217,245,252,.45)}
.wc-n{font-family:'Syne',sans-serif;font-weight:800;font-size:3.5rem;letter-spacing:-.04em;color:rgba(41,56,66,.06);line-height:1;margin-bottom:20px}
.wc h3{font-family:'Syne',sans-serif;font-weight:600;font-size:1.04rem;letter-spacing:-.01em;color:var(--navy);margin-bottom:13px;transition:color .3s}
.wc:hover h3{color:var(--forest)}
.wc p{font-family:'Inter',sans-serif;font-size:.78rem;font-weight:300;line-height:1.88;color:rgba(41,56,66,.54)}

/* CONTACT */
.contact{display:grid;grid-template-columns:1fr 1fr;min-height:88vh}
.contact-l{background:var(--navy);padding:120px 80px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden}
.contact-l::before{content:'';position:absolute;top:-180px;left:-180px;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(217,245,252,.04) 0%,transparent 70%);pointer-events:none}
.contact-h{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(3rem,5vw,5.5rem);line-height:.9;letter-spacing:-.03em;color:var(--white);margin-bottom:30px;position:relative}
.contact-h .a{color:var(--sky)}
.contact-p{font-family:'Inter',sans-serif;font-size:.84rem;font-weight:300;line-height:2;color:rgba(217,245,252,.36);max-width:400px;margin-bottom:60px;position:relative}
.ci-b{margin-bottom:18px}
.ci-l{font-family:'Inter',sans-serif;font-size:.5rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--sky);opacity:.55;margin-bottom:4px}
.ci-v{font-family:'Inter',sans-serif;font-size:.84rem;font-weight:300;color:rgba(217,245,252,.52);line-height:1.65}
.c-badge{display:inline-flex;align-items:center;gap:10px;margin-top:26px;padding:10px 18px;border:1px solid rgba(93,125,135,.2)}
.cb-dot{width:6px;height:6px;border-radius:50%;background:var(--sky);opacity:.55;flex-shrink:0}
.cb-t{font-family:'Inter',sans-serif;font-size:.54rem;font-weight:300;letter-spacing:.16em;text-transform:uppercase;color:rgba(217,245,252,.32)}
.contact-r{background:var(--white);padding:120px 80px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid rgba(93,125,135,.1)}
.fl{font-family:'Inter',sans-serif;font-size:.54rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(93,125,135,.55);display:block;margin-bottom:10px}
.fi{width:100%;background:none;border:none;border-bottom:1px solid rgba(93,125,135,.18);padding:12px 0;font-family:'Inter',sans-serif;font-size:.88rem;font-weight:300;color:var(--navy);outline:none;resize:none;transition:border-color .3s;margin-bottom:30px}
.fi::placeholder{color:rgba(41,56,66,.22)}.fi:focus{border-bottom-color:var(--steel)}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.f-sub{display:inline-flex;align-items:center;gap:16px;font-family:'Syne',sans-serif;font-size:.66rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;padding:16px 40px;background:var(--navy);border:1px solid var(--navy);color:var(--white);transition:all .35s cubic-bezier(.16,1,.3,1);margin-top:8px}
.f-sub:hover{background:var(--forest);border-color:var(--forest)}
.f-arr{font-size:1rem;transition:transform .3s}.f-sub:hover .f-arr{transform:translateX(6px)}
.f-ok{display:none;background:var(--sky);padding:44px}
.f-ok p{font-family:'Inter',sans-serif;font-size:.88rem;font-weight:300;color:var(--navy);line-height:2}
.f-ok strong{font-weight:600}

/* FOOTER */
footer{background:var(--ink);padding:44px 64px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;border-top:1px solid rgba(93,125,135,.1)}
.foot-logo{font-family:'Syne',sans-serif;font-weight:700;font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(217,245,252,.3)}
.foot-logo sup{color:var(--steel);font-size:.5em;vertical-align:super}
.foot-nav{display:flex;gap:36px}
.foot-nav button{font-family:'Inter',sans-serif;font-size:.58rem;font-weight:300;letter-spacing:.18em;text-transform:uppercase;color:rgba(93,125,135,.4);background:none;border:none;cursor:pointer;transition:color .2s;padding:0}
.foot-nav button:hover{color:rgba(217,245,252,.52)}
.foot-btm{width:100%;padding-top:22px;border-top:1px solid rgba(93,125,135,.08);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.foot-cp,.foot-rg{font-family:'Inter',sans-serif;font-size:.56rem;font-weight:300;letter-spacing:.06em;color:rgba(93,125,135,.32)}

/* ── BURGER ────────────────────────────────────────────────── */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;padding:6px;background:none;border:none;cursor:pointer;z-index:1000;flex-shrink:0}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--white);transition:transform .35s ease,opacity .35s ease}
.nav.on .nav-burger span{background:var(--navy)}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── MOBILE — scaled down, layout preserved ────────────────── */
@media(max-width:960px){

  /* Nav */
  .nav,.nav.on{padding:14px 20px}
  .nav-burger{display:flex}
  .nav-r{
    position:fixed;top:0;right:0;height:100vh;
    width:72vw;max-width:280px;
    background:rgba(26,39,48,.97);backdrop-filter:blur(20px);
    flex-direction:column;align-items:flex-start;justify-content:center;
    padding:40px 28px;gap:4px;
    border-left:1px solid rgba(93,125,135,.2);
    transform:translateX(100%);transition:transform .4s cubic-bezier(.16,1,.3,1);
    z-index:999;
  }
  .nav-r.open{transform:translateX(0)}
  .nav-link{display:block;font-size:1.2rem;font-family:'Syne',sans-serif;font-weight:700;color:rgba(217,245,252,.6);padding:10px 0;width:100%;text-align:left;letter-spacing:-.01em;text-transform:none;transition:color .2s}
  .nav-link:hover{color:var(--sky)}
  .nav-cta{display:block;margin-top:16px;padding:12px 20px;border:1px solid rgba(217,245,252,.2);color:rgba(217,245,252,.8);font-size:.62rem;letter-spacing:.14em;width:100%;text-align:center}

  /* ── 1. HERO — kicker+heading top, text+buttons+stats bottom ── */
  .hero{min-height:100svh;align-items:stretch;overflow:hidden}
  .hero-photo{position:absolute;inset:0}
  .hero-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transform:none!important}
  .hero-body{
    display:flex;flex-direction:column;justify-content:space-between;
    padding:100px 20px 44px;gap:0;
    grid-template-columns:unset;
  }
  .hero-h1{font-size:clamp(2.4rem,9vw,4rem);margin-bottom:12px;line-height:.9}
  .hero-kicker{font-size:.54rem;letter-spacing:.22em;margin-bottom:18px}
  .hero-sub{font-size:.78rem;margin-bottom:20px;max-width:100%}
  .hero-btns{gap:8px;margin-bottom:20px}
  .btn-sky,.btn-ghost{font-size:.6rem;padding:11px 16px}
  /* Stats row above buttons */
  .hero-stats{
    display:flex;flex-direction:row;width:100%;
    justify-content:flex-start;gap:28px;
    margin-bottom:20px;
  }
  .hs-item{flex-direction:row;align-items:center;gap:8px;padding:0;border-bottom:none}
  .hs-n{font-size:1.4rem;text-align:left}
  .hs-l{font-size:.42rem;text-align:left;margin-top:0}
  .hero-scroll{display:none}

  /* Band */
  .band{padding:28px 20px;gap:14px;flex-wrap:wrap}
  .band-txt{font-size:.8rem;max-width:100%}
  .btag{font-size:.5rem;padding:6px 10px}

  /* ── 2. ABOUT — text on top, image on bottom ── */
  .about-grid{
    grid-template-columns:1fr;
    grid-template-rows:auto auto;
    min-height:unset;
  }
  .about-text{
    order:1;padding:44px 20px 32px;
    grid-column:unset;
  }
  .about-img{
    order:2;height:56vw;min-height:200px;
    position:relative;
  }
  .about-img img{position:absolute;object-position:center 30%}
  .about-img-shade{
    background:linear-gradient(to bottom,var(--white) 0%,transparent 25%,transparent 75%,rgba(41,56,66,.3) 100%)
  }
  .about-yr{display:none}
  .about-h{font-size:clamp(1.6rem,5vw,2.4rem);margin-bottom:14px}
  .about-rule{margin-bottom:12px;width:28px}
  .about-p{font-size:.76rem;line-height:1.8;margin-bottom:24px;max-width:100%}
  .fn{font-size:1.5rem}
  .fl{font-size:.44rem}
  .figs{padding-top:20px;gap:0}
  .figs>div{padding-right:12px}
  .figs>div:last-child{padding-left:12px;padding-right:0}
  .figs>div:nth-child(2){padding-left:12px}

  /* ── 3. SERVICES — "six specialist" under CORE SERVICES ── */
  .sec{padding:48px 20px}
  .svc-head{
    grid-template-columns:1fr;  /* stack heading above intro */
    gap:12px;margin-bottom:36px;
  }
  .svc-h{font-size:clamp(2rem,7vw,3rem);line-height:.9}
  .svc-intro{font-size:.72rem;line-height:1.8;max-width:100%}
  .svc-row{grid-template-columns:36px 1fr 1fr auto;gap:8px 10px;padding:14px 0}
  .svc-name{font-size:clamp(.8rem,2.5vw,1.1rem)}
  .svc-desc{font-size:.62rem;line-height:1.5}
  .svc-n{font-size:.56rem}
  .svc-arr{font-size:.8rem}

  /* ── 4. PROJECTS — don't touch ── */
  .projects{padding:48px 0}
  .proj-head{padding:0 20px;margin-bottom:32px;flex-direction:column;align-items:flex-start;gap:8px}
  .proj-head-h{font-size:clamp(1.8rem,6vw,2.8rem);line-height:.9}
  .proj-head-sub{font-size:.64rem;max-width:100%;text-align:left}
  .proj-feat{margin:0 20px;height:40vw;min-height:180px;max-height:300px}
  .proj-feat-name{font-size:clamp(1.1rem,3vw,2rem)}
  .proj-feat-body{padding:16px 20px;gap:12px}
  .proj-feat-label{font-size:.46rem;top:14px;left:14px;padding:4px 9px}
  .proj-feat-meta{gap:10px}
  .pmi-l{font-size:.4rem}
  .pmi-v{font-size:.64rem}
  .proj-grid{margin:3px 20px 0;gap:2px;grid-template-columns:repeat(4,1fr)}
  .pgc{aspect-ratio:unset;height:28vw;min-height:100px}
  .pgc-name{font-size:.7rem}
  .pgc-tag{font-size:.4rem}
  .pgc-yr{font-size:.4rem}

  /* ── 5. SHOWCASE — text top, image bottom ── */
  .showcase{
    grid-template-columns:1fr;
    grid-template-rows:auto auto;
    min-height:unset;
  }
  .showcase-body{
    order:1;padding:44px 20px 32px;
    background:var(--navy);
  }
  .showcase-img{
    order:2;height:56vw;min-height:200px;
    position:relative;overflow:hidden;
  }
  .showcase-img img{position:absolute;object-position:center 35%}
  .showcase-img-blend{
    background:linear-gradient(to bottom,var(--navy) 0%,transparent 20%,transparent 80%,rgba(41,56,66,.5) 100%)
  }
  .showcase-h{font-size:clamp(1.6rem,5vw,2.6rem);margin-bottom:16px}
  .showcase-p{font-size:.74rem;max-width:100%;margin-bottom:24px}
  .spec-row{padding:10px 0}
  .spec-name{font-size:.72rem}
  .spec-lbl{font-size:.44rem}

  /* ── 6. WHY — heading left, quote BELOW heading ── */
  .why{padding:48px 20px}
  .why-top{
    grid-template-columns:1fr;  /* stack: heading then quote */
    gap:20px;margin-bottom:36px;
  }
  .why-h{font-size:clamp(2rem,7vw,3.2rem);line-height:.9}
  .why-quote{font-size:.78rem;padding-left:14px;margin-bottom:14px}
  .why-cite{font-size:.46rem}
  .why-grid{gap:2px;grid-template-columns:repeat(3,1fr)}
  .wc{padding:22px 14px}
  .wc-n{font-size:1.8rem;margin-bottom:10px}
  .wc h3{font-size:.78rem;margin-bottom:6px}
  .wc p{font-size:.62rem;line-height:1.65}

  /* ── 7. CONTACT — navy GET IN TOUCH top, white form bottom ── */
  .contact{
    grid-template-columns:1fr;
    grid-template-rows:auto auto;
    min-height:unset;
  }
  .contact-l{
    order:1;padding:44px 20px 36px;
    justify-content:flex-start;
    border-right:none;
    border-bottom:1px solid rgba(93,125,135,.15);
  }
  .contact-r{
    order:2;padding:36px 20px 44px;
  }
  .contact-h{font-size:clamp(2rem,7vw,3.2rem);line-height:.9;margin-bottom:14px}
  .contact-p{font-size:.74rem;margin-bottom:24px;max-width:100%;line-height:1.75}
  .ci-b{margin-bottom:12px}
  .ci-l{font-size:.42rem}
  .ci-v{font-size:.7rem}
  .c-badge{padding:8px 12px;margin-top:16px}
  .cb-t{font-size:.46rem}
  .fl{font-size:.44rem;margin-bottom:6px}
  .fi{font-size:.74rem;padding:9px 0;margin-bottom:18px}
  .f2{gap:14px}
  .f-sub{font-size:.58rem;padding:13px 20px;margin-top:4px}

  /* Footer */
  footer{padding:22px 20px;gap:12px}
  .foot-logo{font-size:.78rem}
  .foot-nav{gap:16px;flex-wrap:wrap}
  .foot-nav button{font-size:.5rem}
  .foot-cp,.foot-rg{font-size:.48rem}
}
