
:root{
  --ink:#111114;
  --paper:#f2f0eb;
  --paper-2:#e8e4dc;
  --muted:#6d6a64;
  --line:rgba(17,17,20,.14);
  --accent:#455ce9;
  --white:#fff;
  --radius:2rem;
  --display:"Helvetica Neue",Arial,sans-serif;
  --body:Inter,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);overflow-x:hidden}
body.nav-open{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}
::selection{background:var(--accent);color:#fff}
.container{width:min(92vw,1400px);margin-inline:auto}
.eyebrow{text-transform:uppercase;letter-spacing:.16em;font-size:.75rem;font-weight:700}
.muted{color:var(--muted)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Loader */
.loader{position:fixed;inset:0;z-index:9999;background:var(--ink);color:#fff;display:grid;place-items:center;transition:transform .8s cubic-bezier(.76,0,.24,1)}
.loader.is-hidden{transform:translateY(-105%)}
.loader-inner{display:grid;gap:1rem;text-align:center}
.loader-count{font-size:clamp(4rem,11vw,9rem);font-weight:700;letter-spacing:-.08em}
.loader-line{width:min(55vw,520px);height:2px;background:#333;overflow:hidden}
.loader-line span{display:block;height:100%;width:0;background:#fff;animation:load 1.1s forwards}
@keyframes load{to{width:100%}}

/* Cursor */
.cursor,.cursor-dot{position:fixed;left:0;top:0;pointer-events:none;z-index:10000;border-radius:50%;transform:translate(-50%,-50%);mix-blend-mode:difference}
.cursor{width:44px;height:44px;border:1px solid #fff;transition:width .2s,height .2s,background .2s}
.cursor-dot{width:5px;height:5px;background:#fff}
.cursor.is-active{width:72px;height:72px;background:#fff}
@media (pointer:coarse){.cursor,.cursor-dot{display:none}}

/* Header */
.site-header{position:fixed;z-index:1000;top:0;left:0;right:0;padding:1.35rem 0;mix-blend-mode:difference;color:#fff}
.nav{display:flex;align-items:center;justify-content:space-between}
.brand{font-weight:700;letter-spacing:-.04em;font-size:1.05rem;display:flex;align-items:center;gap:.75rem}
.brand-mark{width:1.75rem;height:1.75rem;border:1px solid currentColor;border-radius:50%;display:grid;place-items:center;font-size:.72rem}
.menu-btn{border:0;background:transparent;color:inherit;display:flex;align-items:center;gap:.8rem;cursor:pointer;padding:.65rem 0}
.menu-dot{width:.55rem;height:.55rem;background:currentColor;border-radius:50%}

/* Overlay nav */
.nav-overlay{position:fixed;inset:0;background:var(--ink);color:#fff;z-index:950;transform:translateY(-105%);transition:transform .8s cubic-bezier(.76,0,.24,1);display:flex;flex-direction:column}
.nav-overlay.open{transform:translateY(0)}
.nav-overlay-inner{width:min(92vw,1400px);margin:auto;padding-top:6rem}
.nav-list{list-style:none;padding:0;margin:0;border-top:1px solid rgba(255,255,255,.16)}
.nav-list li{border-bottom:1px solid rgba(255,255,255,.16);overflow:hidden}
.nav-list a{display:flex;align-items:center;justify-content:space-between;padding:.95rem 0;font-size:clamp(3.25rem,8.5vw,8.5rem);letter-spacing:-.075em;line-height:.9;transition:padding .25s}
.nav-list a:hover{padding-left:1.4rem}
.nav-num{font-size:.8rem;letter-spacing:.12em;color:#a1a1aa}
.nav-footer{display:flex;justify-content:space-between;gap:2rem;padding:2rem 0;color:#a1a1aa;font-size:.9rem}

/* Hero */
.hero{min-height:100svh;background:var(--paper);display:flex;align-items:flex-end;padding:10rem 0 4rem;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.6fr .65fr;gap:4rem;align-items:end}
.hero h1{font-family:var(--display);font-size:clamp(4.3rem,10.5vw,10.8rem);line-height:.82;letter-spacing:-.085em;margin:0;max-width:11ch;font-weight:600}
.hero-side{padding-bottom:1.2rem}
.hero-side p{font-size:clamp(1.05rem,1.5vw,1.35rem);line-height:1.5;max-width:30ch;margin:1rem 0 2rem}
.location-pill{display:inline-flex;align-items:center;gap:.75rem;padding:.85rem 1.1rem;border:1px solid var(--line);border-radius:999px}
.location-dot{width:.6rem;height:.6rem;border-radius:50%;background:#22c55e;box-shadow:0 0 0 .35rem rgba(34,197,94,.12)}
.hero-orbit{position:absolute;width:30rem;height:30rem;right:-10rem;top:16%;border:1px solid var(--line);border-radius:50%;animation:spin 18s linear infinite}
.hero-orbit:before,.hero-orbit:after{content:"";position:absolute;border:1px solid var(--line);border-radius:50%;inset:10%}
.hero-orbit:after{inset:26%}
@keyframes spin{to{transform:rotate(360deg)}}

/* Buttons */
.round-btn{width:10rem;height:10rem;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:#fff;font-weight:700;position:relative;overflow:hidden;transition:transform .2s}
.round-btn:after{content:"";position:absolute;inset:100% 0 0;background:#3144c7;transition:inset .35s}
.round-btn span{position:relative;z-index:1}
.round-btn:hover:after{inset:0}
.text-link{display:inline-flex;align-items:center;gap:.6rem;border-bottom:1px solid currentColor;padding-bottom:.25rem}
.arrow{transition:transform .25s}.text-link:hover .arrow{transform:translate(4px,-4px)}

/* Marquee */
.marquee{background:var(--ink);color:#fff;overflow:hidden;padding:2rem 0}
.marquee-track{display:flex;width:max-content;animation:marquee 28s linear infinite}
.marquee span{font-size:clamp(2.7rem,5vw,5.7rem);letter-spacing:-.055em;white-space:nowrap;padding-right:3rem}
.marquee i{font-style:normal;color:#737373}
@keyframes marquee{to{transform:translateX(-50%)}}

/* Sections */
.section{padding:9rem 0}
.section-head{display:flex;justify-content:space-between;gap:3rem;align-items:end;margin-bottom:4rem}
.section-head h2{font-size:clamp(3.2rem,7vw,7.5rem);letter-spacing:-.075em;line-height:.9;margin:0;max-width:10ch;font-weight:500}
.section-head p{max-width:31rem;font-size:1.05rem;line-height:1.65}

/* Project rows */
.projects{border-top:1px solid var(--line)}
.project-row{position:relative;display:grid;grid-template-columns:5rem 1fr auto;align-items:center;gap:2rem;padding:2.4rem 0;border-bottom:1px solid var(--line);cursor:pointer}
.project-row h3{font-size:clamp(2.4rem,5vw,5.7rem);line-height:.9;letter-spacing:-.07em;margin:0;font-weight:500;transition:transform .35s,opacity .35s}
.project-row .project-meta{text-align:right;color:var(--muted)}
.project-row:hover h3{transform:translateX(1.1rem);opacity:.55}
.project-num{font-size:.8rem;color:var(--muted)}
.project-preview{position:fixed;width:min(34vw,520px);aspect-ratio:1.45;object-fit:cover;z-index:900;pointer-events:none;opacity:0;transform:translate(-50%,-50%) scale(.86);transition:opacity .2s,transform .25s;border-radius:1.2rem;box-shadow:0 30px 80px rgba(0,0,0,.3)}
.project-preview.show{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* Services */
.dark{background:var(--ink);color:#fff}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(255,255,255,.18)}
.service{padding:2.5rem 2rem 3.5rem 0;border-bottom:1px solid rgba(255,255,255,.18)}
.service:nth-child(3n+2),.service:nth-child(3n+3){padding-left:2rem;border-left:1px solid rgba(255,255,255,.18)}
.service span{display:block;color:#8b8b91;margin-bottom:4rem}
.service h3{font-size:1.75rem;margin:0 0 1rem;letter-spacing:-.04em}
.service p{color:#a3a3aa;line-height:1.65;max-width:30ch}

/* About teaser */
.about-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:7rem;align-items:start}
.about-grid h2{font-size:clamp(3rem,6.4vw,7rem);letter-spacing:-.075em;line-height:.92;margin:0}
.about-copy{padding-top:.7rem}
.about-copy p{font-size:1.15rem;line-height:1.7;margin-top:0}
.stats{display:grid;grid-template-columns:repeat(3,1fr);margin-top:4rem;border-top:1px solid var(--line)}
.stat{padding:2rem 1.5rem 0 0}
.stat strong{display:block;font-size:clamp(2.4rem,4vw,4.8rem);letter-spacing:-.07em}
.stat span{color:var(--muted);font-size:.9rem}

/* CTA */
.big-cta{padding:8rem 0;background:var(--accent);color:#fff}
.big-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:3rem}
.big-cta h2{font-size:clamp(4rem,9vw,9rem);line-height:.82;letter-spacing:-.08em;margin:0;max-width:9ch;font-weight:500}
.big-cta .round-btn{background:#fff;color:var(--ink)}
.big-cta .round-btn:after{background:#e7e7e7}

/* Footer */
.footer{background:var(--ink);color:#fff;padding:3rem 0}
.footer-grid{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:end}
.footer-links{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer small{color:#8f8f96}

/* Inner pages */
.page-hero{min-height:74svh;padding:12rem 0 5rem;display:flex;align-items:end}
.page-hero h1{font-size:clamp(5rem,13vw,13rem);line-height:.78;letter-spacing:-.09em;margin:0;font-weight:500}
.page-hero p{font-size:1.2rem;max-width:38rem;line-height:1.65;margin:2rem 0 0}
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.3rem}
.work-card{background:#ddd8cf;border-radius:1.6rem;overflow:hidden}
.work-card img{aspect-ratio:1.45;object-fit:cover;transition:transform .7s cubic-bezier(.2,.8,.2,1)}
.work-card:hover img{transform:scale(1.04)}
.work-card-copy{display:flex;justify-content:space-between;gap:2rem;padding:1.4rem 1.5rem 1.7rem}
.work-card h2{margin:0;font-size:1.6rem;letter-spacing:-.04em}
.work-card p{margin:.35rem 0 0;color:var(--muted)}
.work-card span{white-space:nowrap;font-size:.85rem;color:var(--muted)}

.timeline{border-top:1px solid var(--line)}
.timeline-item{display:grid;grid-template-columns:13rem 1fr;gap:2rem;padding:2rem 0;border-bottom:1px solid var(--line)}
.timeline-item h3{font-size:1.65rem;margin:0 0 .45rem;letter-spacing:-.04em}
.timeline-item p{max-width:45rem;margin:0;color:var(--muted);line-height:1.65}
.tools{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:2.5rem}
.tool{border:1px solid var(--line);border-radius:999px;padding:.7rem 1rem}

.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:6rem}
.contact-layout h1{font-size:clamp(4rem,8vw,8rem);line-height:.85;letter-spacing:-.08em;margin:0 0 2rem}
.contact-details{display:grid;gap:1.5rem;margin-top:4rem}
.contact-details a{font-size:1.15rem;border-bottom:1px solid var(--line);padding-bottom:1rem}
.form{display:grid;gap:1.25rem}
.form label{display:grid;gap:.55rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.12em}
.form input,.form textarea{width:100%;border:0;border-bottom:1px solid var(--line);background:transparent;padding:1rem 0;font-size:1.2rem;outline:none}
.form textarea{min-height:10rem;resize:vertical}
.submit{border:0;cursor:pointer;margin-top:1rem}

.policy{max-width:850px}
.policy h1{font-size:clamp(4rem,8vw,8rem);letter-spacing:-.075em;line-height:.9}
.policy h2{font-size:1.7rem;margin-top:3rem}
.policy p{line-height:1.75;color:#4f4d49}

/* Reveal */
.reveal{opacity:0;transform:translateY(35px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.visible{opacity:1;transform:none}

/* Responsive */
@media(max-width:900px){
  .hero-grid,.about-grid,.contact-layout{grid-template-columns:1fr}
  .hero{padding-top:9rem}
  .hero-side{display:grid;grid-template-columns:1fr auto;align-items:end}
  .services-grid{grid-template-columns:1fr}
  .service,.service:nth-child(3n+2),.service:nth-child(3n+3){padding:2.5rem 0;border-left:0}
  .work-grid{grid-template-columns:1fr}
  .big-cta-inner{align-items:flex-end}
  .round-btn{width:8rem;height:8rem}
  .project-preview{display:none}
}
@media(max-width:650px){
  .section{padding:6.5rem 0}
  .hero h1{font-size:clamp(4rem,20vw,7rem)}
  .hero-side{grid-template-columns:1fr}
  .round-btn{width:7.5rem;height:7.5rem}
  .project-row{grid-template-columns:2.5rem 1fr;padding:1.65rem 0}
  .project-row .project-meta{display:none}
  .section-head{display:grid}
  .stats{grid-template-columns:1fr}
  .big-cta-inner{display:grid}
  .footer-grid{grid-template-columns:1fr}
  .nav-footer{display:grid}
  .timeline-item{grid-template-columns:1fr}
  .work-card-copy{display:grid}
}
