/* ── LOCAL FONTS (self-hosted) ─────────────
   Rubik is provided as a self-hosted brand font asset for future use.
   Current typography (Inter/Bitter) is unchanged. */
@font-face{font-family:'Rubik';font-style:normal;font-weight:400;font-display:swap;src:url('../assets/fonts/rubik-400.woff2') format('woff2')}
@font-face{font-family:'Rubik';font-style:normal;font-weight:500;font-display:swap;src:url('../assets/fonts/rubik-500.woff2') format('woff2')}
@font-face{font-family:'Rubik';font-style:normal;font-weight:600;font-display:swap;src:url('../assets/fonts/rubik-600.woff2') format('woff2')}
@font-face{font-family:'Rubik';font-style:normal;font-weight:700;font-display:swap;src:url('../assets/fonts/rubik-700.woff2') format('woff2')}

/* ── SKIP LINK ──────────────────────────── */
.skip-link{position:fixed;top:-100%;left:16px;z-index:20000;background:var(--r);color:#fff;padding:10px 20px;font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;transition:top .2s;border-radius:0 0 4px 4px}
.skip-link:focus{top:0}

/* ── FOCUS VISIBLE (WCAG 2.1 AA) ────────── */
:focus{outline:none}
:focus-visible{outline:2px solid var(--r);outline-offset:3px}
a:focus-visible,button:focus-visible,.btn-p:focus-visible,.btn-s:focus-visible,.btn-sub:focus-visible,.nav-cta:focus-visible{outline:2px solid var(--r);outline-offset:3px}
.nav-links a:focus-visible{outline-color:var(--r);outline-offset:4px}
nav.scrolled .nav-links a:focus-visible,.nav-logo:focus-visible{outline-color:var(--r)}
.form-in:focus-visible,.form-ta:focus-visible{outline:none;border-color:var(--g);box-shadow:0 2px 0 0 var(--g)}

/* ── TOKENS ─────────────────────────────── */
:root{
  --g:#212529;--w:#E7EBEF;--f:#0B3B2E;--r:#C9000A;--ch:#2b2a29;
  --eout:cubic-bezier(.16,1,.3,1);--eio:cubic-bezier(.65,0,.35,1);
  --nh:80px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Inter',sans-serif;background:var(--w);color:var(--g);overflow-x:hidden;cursor:none}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
[id]{scroll-margin-top:var(--nh)}

/* ── CURSOR ─────────────────────────────── */
#cur{position:fixed;width:8px;height:8px;background:var(--r);border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);transition:width .3s var(--eout),height .3s var(--eout)}
#cur-ring{position:fixed;width:32px;height:32px;border:1px solid var(--g);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .4s var(--eout),height .4s var(--eout),border-color .3s}
#cur.h{width:16px;height:16px}
#cur-ring.h{width:56px;height:56px;border-color:var(--r)}
@media(hover:none),(max-width:768px){body{cursor:auto}#cur,#cur-ring{display:none}}

/* ── SCROLL BAR ─────────────────────────── */
#sp{position:fixed;top:0;left:0;height:2px;background:var(--r);z-index:2000;transform-origin:left;transform:scaleX(0);transition:transform .08s linear}

/* ── NAV ────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nh);display:flex;align-items:center;padding:0 clamp(20px,4.5vw,64px);transition:background .5s var(--eout),border-color .5s,box-shadow .5s}
nav.scrolled{background:rgba(231,235,239,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(33,37,41,.1);box-shadow:0 1px 24px rgba(33,37,41,.06)}
.nav-inner{width:100%;max-width:1440px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;flex-shrink:0;min-width:0;z-index:1100;position:relative}
.nav-logo .lsvg{height:30px;width:auto;display:block;min-width:120px;max-width:200px;color:var(--w);fill:currentColor;transition:color .45s var(--eout)}
nav.scrolled .nav-logo .lsvg{color:var(--ch)}
.nav-links{display:flex;align-items:center;gap:clamp(20px,3vw,48px)}
.nav-links a{font-size:.67rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(231,235,239,.75);transition:color .3s;position:relative;white-space:nowrap}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--r);transition:width .3s var(--eout)}
.nav-links a:hover{color:var(--w)}
.nav-links a:hover::after{width:100%}
nav.scrolled .nav-links a{color:rgba(33,37,41,.55)}
nav.scrolled .nav-links a:hover{color:var(--g)}
.nav-cta{font-size:.67rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--w);padding:10px 24px;border:1px solid rgba(231,235,239,.35);transition:all .3s;white-space:nowrap;flex-shrink:0}
.nav-cta:hover{background:var(--r);border-color:var(--r)}
nav.scrolled .nav-cta{color:var(--g);border-color:rgba(33,37,41,.25)}
nav.scrolled .nav-cta:hover{background:var(--r);border-color:var(--r);color:var(--w)}

/* ── HAMBURGER BUTTON ──────────────────── */
.nav-burger{display:none;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;gap:0;cursor:pointer;-webkit-tap-highlight-color:transparent;position:relative;z-index:1100;background:none;border:none;padding:0}
.nav-burger span{display:block;width:22px;height:2px;background:var(--w);border-radius:2px;transition:transform .35s var(--eout),opacity .25s;margin:3px 0}
nav.scrolled .nav-burger span{background:var(--g)}
nav.menu-open .nav-burger span{background:var(--w)!important}
nav.menu-open .nav-burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
nav.menu-open .nav-burger span:nth-child(2){opacity:0;transform:scaleX(0)}
nav.menu-open .nav-burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ── MOBILE MENU PANEL ─────────────────── */
.mobile-menu{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1050;background:linear-gradient(155deg,#0B3B2E 0%,#0d2318 45%,#101a13 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s var(--eout),visibility 0s .35s}
.mobile-menu.open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .35s var(--eout),visibility 0s 0s}
.mobile-menu a{display:block;font-size:clamp(1.2rem,4vw,1.8rem);font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(231,235,239,.8);padding:16px 0;transition:color .3s,transform .35s var(--eout);transform:translateY(12px);opacity:0}
.mobile-menu.open a{transform:translateY(0);opacity:1}
.mobile-menu.open a:nth-child(1){transition-delay:.06s}
.mobile-menu.open a:nth-child(2){transition-delay:.1s}
.mobile-menu.open a:nth-child(3){transition-delay:.14s}
.mobile-menu.open a:nth-child(4){transition-delay:.18s}
.mobile-menu.open a:nth-child(5){transition-delay:.22s}
.mobile-menu a:hover,.mobile-menu a:focus{color:var(--w)}
.mobile-menu .mm-cta{margin-top:24px;font-size:clamp(.7rem,2.5vw,.85rem);font-weight:600;letter-spacing:.18em;padding:14px 40px;border:1px solid rgba(231,235,239,.3);transition:background .3s,border-color .3s,color .3s,transform .35s,opacity .35s}
.mobile-menu .mm-cta:hover{background:var(--r);border-color:var(--r);color:var(--w)}

/* ── MOBILE NAV BREAKPOINT ─────────────── */
@media(max-width:900px){
  .nav-links,.nav-cta{display:none!important}
  .nav-burger{display:flex}
  /* Always give the nav a subtle backdrop so logo is readable over any content */
  nav:not(.scrolled):not(.menu-open){background:linear-gradient(to bottom,rgba(11,59,46,.55) 0%,transparent 100%)}
  nav.menu-open{background:var(--f)!important;border-bottom-color:transparent!important;box-shadow:none!important;z-index:1060}
  nav.menu-open .nav-logo .lsvg{color:var(--w)!important}
  /* Ensure logo color on scrolled mobile matches */
  nav.scrolled:not(.menu-open) .nav-logo .lsvg{color:var(--ch)!important}
  body.menu-lock{overflow:hidden}
  /* Larger tap target for logo on mobile */
  .nav-logo .lsvg{height:26px;min-width:100px}
}

/* ── HERO ───────────────────────────────── */
.hero{position:relative;width:100%;height:100vh;min-height:600px;background:var(--f);overflow:hidden;display:flex;align-items:center}
.h-bg{position:absolute;inset:0;background:linear-gradient(155deg,#0B3B2E 0%,#0d2318 45%,#101a13 100%)}
.h-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(231,235,239,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(231,235,239,.04) 1px,transparent 1px);background-size:80px 80px}
.h-grid-sm{position:absolute;inset:0;background-image:linear-gradient(rgba(231,235,239,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(231,235,239,.015) 1px,transparent 1px);background-size:16px 16px}
.h-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.h-shape{position:absolute;border:1px solid rgba(231,235,239,.055)}
.hs1{width:min(600px,80vw);height:min(600px,80vw);right:-40px;top:50%;transform:translateY(-50%) rotate(12deg)}
.hs2{width:min(400px,55vw);height:min(400px,55vw);right:min(170px,18vw);top:50%;transform:translateY(-50%) rotate(12deg)}
.hs3{width:min(200px,28vw);height:min(200px,28vw);right:min(270px,33vw);top:50%;transform:translateY(-50%) rotate(12deg)}
.h-vline{position:absolute;top:0;right:36%;bottom:0;width:1px;background:linear-gradient(to bottom,transparent,rgba(201,0,10,.25),transparent)}
.h-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(11,59,46,.35) 0%,rgba(11,59,46,.08) 55%,transparent 100%)}
.h-content{position:relative;z-index:10;width:100%;max-width:1440px;margin:0 auto;padding:0 clamp(20px,4.5vw,64px);padding-top:calc(var(--nh) + clamp(32px,5vh,72px));padding-bottom:clamp(140px,15vw,200px)}
.h-labels{position:absolute;inset:0;pointer-events:none}
.h-label{position:absolute;font-size:.58rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:rgba(231,235,239,.35);display:flex;align-items:center;gap:8px}
.h-label::before{content:'';display:block;width:16px;height:1px;background:var(--r);flex-shrink:0}
.hl1{top:160px;right:clamp(20px,4.5vw,64px)}
.hl2{bottom:120px;left:clamp(20px,4.5vw,64px)}
.hl3{top:50%;right:calc(36% + 40px);transform:translateY(-50%)}
.hl4{bottom:180px;right:clamp(20px,4.5vw,64px)}
.h-coords{position:absolute;bottom:28px;right:clamp(20px,4.5vw,64px);font-size:.56rem;color:rgba(231,235,239,.2);font-family:'Courier New',monospace;letter-spacing:.1em}
.h-eyebrow{font-size:.65rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--r);margin-bottom:16px;display:flex;align-items:center;gap:14px;opacity:0;transform:translateY(20px);animation:fu .8s var(--eout) .3s forwards}
.h-eyebrow::before{content:'';display:block;width:28px;height:1px;background:var(--r);flex-shrink:0}
/* Headline: scaled down from 6.5vw/8rem → 4.5vw/5.5rem for better proportion */
.h-headline{font-size:clamp(1.9rem,4.5vw,5.5rem);font-weight:800;line-height:1.05;letter-spacing:-.022em;text-transform:uppercase;color:var(--w);max-width:700px;opacity:0;transform:translateY(40px);animation:fu 1s var(--eout) .5s forwards}
.h-headline em{font-style:normal;color:transparent;-webkit-text-stroke:1px rgba(231,235,239,.35)}
.h-sub{margin-top:clamp(14px,2vw,28px);font-size:clamp(.875rem,1.1vw,.975rem);line-height:1.75;color:rgba(231,235,239,.55);max-width:440px;opacity:0;transform:translateY(30px);animation:fu .9s var(--eout) .8s forwards}
.h-actions{margin-top:clamp(22px,3vw,44px);display:flex;flex-wrap:wrap;align-items:center;gap:clamp(14px,2vw,28px);opacity:0;transform:translateY(20px);animation:fu .8s var(--eout) 1s forwards}
.btn-p{font-size:.67rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--w);background:var(--r);padding:16px 32px;display:inline-flex;align-items:center;gap:12px;border:1px solid var(--r);transition:all .3s var(--eout)}
.btn-p:hover{background:transparent;color:var(--r)}
.btn-s{font-size:.67rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:rgba(231,235,239,.6);display:inline-flex;align-items:center;gap:8px;transition:color .3s}
.btn-s::after{content:'';display:block;width:24px;height:1px;background:rgba(231,235,239,.35);transition:width .3s var(--eout),background .3s}
.btn-s:hover{color:var(--w)}
.btn-s:hover::after{width:40px;background:var(--r)}
.scroll-ind{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fi 1s ease 2s forwards;z-index:10}
.scroll-ind span{font-size:.55rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:rgba(231,235,239,.35)}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(201,0,10,.8),transparent);animation:sp2 2s ease-in-out infinite}

/* ── TICKER ─────────────────────────────── */
.ticker{padding:14px 0;background:var(--r);overflow:hidden}
.ticker-track{display:flex;gap:64px;white-space:nowrap;animation:tick 25s linear infinite}
.ticker-item{font-size:.6rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--w);display:flex;align-items:center;gap:32px;flex-shrink:0}
.ticker-item::after{content:'×';opacity:.45}

/* ── SECTION UTILS ──────────────────────── */
section{position:relative}
.container{max-width:1440px;margin:0 auto;padding:0 clamp(20px,4.5vw,64px)}
.sec-label{font-size:.6rem;font-weight:500;letter-spacing:.35em;text-transform:uppercase;color:var(--r);display:flex;align-items:center;gap:12px}
.sec-label::before{content:'';display:block;width:24px;height:1px;background:var(--r);flex-shrink:0}
.sec-num{font-size:.6rem;font-weight:400;letter-spacing:.2em;color:rgba(33,37,41,.25);font-family:'Courier New',monospace}
.sec-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:clamp(40px,7vw,96px);padding-bottom:clamp(20px,3.5vw,48px);border-bottom:1px solid rgba(33,37,41,.09);gap:24px;flex-wrap:wrap}
.sec-title{font-size:clamp(1.75rem,3.5vw,3.5rem);font-weight:700;line-height:1.1;letter-spacing:-.02em;color:var(--g)}
.sec-title em{font-style:normal;color:var(--f)}
.reveal{opacity:0;transform:translateY(32px);transition:opacity .85s var(--eout),transform .85s var(--eout)}
.reveal.vis{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* ── PROJECTS ───────────────────────────── */
.projects{padding:clamp(64px,11vw,160px) 0;background:var(--w)}
.proj-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.pc{position:relative;overflow:hidden;background:#0d2318;cursor:none}
.pc:nth-child(1){grid-column:span 7;aspect-ratio:4/3}
.pc:nth-child(2){grid-column:span 5;aspect-ratio:3/4}
.pc:nth-child(3){grid-column:span 4;aspect-ratio:1}
.pc:nth-child(4){grid-column:span 8;aspect-ratio:16/9}
.pc-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .8s var(--eout);display:block}
.pc-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,20,14,.88) 0%,rgba(10,20,14,.18) 55%,transparent 100%);transition:opacity .5s}
.pc:hover .pc-ov{opacity:.95}
.pc:hover .pc-bg{transform:scale(1.04)}
.pc-content{position:absolute;bottom:0;left:0;right:0;padding:clamp(16px,2.5vw,32px)}
.pc-cat{font-size:.56rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--r);margin-bottom:6px}
.pc-title{font-size:clamp(.9rem,1.5vw,1.25rem);font-weight:700;color:var(--w);line-height:1.2;letter-spacing:-.01em}
.pc-num{position:absolute;top:16px;right:16px;font-size:.54rem;color:rgba(231,235,239,.25);font-family:'Courier New',monospace;letter-spacing:.18em}
.pc-label{position:absolute;top:16px;left:16px;font-size:.62rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--w);background:rgba(10,20,14,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:6px 11px;border-radius:2px;font-family:'Inter',sans-serif;z-index:2}
.pc-arrow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:56px;height:56px;border:1px solid rgba(231,235,239,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s,transform .3s var(--eout)}
.pc:hover .pc-arrow{opacity:1;transform:translate(-50%,-50%) scale(1)}
.pc-arrow svg{width:20px;height:20px;stroke:var(--w);fill:none;stroke-width:1.5}

/* ── PHILOSOPHY ─────────────────────────── */
.philosophy{padding:clamp(64px,11vw,160px) 0;background:var(--g);position:relative;overflow:hidden}
.ph-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(231,235,239,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(231,235,239,.022) 1px,transparent 1px);background-size:80px 80px}
.philosophy .sec-header{border-bottom-color:rgba(231,235,239,.07)}
.philosophy .sec-title{color:var(--w)}
.philosophy .sec-label{color:rgba(231,235,239,.45)}
.philosophy .sec-label::before{background:rgba(231,235,239,.45)}
.philosophy .sec-num{color:rgba(231,235,239,.18)}
.ph-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 2fr;gap:clamp(40px,11vw,160px);align-items:start}
.ph-meta{display:flex;flex-direction:column}
.ph-mi{display:flex;flex-direction:column;gap:4px;padding:20px 0;border-bottom:1px solid rgba(231,235,239,.07)}
.ph-mi:last-child{border:none}
.ph-ml{font-size:.56rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:rgba(231,235,239,.28)}
.ph-mv{font-size:.875rem;color:rgba(231,235,239,.65);margin-top:2px}
.ph-right{display:flex;flex-direction:column;gap:clamp(28px,4vw,48px)}
.ph-quote{font-family:'Bitter',serif;font-size:clamp(1.25rem,2.8vw,2.5rem);font-style:italic;line-height:1.45;color:var(--w);letter-spacing:-.01em}
.ph-quote strong{font-style:normal;font-weight:600;color:rgba(231,235,239,.42)}
.ph-text{font-size:clamp(.875rem,1.1vw,1rem);line-height:1.8;color:rgba(231,235,239,.5)}
.ph-principles{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,32px);padding-top:clamp(28px,4vw,48px);border-top:1px solid rgba(231,235,239,.07)}
.prin{display:flex;flex-direction:column;gap:6px}
.prin-n{font-size:.6rem;color:var(--r);letter-spacing:.2em;font-family:'Courier New',monospace}
.prin-t{font-size:.875rem;font-weight:600;color:var(--w);letter-spacing:.03em}
.prin-d{font-size:.75rem;color:rgba(231,235,239,.38);line-height:1.6}

/* ── SERVICES ───────────────────────────── */
.services{padding:clamp(64px,11vw,160px) 0;background:var(--w)}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid rgba(33,37,41,.09)}
.srv{padding:clamp(28px,4vw,56px) clamp(20px,3vw,40px);border-right:1px solid rgba(33,37,41,.09);border-bottom:1px solid rgba(33,37,41,.09);position:relative;overflow:hidden;transition:background .4s}
.srv:nth-child(3n){border-right:none}
.srv:nth-child(n+4){border-bottom:none}
.srv:hover{background:var(--g)}
.srv::before{content:'';position:absolute;top:0;left:0;width:2px;height:0;background:var(--r);transition:height .4s var(--eout)}
.srv:hover::before{height:100%}
.srv-icon{width:48px;height:48px;margin-bottom:28px}
.srv-icon svg{width:100%;height:100%;stroke:var(--g);fill:none;stroke-width:1;transition:stroke .4s}
.srv:hover .srv-icon svg{stroke:rgba(231,235,239,.6)}
.srv-n{font-size:.6rem;color:var(--r);letter-spacing:.2em;font-family:'Courier New',monospace;margin-bottom:12px}
.srv-title{font-size:clamp(.95rem,1.3vw,1.2rem);font-weight:700;color:var(--g);letter-spacing:-.01em;margin-bottom:14px;line-height:1.2;transition:color .4s}
.srv:hover .srv-title{color:var(--w)}
.srv-desc{font-size:.875rem;color:rgba(33,37,41,.55);line-height:1.75;transition:color .4s}
.srv:hover .srv-desc{color:rgba(231,235,239,.45)}
.srv-tags{margin-top:20px;display:flex;flex-wrap:wrap;gap:6px}
.srv-tag{font-size:.54rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:rgba(33,37,41,.38);border:1px solid rgba(33,37,41,.13);padding:3px 8px;transition:all .4s}
.srv:hover .srv-tag{color:rgba(231,235,239,.35);border-color:rgba(231,235,239,.12)}

/* ── PROCESS ────────────────────────────── */
.process{padding:clamp(64px,11vw,160px) 0;background:var(--f);position:relative;overflow:hidden}
.proc-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(231,235,239,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(231,235,239,.025) 1px,transparent 1px);background-size:40px 40px}
.process .sec-title{color:var(--w)}
.process .sec-header{border-bottom-color:rgba(231,235,239,.09)}
.process .sec-num{color:rgba(231,235,239,.18)}
.process .sec-label{color:rgba(231,235,239,.4)}
.process .sec-label::before{background:rgba(231,235,239,.4)}
.proc-steps{display:grid;grid-template-columns:repeat(5,1fr);position:relative}
.proc-steps::before{content:'';position:absolute;top:40px;left:8%;right:8%;height:1px;background:rgba(231,235,239,.1);z-index:0}
.proc-step{padding:clamp(16px,2vw,32px) clamp(12px,1.5vw,24px);display:flex;flex-direction:column;position:relative;z-index:1}
.proc-marker{width:80px;height:80px;border:1px solid rgba(231,235,239,.13);display:flex;align-items:center;justify-content:center;margin-bottom:32px;background:var(--f);transition:border-color .3s,background .3s}
.proc-step:hover .proc-marker{border-color:var(--r);background:rgba(201,0,10,.04)}
.proc-mn{font-size:1.2rem;font-weight:700;color:rgba(231,235,239,.18);font-family:'Courier New',monospace;transition:color .3s}
.proc-step:hover .proc-mn{color:var(--r)}
.proc-phase{font-size:.54rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:rgba(231,235,239,.28);margin-bottom:10px}
.proc-title{font-size:.9rem;font-weight:700;color:var(--w);letter-spacing:-.01em;margin-top:0;margin-bottom:10px;line-height:1.3}
.proc-desc{font-size:.78rem;color:rgba(231,235,239,.38);line-height:1.65}

/* ── CASE STUDIES ───────────────────────── */
.casestudies{padding:clamp(64px,11vw,160px) 0;background:var(--w)}
.cs-list{display:flex;flex-direction:column}
.cs-item{display:flex;align-items:center;gap:clamp(16px,3vw,48px);padding:clamp(18px,2.5vw,32px) 0;border-bottom:1px solid rgba(33,37,41,.08);cursor:none;transition:padding-left .3s var(--eout);position:relative}
.cs-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:var(--f);transition:width .5s var(--eout);z-index:0}
.cs-item:hover{padding-left:16px}
.cs-item:hover::before{width:3px}
.cs-item>*{position:relative;z-index:1}
.cs-num{font-size:.78rem;font-weight:600;color:rgba(33,37,41,.32);font-family:'Inter',sans-serif;letter-spacing:.12em;text-transform:uppercase;flex-shrink:0;width:68px}
.cs-info{flex:1;min-width:0}
.cs-title{font-size:clamp(.95rem,1.8vw,1.5rem);font-weight:700;color:var(--g);letter-spacing:-.01em;line-height:1.2;transition:color .3s}
.cs-item:hover .cs-title{color:var(--f)}
.cs-det{display:flex;gap:24px;flex-shrink:0}
.cs-type{font-size:.6rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(33,37,41,.35)}
.cs-arrow{width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transform:translateX(-8px);transition:opacity .3s,transform .3s var(--eout)}
.cs-arrow svg{width:20px;height:20px;stroke:var(--f);fill:none;stroke-width:1.5}
.cs-item:hover .cs-arrow{opacity:1;transform:translateX(0)}

/* ── STUDIO ─────────────────────────────── */
.studio{padding:clamp(64px,11vw,160px) 0;background:var(--w)}
.stu-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,8vw,96px);align-items:stretch}
.stu-title{font-size:clamp(2rem,4.5vw,4.5rem);font-weight:800;line-height:1.05;letter-spacing:-.03em;color:var(--g);margin:24px 0 32px}
.stu-title span{color:var(--f)}
.stu-body{font-size:clamp(.875rem,1.1vw,1rem);line-height:1.8;color:rgba(33,37,41,.55)}
.stu-visual{position:relative;overflow:hidden}
/* Studio image — fills the full right column height */
.stu-img{position:relative;overflow:hidden;background:var(--g);min-height:520px;height:100%}
.stu-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 32%;display:block;transition:transform .8s var(--eout)}
.stu-visual:hover .stu-photo{transform:scale(1.03)}
.stu-img-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,20,14,.55) 0%,rgba(10,20,14,.08) 50%,transparent 100%)}
.stu-img-lbl{position:absolute;bottom:24px;left:24px;font-size:.54rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(231,235,239,.45);font-family:'Courier New',monospace;z-index:2}
.stu-img-tag{position:absolute;top:24px;right:24px;font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--w);background:rgba(10,20,14,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:8px 14px;border-radius:2px;font-family:'Inter',sans-serif;z-index:2}

/* ── TESTIMONIALS ───────────────────────── */
.testimonials{padding:clamp(64px,11vw,160px) 0;background:var(--g);position:relative;overflow:hidden}
.test-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(231,235,239,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(231,235,239,.022) 1px,transparent 1px);background-size:80px 80px}
.testimonials .sec-header{border-bottom-color:rgba(231,235,239,.07)}
.testimonials .sec-title{color:var(--w)}
.testimonials .sec-label{color:rgba(231,235,239,.38)}
.testimonials .sec-label::before{background:rgba(231,235,239,.38)}
.testimonials .sec-num{color:rgba(231,235,239,.18)}
.team-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:24px;position:relative;z-index:1}
.team-card{position:relative;flex:0 1 386px;max-width:386px;aspect-ratio:3/4;overflow:hidden;border:1px solid rgba(231,235,239,.07);background:linear-gradient(135deg,#142f22 0%,#0d2318 100%);transition:border-color .3s}
.team-card:hover{border-color:rgba(231,235,239,.15)}
.team-card-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 18%;display:block;transition:transform .8s var(--eout)}
.team-card:hover .team-card-img{transform:scale(1.04)}
.team-card-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,17,12,.96) 0%,rgba(8,17,12,.65) 32%,rgba(8,17,12,.18) 60%,transparent 85%);z-index:1}
.team-info{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:clamp(20px,3vw,30px) clamp(18px,2.5vw,24px)}
.team-name{font-size:clamp(1rem,1.5vw,1.3rem);font-weight:700;color:var(--w);letter-spacing:-.01em;text-shadow:0 2px 10px rgba(0,0,0,.5)}
.team-role{font-size:.62rem;font-weight:600;letter-spacing:.24em;text-transform:none;color:var(--r);margin-top:8px;text-shadow:0 1px 6px rgba(0,0,0,.4)}

/* ── CONTACT ────────────────────────────── */
.contact{padding:clamp(64px,11vw,160px) 0;background:var(--w)}
.ct-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(40px,8vw,96px);align-items:start}
.ct-intro{font-size:clamp(.875rem,1.2vw,1.05rem);line-height:1.75;color:rgba(33,37,41,.5);margin-bottom:40px}
.ct-details{display:flex;flex-direction:column}
.ct-det{display:flex;flex-direction:column;gap:4px;padding:18px 0;border-bottom:1px solid rgba(33,37,41,.07)}
.ct-det:first-child{border-top:1px solid rgba(33,37,41,.07)}
.ct-dl{font-size:.54rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:rgba(33,37,41,.3)}
.ct-dv{font-size:.9rem;color:var(--g);transition:color .3s;margin-top:4px}
a.ct-dv:hover{color:var(--r)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-grp{margin-bottom:16px}
.form-lbl{display:block;font-size:.56rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:rgba(33,37,41,.4);margin-bottom:8px}
.form-in,.form-ta{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(33,37,41,.18);font-family:'Inter',sans-serif;font-size:.875rem;color:var(--g);padding:10px 0;outline:none;transition:border-color .3s,box-shadow .3s;-webkit-appearance:none;border-radius:0}
.form-in:focus,.form-ta:focus{border-color:var(--g)}
.form-in.invalid,.form-ta.invalid{border-color:var(--r)}
.form-in.valid,.form-ta.valid{border-color:#2a7a4b}
.form-ta{resize:none;height:110px}
/* Field error message */
.field-error{display:block;font-size:.62rem;color:var(--r);margin-top:4px;letter-spacing:.04em}
/* Honeypot — hidden from real users */
.hp-wrap{position:absolute;left:-9999px;opacity:0;pointer-events:none;tab-index:-1}
.form-bot{display:flex;align-items:center;justify-content:space-between;margin-top:28px;gap:16px;flex-wrap:wrap}
.form-note{font-size:.68rem;color:rgba(33,37,41,.3);letter-spacing:.04em}
.btn-sub{font-size:.67rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--w);background:var(--g);padding:14px 28px;display:inline-flex;align-items:center;gap:10px;border:1px solid var(--g);transition:all .3s var(--eout);cursor:pointer}
.btn-sub:hover:not(:disabled){background:var(--r);border-color:var(--r)}
.btn-sub:disabled{opacity:.6;cursor:not-allowed}
.btn-sub svg{flex-shrink:0}
/* Spinner */
.btn-spinner{width:14px;height:14px;border:2px solid rgba(231,235,239,.3);border-top-color:var(--w);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
/* Form feedback */
.form-feedback{margin-top:24px;padding:16px 20px;font-size:.825rem;line-height:1.6;letter-spacing:.02em;display:none;border-left:3px solid}
.form-feedback.success{background:rgba(42,122,75,.07);border-color:#2a7a4b;color:#1a5c38}
.form-feedback.error{background:rgba(201,0,10,.06);border-color:var(--r);color:#8a0007}

/* ── FOOTER ─────────────────────────────── */
footer{background:var(--g);padding:clamp(48px,8vw,120px) 0 0;position:relative}
.ft-bar{height:3px;background:var(--r)}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(24px,4vw,64px);margin-bottom:clamp(40px,6vw,96px)}
.ft-logo-wrap{margin-bottom:20px}
.ft-logo-wrap .lsvg{height:28px;width:auto;display:block;min-width:100px;color:rgba(231,235,239,.62);fill:currentColor}
.ft-tag{font-size:.78rem;line-height:1.7;color:rgba(231,235,239,.3);max-width:280px;margin-top:20px}
.ft-col-title{font-size:.56rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:rgba(231,235,239,.28);margin-bottom:20px}
.ft-links{display:flex;flex-direction:column;gap:12px}
.ft-links a{font-size:.78rem;color:rgba(231,235,239,.32);transition:color .3s}
.ft-links a:hover{color:var(--w)}
.ft-bot{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;border-top:1px solid rgba(231,235,239,.06);flex-wrap:wrap}
.ft-copy{font-size:.68rem;color:rgba(231,235,239,.18);letter-spacing:.04em}
.ft-legal{display:flex;gap:20px}
.ft-legal a{font-size:.68rem;color:rgba(231,235,239,.18);letter-spacing:.04em;transition:color .3s}
.ft-legal a:hover{color:rgba(231,235,239,.5)}

/* ── KEYFRAMES ──────────────────────────── */
@keyframes fu{to{opacity:1;transform:translateY(0)}}
@keyframes fi{to{opacity:1}}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes sp2{0%{opacity:0;transform:scaleY(0);transform-origin:top}50%{opacity:1;transform:scaleY(1)}100%{opacity:0;transform:scaleY(1);transform-origin:bottom}}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */

/* 900px ─ nav handled in mobile menu section above */
@media(max-width:900px){
  nav{padding:0 clamp(16px,4vw,24px)}
}

/* 1200px ─ large tablet */
@media(max-width:1200px){
  .stu-inner{grid-template-columns:1fr}
  .stu-inner .stu-visual{max-width:600px}
}

/* 1024px ─ tablet landscape */
@media(max-width:1024px){
  .ph-inner{grid-template-columns:1fr;gap:48px}
  .ph-principles{grid-template-columns:repeat(3,1fr)}
  .proc-steps{grid-template-columns:repeat(3,1fr)}
  .proc-steps::before{display:none}
  .ft-grid{grid-template-columns:1fr 1fr;gap:40px}
}

/* 768px ─ tablet portrait / mobile */
@media(max-width:768px){
  :root{--nh:64px}
  /* hero */
  .h-shapes,.h-vline,.h-labels,.h-coords{display:none}
  .h-content{padding-top:calc(var(--nh) + 28px);padding-bottom:200px}
  /* projects */
  .proj-grid{grid-template-columns:1fr 1fr}
  .pc:nth-child(1){grid-column:span 2;aspect-ratio:16/9}
  .pc:nth-child(2){grid-column:span 1;aspect-ratio:4/3}
  .pc:nth-child(3){grid-column:span 1;aspect-ratio:4/3}
  .pc:nth-child(4){grid-column:span 2;aspect-ratio:16/9}
  /* services gap-border trick */
  .srv-grid{grid-template-columns:1fr 1fr;border:none;gap:1px;background:rgba(33,37,41,.09)}
  .srv{border:none;background:var(--w)}
  .srv:hover{background:var(--g)}
  /* process */
  .proc-steps{grid-template-columns:1fr 1fr}
  .proc-steps::before{display:none}
  /* contact */
  .ct-inner{grid-template-columns:1fr}
  /* form */
  .form-row{grid-template-columns:1fr}
  /* studio */
  .stu-inner{grid-template-columns:1fr}
  /* philosophy */
  .ph-principles{grid-template-columns:1fr 1fr;gap:20px}
  /* case studies */
  .cs-det{display:none}
  /* footer */
  .ft-grid{grid-template-columns:1fr 1fr}
  .ft-grid>div:first-child{grid-column:span 2}
  /* sec header */
  .sec-header{flex-direction:column;align-items:flex-start}
}

/* 480px ─ mobile portrait */
@media(max-width:480px){
  /* projects */
  .proj-grid{grid-template-columns:1fr;gap:8px}
  .pc:nth-child(1),.pc:nth-child(2),.pc:nth-child(3),.pc:nth-child(4){grid-column:span 1;aspect-ratio:16/9}
  /* services */
  .srv-grid{grid-template-columns:1fr}
  /* process */
  .proc-steps{grid-template-columns:1fr}
  .proc-step{flex-direction:row;align-items:flex-start;gap:20px;border-bottom:1px solid rgba(231,235,239,.08);padding:24px 0}
  .proc-marker{margin-bottom:0;flex-shrink:0;width:56px;height:56px}
  .proc-mn{font-size:.9rem}
  /* stats */
  .h-content{padding-top:calc(var(--nh) + 20px);padding-bottom:320px}
  /* philosophy */
  .ph-principles{grid-template-columns:1fr}
  /* team */
  .team-card{flex:0 1 280px;max-width:280px;aspect-ratio:4/5}
  /* footer */
  .ft-grid{grid-template-columns:1fr}
  .ft-grid>div:first-child{grid-column:span 1}
  .ft-bot{flex-direction:column;align-items:flex-start;gap:10px}
  .ft-legal{flex-wrap:wrap;gap:12px}
}

/* ── PERFORMANCE HINTS ──────────────────── */
.reveal{will-change:opacity,transform}
.reveal.vis{will-change:auto}
.pc-bg{will-change:transform}
.pc:not(:hover) .pc-bg{will-change:auto}
.nav-logo .lsvg,.ft-logo-wrap .lsvg{will-change:fill}

/* ── MOBILE: KONTAKT moved to hamburger menu ── */

/* ── PRINT ──────────────────────────────── */
@media print{
  nav,#cur,#cur-ring,#sp,.ticker,.scroll-ind,.h-shapes,.h-labels,.h-coords,
  .h-grid,.h-grid-sm,.h-vline,.h-overlay,.ph-bg,.proc-bg,.test-bg,
  .pc-ov,.pc-arrow{display:none!important}
  body{cursor:auto;background:#fff;color:#000;font-size:12pt}
  .hero{height:auto;min-height:0;page-break-after:always}
  a[href]::after{content:" (" attr(href) ")"}
  .container{max-width:100%;padding:0 20px}
  section{padding:24pt 0!important}
}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none;will-change:auto}
  html{scroll-behavior:auto}
}
