:root{
  --blue:#4F719A; --blue-d:#3C597E; --blue-dd:#2E465F;
  --gray:#858591; --gray-2:#9DA0AB;
  --ink:#262C35; --ink-2:#525A66; --muted:#8A909B;
  --paper:#ffffff; --bg:#F4F6F9; --bg-2:#EDF0F4; --line:#E2E6EC; --line-2:#D2D8E0;
  --dark:#222A35; --dark-2:#2C3540;
  --shadow:0 1px 2px rgba(38,44,53,.04),0 12px 34px rgba(38,44,53,.09);
  --shadow-lg:0 26px 70px rgba(38,44,53,.22);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;background:var(--paper);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;opacity:0;animation:pageIn .6s ease forwards}
@keyframes pageIn{from{opacity:0}to{opacity:1}}
body.leaving{animation:none;opacity:0;transition:opacity .32s ease}
h1,h2,h3,h4{margin:0;font-family:'Libre Franklin',Helvetica,Arial,sans-serif;font-weight:600;letter-spacing:-.01em;line-height:1.1}
.serif{font-family:'Newsreader',Georgia,serif}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}
.eyebrow{font:600 12px/1 'Inter',sans-serif;letter-spacing:.28em;text-transform:uppercase;color:var(--blue)}
.btn{display:inline-flex;align-items:center;gap:9px;border:none;border-radius:2px;padding:15px 30px;font:600 12.5px/1 'Inter',sans-serif;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:.2s}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dd)}
.btn-outline{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.55)}
.btn-outline:hover{background:#fff;color:var(--ink)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:.35s}
.nav{position:relative;display:flex;align-items:center;justify-content:center;height:88px}
.brand{position:absolute;left:0;top:0;bottom:0;display:flex;align-items:center;cursor:pointer}
.brand img{height:54px;width:auto;display:block;transition:.35s}
.nav-links{display:flex;gap:40px;align-items:center}
.nav-links a{font:600 13px/1 'Inter',sans-serif;letter-spacing:.13em;text-transform:uppercase;color:#fff;opacity:.9;transition:.18s}
.nav-links a:hover,.nav-links a.active{opacity:1}
.brand .logo-dark{display:none}
header.scrolled,header.solid{background:rgba(255,255,255,.97);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line)}
header.scrolled .nav,header.solid .nav{height:74px}
header.scrolled .brand img,header.solid .brand img{height:46px}
header.scrolled .brand .logo-white,header.solid .brand .logo-white{display:none}
header.scrolled .brand .logo-dark,header.solid .brand .logo-dark{display:block}
header.scrolled .nav-links a,header.solid .nav-links a{color:var(--ink-2)}
header.scrolled .nav-links a.active,header.solid .nav-links a.active{color:var(--blue)}
.menu-btn{display:none;background:none;border:none;cursor:pointer;width:30px;height:22px;position:absolute;right:0;top:50%;transform:translateY(-50%);z-index:1100}
.menu-btn span{position:absolute;left:0;right:0;height:2px;background:#fff;transition:.25s}
.menu-btn span:nth-child(1){top:0}.menu-btn span:nth-child(2){top:10px}.menu-btn span:nth-child(3){top:20px}
header.scrolled .menu-btn span,header.solid .menu-btn span{background:var(--ink)}

/* HERO */
.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--dark)}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.06);transition:opacity 1.6s ease,transform 7.5s ease;will-change:opacity,transform}
.hero-slide.on{opacity:1;transform:scale(1.0)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,36,48,.5) 0%,rgba(28,36,48,.28) 42%,rgba(24,31,42,.8) 100%);z-index:2}
.hero-inner{position:relative;z-index:3;width:100%}
.hero .eyebrow{color:rgba(255,255,255,.82);margin-bottom:24px}
.hero h1{font-size:clamp(34px,5.2vw,66px);font-weight:300;max-width:17ch;letter-spacing:-.015em;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.hero p{font-size:clamp(16px,1.5vw,19px);max-width:50ch;margin:26px 0 38px;color:rgba(255,255,255,.9)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.scrollcue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;font:600 11px/1 'Inter';letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.7);display:flex;flex-direction:column;align-items:center;gap:10px}
.scrollcue::after{content:"";width:1px;height:38px;background:rgba(255,255,255,.45);animation:cue 2s infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* SECTIONS */
section{position:relative}
.intro{padding:120px 0 110px;text-align:center;background:var(--paper)}
.intro .lede{font-size:clamp(23px,2.9vw,36px);font-weight:300;line-height:1.4;max-width:30ch;margin:26px auto 0;color:var(--ink);letter-spacing:-.01em}

.about{padding:0 0 120px;background:var(--paper)}
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center;border-top:1px solid var(--line);padding-top:90px}
.about-text h2{font-size:clamp(28px,3.4vw,40px);font-weight:400;margin:18px 0 26px;letter-spacing:-.02em}
.about-text p{color:var(--ink-2);font-size:16.5px;margin:0 0 20px;max-width:46ch}
.about-text .sign{margin-top:34px;font-size:14px;color:var(--muted)}
.about-img{background:url('assets/about.jpg') center/cover;min-height:460px;border-radius:3px}

/* ABOUT FEATURE (full-bleed band on home) */
.about-feature{position:relative;display:flex;align-items:center;color:#fff;overflow:hidden;min-height:80vh;padding:130px 0}
.about-feature .af-bg{position:absolute;inset:0;background:url('assets/about-feature.jpg') center/cover;transform:scale(1.03)}
.about-feature .af-ov{position:absolute;inset:0;background:linear-gradient(100deg,rgba(20,27,38,.9) 0%,rgba(22,29,40,.62) 48%,rgba(24,31,42,.22) 100%)}
.about-feature .wrap{position:relative;z-index:2}
.af-content{max-width:560px}
.af-content .eyebrow{color:rgba(255,255,255,.82)}
.af-content h2{font-size:clamp(28px,3.6vw,44px);font-weight:400;letter-spacing:-.02em;margin:18px 0 22px}
.af-content p{color:rgba(255,255,255,.9);font-size:16.5px;margin:0 0 18px}
.af-content .btn{margin-top:14px}

.approach{padding:118px 0;background:var(--bg)}
.approach .head{max-width:640px;margin-bottom:60px}
.approach h2{font-size:clamp(28px,3.4vw,42px);font-weight:400;margin-top:16px;letter-spacing:-.02em}
.focus{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.focus .item{background:var(--paper);border:1px solid var(--line);border-radius:5px;padding:42px 40px;transition:.25s}
.focus .item:hover{box-shadow:var(--shadow);border-color:var(--line-2);transform:translateY(-3px)}
.focus .accent{width:36px;height:3px;background:var(--blue);border-radius:2px;margin-bottom:24px}
.focus h3{font-size:20px;font-weight:600;margin-bottom:12px;letter-spacing:-.005em}
.focus p{color:var(--ink-2);font-size:15px;line-height:1.64;margin:0}

/* BAND */
.band{position:relative;height:56vh;min-height:360px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;background:url('assets/band-rooftop.jpg') center/cover fixed}
.band::after{content:"";position:absolute;inset:0;background:rgba(30,38,50,.6)}
.band .band-in{position:relative;z-index:2;padding:0 24px}
.band .eyebrow{color:rgba(255,255,255,.78)}
.band p{font-family:'Newsreader',serif;font-weight:300;font-size:clamp(26px,3.6vw,44px);line-height:1.3;max-width:20ch;margin:18px auto 0;letter-spacing:-.01em}

/* PROJECTS TEASER (home) */
.teaser{background:var(--paper);padding:118px 0}
.teaser-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.teaser-img{background:url('assets/p2-1.jpg') center/cover;min-height:440px;border-radius:3px;box-shadow:var(--shadow)}
.teaser h2{font-size:clamp(28px,3.4vw,42px);font-weight:400;margin:16px 0 22px;letter-spacing:-.02em}
.teaser p{color:var(--ink-2);font-size:16.5px;max-width:42ch;margin:0 0 32px}

/* PROJECTS PAGE */
.page-head{position:relative;height:52vh;min-height:380px;display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:var(--dark)}
.page-head .ph-bg{position:absolute;inset:0;background:url('assets/p2-2.jpg') center/cover;transform:scale(1.04)}
.page-head .ph-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,36,48,.45),rgba(24,31,42,.82));z-index:2}
.page-head .wrap{position:relative;z-index:3;padding-bottom:54px}
.page-head .eyebrow{color:rgba(255,255,255,.82);margin-bottom:18px}
.page-head h1{font-size:clamp(34px,5vw,60px);font-weight:300;letter-spacing:-.015em}
.page-head p{margin:16px 0 0;color:rgba(255,255,255,.9);max-width:52ch;font-size:17px}

.projects-list{padding:96px 0 120px;background:var(--paper)}
.project{display:grid;grid-template-columns:1.32fr .82fr;gap:54px;align-items:center;margin-bottom:30px;padding-bottom:64px;border-bottom:1px solid var(--line)}
.project:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.project.reverse .carousel{order:2}
.pinfo .eyebrow{display:block;margin-bottom:14px}
.pinfo h3{font-family:'Newsreader',serif;font-size:clamp(26px,3vw,36px);font-weight:400;letter-spacing:-.01em;color:var(--ink);margin:0 0 16px}
.pinfo p{color:var(--ink-2);font-size:16px;margin:0 0 26px}
.pmeta{border-top:1px solid var(--line)}
.pmeta .row{display:flex;justify-content:space-between;gap:18px;padding:13px 2px;border-bottom:1px solid var(--line)}
.pmeta .k{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600;font-size:11px;align-self:center}
.pmeta .v{color:var(--ink);font-weight:500;font-size:14px;text-align:right}

/* CAROUSEL */
.carousel{position:relative;aspect-ratio:16/10;overflow:hidden;border-radius:3px;background:var(--bg-2);box-shadow:var(--shadow);touch-action:pan-y}
.track{display:flex;height:100%;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.slide{min-width:100%;height:100%;background-size:cover;background-position:center}
.cbtn{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:50px;height:50px;border-radius:50%;border:none;background:rgba(255,255,255,.9);color:var(--ink);font-size:24px;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:0 4px 16px rgba(0,0,0,.18);transition:.2s}
.cbtn:hover{background:#fff;color:var(--blue)}
.cbtn.prev{left:18px}.cbtn.next{right:18px}
.counter{position:absolute;right:18px;bottom:16px;z-index:4;background:rgba(28,36,48,.66);color:#fff;font:600 12px/1 'Inter';letter-spacing:.08em;padding:8px 12px;border-radius:2px}
.dots{position:absolute;left:0;right:0;bottom:16px;z-index:4;display:flex;gap:8px;justify-content:center}
.dots button{width:8px;height:8px;border-radius:50%;border:none;background:rgba(255,255,255,.55);cursor:pointer;padding:0;transition:.2s}
.dots button.on{background:#fff;width:22px;border-radius:4px}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(15,19,26,.93);display:none;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:86vh;border-radius:3px;box-shadow:0 30px 90px rgba(0,0,0,.55)}
.lb-close{position:absolute;top:20px;right:26px;background:none;border:none;color:#fff;font-size:38px;line-height:1;cursor:pointer;opacity:.85;transition:.2s}
.lb-close:hover{opacity:1}
.lb-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:#fff;width:56px;height:56px;border-radius:50%;font-size:28px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.2s}
.lb-btn:hover{background:rgba(255,255,255,.26)}
.lb-prev{left:26px}.lb-next{right:26px}
.lb-counter{position:absolute;bottom:24px;left:0;right:0;text-align:center;color:rgba(255,255,255,.82);font:600 12.5px/1 'Inter',sans-serif;letter-spacing:.12em}
@media(max-width:680px){
  .lb-btn{width:44px;height:44px;font-size:22px}
  .lb-prev{left:10px}.lb-next{right:10px}
  .lb-close{top:14px;right:16px}
}

/* CONTACT */
.contact{padding:118px 0 120px;background:var(--bg)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.contact h2{font-size:clamp(30px,3.6vw,46px);font-weight:400;margin:16px 0 22px;letter-spacing:-.02em}
.contact .lead{color:var(--ink-2);font-size:16.5px;max-width:40ch;margin-bottom:30px}
.contact .email{display:inline-block;font-family:'Newsreader',serif;font-size:23px;color:var(--blue-d);border-bottom:1px solid var(--line-2);padding-bottom:4px;transition:.2s}
.contact .email:hover{color:var(--blue)}
form{display:grid;gap:18px}
.field label{display:block;font:600 11.5px/1 'Inter';letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.field input,.field textarea{width:100%;border:1px solid var(--line-2);background:#fff;border-radius:2px;padding:14px 15px;font:400 15px/1.5 'Inter';color:var(--ink);transition:.18s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue)}
.field textarea{resize:vertical;min-height:120px}
.hp{position:absolute;left:-9999px}

/* FOOTER */
footer{background:var(--dark);color:rgba(255,255,255,.62);padding:74px 0 40px}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:40px;padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-logo img{height:78px;width:auto;margin-bottom:18px}
.foot-tag{font-size:14px;max-width:34ch;line-height:1.6}
.foot-col h4{font:600 12px/1 'Inter';letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px}
.foot-col a,.foot-col p{display:block;color:rgba(255,255,255,.78);font-size:14.5px;margin-bottom:9px;transition:.18s}
.foot-col a:hover{color:#fff}
.foot-bottom{padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px;color:rgba(255,255,255,.42)}

/* FORM STATES */
.form-status{font-size:13.5px;margin-top:2px;min-height:16px;color:var(--ink-2)}
.form-status.err{color:#b3402f}
.form-done{display:none}
.form-done.show{display:block}
.form-done .chk{width:48px;height:48px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-size:24px;margin-bottom:18px}
.form-done h3{font-size:22px;font-weight:600;margin-bottom:8px}
.form-done p{color:var(--ink-2);margin:0}
form.sent{display:none}

/* ABOUT PAGE */
.about-body{padding:96px 0 110px;background:var(--paper)}
.about-body .col{max-width:730px}
.about-body .eyebrow{display:block;margin-bottom:16px}
.about-body h2{font-size:clamp(27px,3.2vw,40px);font-weight:400;letter-spacing:-.02em;margin:0 0 26px}
.about-body h3{font-size:20px;font-weight:600;margin:50px 0 14px;letter-spacing:-.005em}
.about-body p{color:var(--ink-2);font-size:16.5px;margin:0 0 18px}
.pull{margin:40px 0;border-left:2px solid var(--blue);padding:8px 0 8px 24px;font-family:'Newsreader',serif;font-size:clamp(21px,2.5vw,29px);font-weight:300;color:var(--ink);line-height:1.36}
.about-cta{margin-top:44px}

/* PROJECTS INTRO */
.proj-intro{max-width:720px;margin:0 0 60px}
.proj-intro p{color:var(--ink-2);font-size:16.5px;margin:0}

/* CONTACT PAGE */
.contact-page{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.contact-page .cp-bg{position:absolute;inset:0;background:url('assets/contact-bg.jpg') center/cover;transform:scale(1.03)}
.contact-page .cp-ov{position:absolute;inset:0;background:linear-gradient(115deg,rgba(22,29,40,.9) 0%,rgba(28,36,48,.72) 45%,rgba(34,42,53,.5) 100%)}
.contact-page .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;width:100%;padding-top:128px;padding-bottom:96px}
.cp-intro{color:#fff}
.cp-intro .eyebrow{color:rgba(255,255,255,.82)}
.cp-intro h1{font-size:clamp(34px,4.6vw,56px);font-weight:300;letter-spacing:-.015em;margin:20px 0 20px}
.cp-intro p{color:rgba(255,255,255,.9);max-width:40ch;font-size:17px;margin:0}
.cp-card{background:#fff;border-radius:6px;padding:44px 42px;box-shadow:var(--shadow-lg)}
.cp-card .ttl{font-family:'Newsreader',serif;font-size:24px;font-weight:400;color:var(--ink);margin:0 0 22px}

/* ABOUT — lead, story rows, quote band */
.about-lead{padding:104px 0 84px;text-align:center;background:var(--paper)}
.about-lead .eyebrow{margin-bottom:18px}
.about-lead h2{font-family:'Newsreader',serif;font-weight:300;font-size:clamp(27px,3.6vw,42px);line-height:1.24;letter-spacing:-.015em;max-width:20ch;margin:0 auto;color:var(--ink)}
.about-lead .sub{max-width:680px;margin:26px auto 0}
.about-lead .sub p{color:var(--ink-2);font-size:16.5px;margin:0 0 14px}
.about-lead .sub p:last-child{margin-bottom:0}
.story{padding:92px 0;background:var(--paper)}
.story.tint{background:var(--bg)}
.srow{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.srow.flip .s-img{order:2}
.s-img{min-height:460px;border-radius:4px;background-size:cover;background-position:center;box-shadow:var(--shadow)}
.s-text .eyebrow{display:block;margin-bottom:14px}
.s-text h2{font-family:'Newsreader',serif;font-size:clamp(26px,3.2vw,38px);font-weight:400;letter-spacing:-.015em;margin:0 0 18px;color:var(--ink)}
.s-text p{color:var(--ink-2);font-size:16.5px;margin:0 0 16px}
.s-text p:last-child{margin-bottom:0}
.quoteband{position:relative;min-height:46vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden;padding:84px 0}
.quoteband .qb-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.03)}
.quoteband .qb-ov{position:absolute;inset:0;background:rgba(28,36,48,.64)}
.quoteband .qb-in{position:relative;z-index:2;padding:0 24px;max-width:780px}
.quoteband .eyebrow{color:rgba(255,255,255,.78);margin-bottom:18px;display:block}
.quoteband p{font-family:'Newsreader',serif;font-weight:300;font-size:clamp(24px,3.3vw,40px);line-height:1.32;letter-spacing:-.01em;margin:0}

/* RESPONSIVE */
@media(max-width:960px){
  .about-grid{grid-template-columns:1fr;gap:40px;padding-top:64px}
  .about-img{min-height:300px;order:-1}
  .project{grid-template-columns:1fr;gap:28px;margin-bottom:24px;padding-bottom:52px}
  .project.reverse .carousel{order:0}
  .contact-page .wrap{grid-template-columns:1fr;gap:36px;padding-top:108px;padding-bottom:72px}
  .cp-card{padding:34px 26px}
  .srow{grid-template-columns:1fr;gap:30px}
  .srow.flip .s-img{order:0}
  .s-img{min-height:300px;order:-1}
  .story{padding:64px 0}
  .about-lead{padding:80px 0 60px}
  .teaser-grid{grid-template-columns:1fr;gap:36px}
  .teaser-img{min-height:300px;order:-1}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .band{background-attachment:scroll}
}
@media(max-width:680px){
  .wrap{padding:0 22px}
  .nav{height:72px}
  .nav-links{position:fixed;top:0;right:0;bottom:0;width:80%;max-width:300px;background:var(--dark);flex-direction:column;justify-content:flex-start;align-items:stretch;gap:0;padding:92px 34px 40px;transform:translateX(100%);transition:transform .32s ease;box-shadow:var(--shadow-lg);z-index:1050}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{color:#fff!important;font-size:17px;letter-spacing:.06em;opacity:1;padding:19px 0;border-bottom:1px solid rgba(255,255,255,.12)}
  .nav-links a:last-child{border-bottom:none}
  .menu-btn{display:block;right:20px}
  .nav-links.open ~ .menu-btn span{background:#fff!important}
  .nav-links.open ~ .menu-btn span:nth-child(1){top:10px;transform:rotate(45deg)}
  .nav-links.open ~ .menu-btn span:nth-child(2){opacity:0}
  .nav-links.open ~ .menu-btn span:nth-child(3){top:10px;transform:rotate(-45deg)}
  .focus{grid-template-columns:1fr}
  .focus .item{padding:32px 28px}
  .intro{padding:80px 0 72px}
  .hero h1{font-size:clamp(30px,8vw,44px)}
  .about-feature{min-height:auto;padding:84px 0}
  .about-feature .af-ov{background:linear-gradient(170deg,rgba(20,27,38,.84),rgba(20,27,38,.72))}
  .cbtn{width:42px;height:42px;font-size:20px}
  .cbtn.prev{left:10px}.cbtn.next{right:10px}
  .project .cap{flex-direction:column;align-items:flex-start}
  .project .cap .desc{text-align:left}
  .project{margin-bottom:68px}
  .about-text p{max-width:none}
}
