*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --k:#070707;--k2:#0e0e0e;--k3:#161616;--k4:#1d1d1d;
  --w:#f0ede8;--w2:rgba(240,237,232,.65);--w3:rgba(240,237,232,.35);--w4:rgba(240,237,232,.1);
  --r:#c0112b;--r2:#8a0c1e;--r3:rgba(192,17,43,.12);
  --g:#c4a24a;--g2:#8a6f30;--g3:rgba(196,162,74,.1);
  --mono:'Space Mono',monospace;
  --disp:'Bebas Neue',sans-serif;
  --body:'Barlow Condensed',sans-serif;
  --text:'Barlow',sans-serif;
  --nav-h:64px;
}
html{scroll-behavior:smooth}
body{background:var(--k);color:var(--w);font-family:var(--body);overflow-x:hidden;padding-top:var(--nav-h)}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-thumb{background:var(--r)}

/* GRAIN OVERLAY */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E")}

/* ── NAV ───────────────────────────────────────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;
  justify-content:space-between;padding:0 2rem;height:var(--nav-h);
  background:rgba(7,7,7,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--w4)}
.n-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.n-mark{width:34px;height:34px;background:var(--r);display:flex;align-items:center;
  justify-content:center;font-family:var(--disp);font-size:16px;letter-spacing:1px;
  flex-shrink:0;color:var(--w)}
.n-name{font-family:var(--disp);font-size:11px;letter-spacing:4px;line-height:1.4;color:var(--w)}
.n-links{display:flex;gap:1.8rem;align-items:center}
.n-links a{font-family:var(--mono);font-size:9px;letter-spacing:3px;text-transform:uppercase;
  color:var(--w3);text-decoration:none;transition:.2s}
.n-links a:hover,.n-links a.on{color:var(--w)}
.n-btn{font-family:var(--mono);font-size:9px;letter-spacing:3px;background:var(--r);
  color:var(--w);border:none;padding:.55rem 1.2rem;cursor:pointer;transition:.2s;text-decoration:none}
.n-btn:hover{background:var(--r2)}
.n-mobile-btn{display:none;flex-direction:column;gap:5px;cursor:pointer;
  background:none;border:none;padding:4px}
.n-mobile-btn span{display:block;width:24px;height:1.5px;background:var(--w);transition:.3s}
@media(max-width:780px){
  .n-links{display:none;position:fixed;top:var(--nav-h);left:0;right:0;
    background:rgba(7,7,7,.98);flex-direction:column;padding:1.5rem 2rem;
    gap:1.2rem;border-bottom:1px solid var(--w4);z-index:999}
  .n-links.open{display:flex}
  .n-mobile-btn{display:flex}
}

/* ── UTILS ─────────────────────────────────────────────────────────────────── */
.wrap{max-width:1240px;margin:0 auto;padding:0 2rem}
.sec{padding:6rem 2rem}
.sec-sm{padding:3.5rem 2rem}
.mono{font-family:var(--mono);font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--w3)}
.mono-g{font-family:var(--mono);font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--g)}
.mono-r{font-family:var(--mono);font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--r)}
.d1{font-family:var(--disp);font-size:clamp(72px,11vw,148px);line-height:.9;letter-spacing:-1px}
.d2{font-family:var(--disp);font-size:clamp(46px,7vw,96px);line-height:.95}
.d3{font-family:var(--disp);font-size:clamp(30px,4.5vw,62px);line-height:1}
.d4{font-family:var(--disp);font-size:clamp(22px,3vw,42px);line-height:1.05}
.p1{font-family:var(--text);font-size:15px;line-height:1.8;color:var(--w2)}
.p2{font-family:var(--text);font-size:13px;line-height:1.75;color:var(--w3)}
.r{color:var(--r)}.g{color:var(--g)}.w2{color:var(--w2)}
.hr{width:36px;height:2px;background:var(--g);display:block;margin:1.2rem 0}
.hr-r{width:36px;height:2px;background:var(--r);display:block;margin:1rem 0}
.btn{display:inline-block;font-family:var(--mono);font-size:9px;letter-spacing:3px;
  padding:.75rem 1.8rem;cursor:pointer;border:none;transition:.25s;text-decoration:none}
.btn-r{background:var(--r);color:var(--w)}.btn-r:hover{background:var(--r2)}
.btn-o{background:transparent;color:var(--w);border:1px solid rgba(240,237,232,.2)}
.btn-o:hover{border-color:var(--w);background:var(--w4)}
.observe{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.observe.in{opacity:1;transform:translateY(0)}

/* ── HERO ──────────────────────────────────────────────────────────────────── */
.hero{min-height:92vh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:5rem 2rem 4rem;position:relative;overflow:hidden;background:var(--k)}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 65% 55% at 75% 35%,rgba(192,17,43,.07),transparent 70%),radial-gradient(ellipse 40% 40% at 15% 75%,rgba(196,162,74,.04),transparent 60%)}
.hero-vline{position:absolute;right:32%;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,transparent,rgba(196,162,74,.15) 50%,transparent);pointer-events:none}
.hero-watermark{position:absolute;bottom:-2rem;right:-1rem;font-family:var(--disp);
  font-size:clamp(180px,28vw,400px);line-height:1;color:rgba(240,237,232,.018);
  pointer-events:none;user-select:none;letter-spacing:-10px}
.hero-content{position:relative;z-index:1;max-width:1240px;margin:0 auto;width:100%}

/* ── CINEMATIC POSTER ──────────────────────────────────────────────────────── */
.poster{position:relative;overflow:hidden;min-height:90vh;display:flex;
  flex-direction:column;background:var(--k);padding:2.5rem 2.5rem 5rem;
  border-top:1px solid var(--w4);border-bottom:1px solid var(--w4)}
.poster::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 80% at 50% 50%,transparent 30%,rgba(7,7,7,.85));
  z-index:1;pointer-events:none}
.poster::after{content:'';position:absolute;right:26%;top:0;bottom:0;width:1px;
  background:linear-gradient(to bottom,transparent,rgba(196,162,74,.2) 40%,transparent);
  z-index:1;pointer-events:none}
.poster-ghost{position:absolute;font-family:var(--disp);color:rgba(240,237,232,.028);
  line-height:1;pointer-events:none;user-select:none;z-index:0}
.poster-inner{position:relative;z-index:2;display:grid;grid-template-columns:320px 1fr 220px;
  min-height:calc(90vh - 8rem);max-width:1240px;margin:0 auto;width:100%;flex:1}

.poster-left{display:flex;flex-direction:column;justify-content:space-between;
  padding-right:2rem;border-right:1px solid var(--w4)}
.poster-top{padding-bottom:2rem}
.poster-bs{display:flex;align-items:center;gap:10px;margin-bottom:1.5rem}
.poster-bs-mark{width:30px;height:30px;background:transparent;border:1px solid var(--w3);
  display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-size:13px}
.poster-bs-txt{font-family:var(--disp);font-size:8px;letter-spacing:3px;line-height:1.5;color:var(--w3)}
.poster-hook{font-family:var(--disp);font-size:clamp(13px,1.4vw,16px);line-height:1.4;
  margin-bottom:1.5rem;letter-spacing:1px}
.poster-label{font-family:var(--body);font-size:clamp(32px,5vw,60px);line-height:.95;
  font-weight:600;margin-bottom:.4rem}
.poster-sublabel{font-family:var(--disp);font-size:clamp(20px,3vw,36px);line-height:1;
  color:var(--g);margin-bottom:1.2rem}
.poster-desc{font-family:var(--text);font-size:clamp(11px,1.2vw,13px);line-height:1.75;
  color:var(--w3);margin-bottom:1rem}
.poster-bullets{list-style:none;margin-top:1rem}
.poster-bullets li{font-family:var(--text);font-style:italic;font-size:clamp(11px,1.1vw,13px);
  line-height:1.6;color:var(--w3);margin-bottom:.4rem}
.poster-bottom{padding-top:2rem;border-top:1px solid var(--w4)}
.poster-brand{font-family:var(--disp);font-size:24px;letter-spacing:1px;line-height:1.1;margin-bottom:.2rem}
.poster-brand-tag{font-family:var(--body);font-size:11px;letter-spacing:2px;color:var(--w3)}

.poster-center{display:flex;flex-direction:column;justify-content:center;align-items:center;
  padding:0 1.5rem;position:relative}
.poster-big{font-family:var(--disp);font-size:clamp(72px,11vw,160px);line-height:.85;
  letter-spacing:-2px;text-align:center;position:relative;z-index:2}
.poster-divider-diamond{text-align:center;margin:1.5rem 0;color:var(--g);font-size:14px}
.poster-taglines{margin-top:1.5rem}
.poster-tagline-item{margin-bottom:.8rem}
.poster-tagline-item .top{font-family:var(--text);font-size:13px;color:var(--w3);font-style:italic}
.poster-tagline-item .bot{font-family:var(--body);font-size:clamp(16px,2vw,22px);
  letter-spacing:1px;font-weight:600}
.poster-center-line{width:1px;height:40px;background:linear-gradient(to bottom,transparent,var(--w4));
  margin:1rem auto}
.poster-glow{position:absolute;top:10%;bottom:10%;width:2px;
  background:linear-gradient(to bottom,transparent,var(--r) 50%,transparent);
  opacity:.3;left:50%;transform:translateX(-50%)}

.poster-right{display:flex;flex-direction:column;justify-content:center;align-items:flex-end;
  padding-left:2rem;border-left:1px solid var(--w4);gap:.4rem}
.poster-attr{display:flex;flex-direction:column;align-items:flex-end;margin-bottom:.8rem}
.poster-attr-text{font-family:var(--body);font-size:clamp(9px,1vw,11px);letter-spacing:2px;
  text-align:right;line-height:1.4;color:var(--w3);text-transform:uppercase}
.poster-attr-text span{color:var(--r)}
.poster-attr-text span.g{color:var(--g)}
.poster-attr-icon{width:24px;height:1px;background:var(--w4);margin:6px 0}
.poster-attr-sym{font-size:14px;text-align:right;color:rgba(240,237,232,.15);margin:.3rem 0}
.poster-words{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:flex-end;margin-top:1rem}
.poster-word{font-family:var(--mono);font-size:8px;letter-spacing:3px;color:var(--w3)}

.poster-foot{position:absolute;bottom:0;left:0;right:0;z-index:3;
  background:rgba(7,7,7,.6);backdrop-filter:blur(4px);padding:.8rem 2.5rem;
  display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--w4)}
.poster-foot-left{display:flex;align-items:center;gap:.8rem}
.poster-foot-right{display:flex;gap:2rem}
.poster-foot-tag{font-family:var(--mono);font-size:8px;letter-spacing:4px;color:var(--w3)}
.poster-foot-tag.on{color:var(--w)}
.barcode{display:flex;gap:1.5px;align-items:flex-end;height:18px}
.barcode span{display:block;width:1.5px;background:var(--w3)}

@media(max-width:900px){
  .poster-inner{grid-template-columns:1fr}
  .poster::after{display:none}
  .poster-left{border-right:none;border-bottom:1px solid var(--w4);padding-right:0;padding-bottom:2rem}
  .poster-right{border-left:none;border-top:1px solid var(--w4);padding-left:0;padding-top:2rem;align-items:flex-start}
  .poster-attr{align-items:flex-start}
  .poster-attr-text{text-align:left}
  .poster-words{justify-content:flex-start}
  .poster-inner{min-height:auto}
}

/* ── MARQUEE ───────────────────────────────────────────────────────────────── */
.mq{overflow:hidden;background:var(--r);padding:.7rem 0}
.mq-track{display:flex;width:max-content;animation:mq 20s linear infinite}
.mq-track:hover{animation-play-state:paused}
.mq-item{font-family:var(--disp);font-size:13px;letter-spacing:5px;padding:0 2rem;
  color:rgba(255,255,255,.9);white-space:nowrap}
.mq-item .dot{color:rgba(255,255,255,.4);margin:0 .3rem}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mq-sm{overflow:hidden;background:var(--k2);padding:.55rem 0;
  border-top:1px solid var(--w4);border-bottom:1px solid var(--w4)}
.mq-sm .mq-track{animation-duration:30s}
.mq-sm .mq-item{font-family:var(--mono);font-size:8px;letter-spacing:4px;color:var(--w3)}

/* ── SERVICE CARDS ─────────────────────────────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--w4)}
.svc-card{background:var(--k);padding:2.2rem;position:relative;overflow:hidden;transition:background .25s}
.svc-card:hover{background:var(--k2)}
.svc-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--r);
  transform:scaleY(0);transform-origin:bottom;transition:.35s}
.svc-card:hover::before{transform:scaleY(1)}
.svc-n{font-family:var(--disp);font-size:72px;color:var(--w4);line-height:1;margin-bottom:.3rem}
.svc-name{font-family:var(--disp);font-size:clamp(20px,2.2vw,30px);line-height:1.1;margin-bottom:.8rem}
.svc-arr{position:absolute;bottom:1.8rem;right:1.8rem;font-family:var(--mono);font-size:14px;
  color:var(--r);opacity:0;transform:translateX(-6px);transition:.3s}
.svc-card:hover .svc-arr{opacity:1;transform:translateX(0)}
@media(max-width:900px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.svc-grid{grid-template-columns:1fr}}

/* ── STATS ─────────────────────────────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--w4)}
.stat{background:var(--k2);padding:2.5rem 1.5rem;text-align:center}
.stat-n{font-family:var(--disp);font-size:clamp(52px,7vw,96px);line-height:1;color:var(--r)}
.stat-l{font-family:var(--mono);font-size:9px;letter-spacing:3px;color:var(--w3);margin-top:.4rem}
@media(max-width:700px){.stats{grid-template-columns:repeat(2,1fr)}}

/* ── VALUES ────────────────────────────────────────────────────────────────── */
.val-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--w4)}
.val-card{background:var(--k);padding:2.5rem;position:relative}
.val-num{position:absolute;top:.8rem;right:1.2rem;font-family:var(--disp);font-size:80px;
  color:rgba(240,237,232,.025);line-height:1}
.val-name{font-family:var(--disp);font-size:clamp(26px,3.5vw,44px);margin-bottom:.8rem}
@media(max-width:600px){.val-grid{grid-template-columns:1fr}}

/* ── TEAM ──────────────────────────────────────────────────────────────────── */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--w4)}
.team-card{background:var(--k);overflow:hidden}
.team-img{height:200px;background:var(--k3);display:flex;align-items:center;justify-content:center;
  font-family:var(--disp);font-size:72px;color:var(--w4);border-bottom:1px solid var(--w4)}
.team-body{padding:1.5rem}
.team-name{font-family:var(--disp);font-size:26px;margin-bottom:.2rem}
.team-role{font-family:var(--mono);font-size:8px;letter-spacing:3px;color:var(--g)}
@media(max-width:700px){.team-grid{grid-template-columns:1fr}}

/* ── WORK GRID ─────────────────────────────────────────────────────────────── */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--w4)}
.work-card{background:var(--k2);overflow:hidden;cursor:pointer;transition:.3s}
.work-card:hover{background:var(--k3)}
.work-img{height:280px;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;font-family:var(--disp);
  font-size:clamp(60px,8vw,110px);color:rgba(240,237,232,.04)}
.work-img .w-watermark{position:absolute;font-size:clamp(120px,18vw,200px);
  color:rgba(240,237,232,.025);pointer-events:none}
.work-body{padding:1.8rem}
.work-ind{font-family:var(--mono);font-size:8px;letter-spacing:3px;color:var(--r);margin-bottom:.7rem}
.work-title{font-family:var(--disp);font-size:clamp(20px,2.5vw,32px);margin-bottom:.6rem}
.work-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.8rem}
.work-tag{font-family:var(--mono);font-size:8px;letter-spacing:2px;padding:.25rem .6rem;
  border:1px solid var(--w4);color:var(--w3);transition:.2s}
.work-card:hover .work-tag{border-color:rgba(192,17,43,.35);color:var(--r)}
@media(max-width:700px){.work-grid{grid-template-columns:1fr}}

/* ── INSIGHTS ──────────────────────────────────────────────────────────────── */
.ins-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--w4)}
.ins-card{background:var(--k);padding:2rem;cursor:pointer;transition:.3s;position:relative}
.ins-card:hover{background:var(--k2)}
.ins-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:var(--g);transform:scaleX(0);transform-origin:left;transition:.35s}
.ins-card:hover::after{transform:scaleX(1)}
.ins-tag{font-family:var(--mono);font-size:8px;letter-spacing:3px;color:var(--r);margin-bottom:1rem}
.ins-title{font-family:var(--disp);font-size:clamp(16px,1.8vw,24px);line-height:1.15;margin-bottom:.8rem}
.ins-arr{font-family:var(--mono);font-size:9px;color:var(--g);margin-top:1.2rem;display:block;transition:.3s}
.ins-card:hover .ins-arr{letter-spacing:6px}
@media(max-width:900px){.ins-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.ins-grid{grid-template-columns:1fr}}

/* ── PROCESS STRIP ─────────────────────────────────────────────────────────── */
.process-strip{background:var(--r);padding:4rem 2rem}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
  max-width:1240px;margin:2.5rem auto 0;position:relative}
.process-steps::before{content:'';position:absolute;top:22px;left:8%;right:8%;
  height:1px;background:rgba(255,255,255,.2)}
.p-step{position:relative;z-index:1}
.p-step-n{font-family:var(--disp);font-size:52px;color:rgba(255,255,255,.35);line-height:1;margin-bottom:.5rem}
.p-step-name{font-family:var(--disp);font-size:22px;color:#fff}
.p-step-desc{font-family:var(--text);font-size:12px;color:rgba(255,255,255,.6);margin-top:.4rem;line-height:1.6}
@media(max-width:700px){.process-steps{grid-template-columns:repeat(2,1fr)}}

/* ── CODEX ─────────────────────────────────────────────────────────────────── */
.codex-panel{min-height:100vh;display:flex;position:relative;overflow:hidden;border-bottom:1px solid var(--w4)}
.codex-left{width:45%;padding:5rem 3rem;display:flex;flex-direction:column;justify-content:center;
  background:var(--k);z-index:2;position:relative}
.codex-right{flex:1;position:relative;overflow:hidden}
.codex-bg-text{position:absolute;font-family:var(--disp);line-height:.8;pointer-events:none;user-select:none}
.codex-attr-strip{position:absolute;right:0;top:0;bottom:0;width:180px;border-left:1px solid var(--w4);
  display:flex;flex-direction:column;justify-content:center;align-items:flex-end;
  padding:2rem 1.5rem;gap:1.5rem;background:rgba(7,7,7,.4);backdrop-filter:blur(4px);z-index:2}
.codex-attr{text-align:right}
.codex-attr-name{font-family:var(--body);font-size:9px;letter-spacing:3px;text-transform:uppercase;
  color:var(--w3);line-height:1.5}
.codex-attr-name span.r{color:var(--r)}
.codex-attr-name span.g{color:var(--g)}
.codex-attr-sep{width:24px;height:1px;background:var(--w4);margin:.5rem 0 .5rem auto}
.codex-attr-sym{font-size:16px;color:rgba(240,237,232,.12)}
.codex-number{font-family:var(--disp);font-size:clamp(150px,22vw,320px);line-height:.85;
  color:rgba(240,237,232,.025);position:absolute;bottom:-1rem;left:-1rem;pointer-events:none;user-select:none}
.codex-center-name{font-family:var(--disp);font-size:clamp(60px,9vw,130px);line-height:.9;
  position:absolute;bottom:4rem;left:3rem;z-index:2;text-shadow:0 0 80px rgba(7,7,7,.9)}
.codex-foot-strip{position:absolute;bottom:0;left:0;right:0;z-index:3;background:rgba(7,7,7,.7);
  backdrop-filter:blur(4px);padding:.7rem 1.5rem;display:flex;justify-content:space-between;
  align-items:center;border-top:1px solid var(--w4)}
@media(max-width:900px){
  .codex-panel{flex-direction:column;min-height:auto}
  .codex-left{width:100%;padding:3rem 1.5rem}
  .codex-right{min-height:50vh}
  .codex-attr-strip{width:140px;padding:1.5rem 1rem}
}

/* ── CTA BANNER ────────────────────────────────────────────────────────────── */
.cta-wrap{background:var(--k2);padding:5rem 2rem;text-align:center;position:relative;
  overflow:hidden;border-top:1px solid var(--w4);border-bottom:1px solid var(--w4)}
.cta-wrap::before{content:'BS';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);font-family:var(--disp);font-size:300px;
  color:rgba(240,237,232,.015);pointer-events:none;letter-spacing:-12px}

/* ── CONTACT ───────────────────────────────────────────────────────────────── */
.c-info-item{padding:1.8rem 0;border-bottom:1px solid var(--w4)}
.c-info-label{font-family:var(--mono);font-size:9px;letter-spacing:4px;color:var(--g);margin-bottom:.5rem}
.c-info-val{font-family:var(--disp);font-size:clamp(14px,2vw,24px)}
.c-form{background:var(--k2);padding:2.5rem}
.f-label{font-family:var(--mono);font-size:9px;letter-spacing:3px;color:var(--w3);
  display:block;margin-bottom:.6rem}
.f-in,.f-sel,.f-ta{width:100%;background:var(--k3);border:1px solid var(--w4);
  color:var(--w);font-family:var(--body);font-size:13px;letter-spacing:1px;
  padding:.8rem 1rem;outline:none;transition:.2s;resize:none;margin-bottom:1.5rem;
  -webkit-appearance:none}
.f-in:focus,.f-sel:focus,.f-ta:focus{border-color:var(--r)}
.f-ta{height:110px}
.f-sel option{background:var(--k3)}
.f-2{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media(max-width:900px){.f-2{grid-template-columns:1fr}}

/* ── FOOTER ────────────────────────────────────────────────────────────────── */
footer{background:var(--k2);padding:3.5rem 2rem 1.5rem;border-top:1px solid var(--w4)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.5rem;
  max-width:1240px;margin:0 auto}
.foot-logo{font-family:var(--disp);font-size:26px;letter-spacing:1px;line-height:1.1;margin-bottom:.3rem}
.foot-tag-line{font-family:var(--mono);font-size:8px;letter-spacing:3px;color:var(--w3)}
.foot-h{font-family:var(--mono);font-size:9px;letter-spacing:4px;color:var(--g);margin-bottom:1rem}
.foot-links{list-style:none}
.foot-links li{margin-bottom:.5rem}
.foot-links a{font-family:var(--body);font-size:13px;color:var(--w3);text-decoration:none;
  cursor:pointer;transition:.2s;letter-spacing:.5px}
.foot-links a:hover{color:var(--w)}
.foot-bottom{max-width:1240px;margin:2.5rem auto 0;padding-top:1.5rem;
  border-top:1px solid var(--w4);display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:1rem}
.foot-copy{font-family:var(--mono);font-size:8px;letter-spacing:2px;color:rgba(240,237,232,.2)}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.foot-grid{grid-template-columns:1fr}}

/* ── CURSOR ────────────────────────────────────────────────────────────────── */
.cur-dot{position:fixed;width:5px;height:5px;border-radius:50%;background:var(--r);
  pointer-events:none;z-index:10000;transform:translate(-50%,-50%)}
.cur-ring{position:fixed;width:28px;height:28px;border-radius:50%;
  border:1px solid rgba(192,17,43,.4);pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);transition:left .12s ease,top .12s ease,width .2s,height .2s,border-color .2s}
@media(hover:none){.cur-dot,.cur-ring{display:none}}

/* ── HERO CTA GRID (class added to home.html inline grid) ──────────────────── */
.hero-cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:2.5rem;align-items:flex-end}
@media(max-width:640px){
  .hero-cta-grid{grid-template-columns:1fr;gap:1.5rem}
  .hero-cta-grid>div:last-child{display:none} /* hide vertical scroll text */
}

/* ── CONTACT PAGE ──────────────────────────────────────────────────────────── */
@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr !important}
  .contact-grid > div[aria-hidden="true"]{display:none}
}

/* ── MOBILE CRITICAL FIXES ─────────────────────────────────────────────────── */
@media(max-width:780px){
  /* Spacing */
  .sec{padding:4rem 1.5rem}
  .sec-sm{padding:2.5rem 1.5rem}
  .wrap{padding:0 1.5rem}
  /* Hero */
  .hero{padding:4rem 1.5rem 3rem;min-height:80vh}
  /* Poster resets */
  .poster{padding:2rem 1.5rem 5rem;overflow:hidden}
  .poster-ghost{opacity:.4;font-size:clamp(120px,28vw,240px)!important;left:-1rem!important;right:auto!important}
  .poster-inner{grid-template-columns:1fr!important;gap:0;min-height:auto!important}
  .poster-left{border-right:none!important;border-bottom:1px solid var(--w4);padding-right:0!important;padding-bottom:2rem}
  .poster-center{padding:2rem 0;align-items:flex-start}
  .poster-big{font-size:clamp(60px,16vw,110px)!important}
  .poster-right{display:none} /* hide decorative right column on mobile */
  .poster-foot{padding:.8rem 1.5rem}
  .poster-foot-right{gap:.8rem}
  .poster-foot-tag{font-size:7px}
  /* Codex / case studies */
  .codex-panel{flex-direction:column;min-height:auto!important}
  .codex-left{width:100%!important;padding:3rem 1.5rem!important}
  .codex-right{min-height:55vw!important}
  .codex-attr-strip{width:120px;padding:1rem .8rem}
  .codex-center-name{font-size:clamp(44px,12vw,80px)!important;left:1.5rem!important;bottom:3rem!important}
  .codex-number{font-size:clamp(100px,22vw,160px)!important}
  /* Process */
  .process-steps::before{display:none}
  /* Stats */
  .stats{grid-template-columns:repeat(2,1fr)}
  /* Values */
  .val-grid{grid-template-columns:1fr}
  /* Team */
  .team-grid{grid-template-columns:repeat(2,1fr)}
  /* Footer */
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
}

@media(max-width:480px){
  /* Nav */
  .n-btn{font-size:8px;padding:.5rem .9rem;letter-spacing:2px}
  /* Spacing */
  .sec{padding:3rem 1.2rem}
  .wrap{padding:0 1.2rem}
  /* Hero */
  .hero{padding:3.5rem 1.2rem 2.5rem;min-height:75vh}
  .d1{font-size:clamp(52px,14vw,80px)!important}
  .d2{font-size:clamp(36px,11vw,60px)!important}
  .d3{font-size:clamp(26px,8.5vw,44px)!important}
  /* Posters */
  .poster{padding:1.5rem 1.2rem 4.5rem}
  .poster-label{font-size:clamp(24px,7vw,42px)!important}
  .poster-sublabel{font-size:clamp(16px,5.5vw,28px)!important}
  .poster-foot{padding:.7rem 1.2rem}
  .poster-foot-right{display:none}
  /* Codex */
  .codex-left{padding:2.5rem 1.2rem!important}
  .codex-attr-strip{display:none}  /* too cramped on small phones */
  .codex-center-name{left:1.2rem!important;bottom:2.5rem!important;font-size:clamp(40px,12vw,70px)!important}
  /* Services */
  .svc-grid{grid-template-columns:1fr}
  .svc-card{padding:1.8rem 1.2rem}
  /* Stats */
  .stat{padding:2rem 1rem}
  /* Team */
  .team-grid{grid-template-columns:1fr}
  /* Process */
  .process-strip{padding:3rem 1.2rem}
  .process-steps{grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:2rem}
  /* Insights */
  .ins-card{padding:1.5rem}
  /* Contact form */
  .c-form{padding:1.8rem 1.2rem}
  .f-2{grid-template-columns:1fr!important}
  /* Footer */
  .foot-grid{grid-template-columns:1fr;gap:1.8rem}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:.6rem}
  /* CTA banner watermark */
  .cta-wrap::before{font-size:160px!important}
  /* Work grid */
  .work-grid{grid-template-columns:1fr}
  .work-img{height:200px}
  /* Ins grid */
  .ins-grid{grid-template-columns:1fr}
}

/* Prevent horizontal overflow from large decorative text */
.hero-watermark,.poster-ghost,.codex-bg-text,.codex-number,.cta-wrap::before{
  pointer-events:none;overflow:hidden
}

/* ── FORM FEEDBACK ─────────────────────────────────────────────────────────── */
.form-msg{font-family:var(--mono);font-size:9px;letter-spacing:2px;padding:.8rem 1rem;
  margin-top:1rem;display:none}
.form-msg.success{background:rgba(196,162,74,.1);border:1px solid var(--g);color:var(--g);display:block}
.form-msg.error{background:rgba(192,17,43,.1);border:1px solid var(--r);color:var(--r);display:block}
.btn[disabled]{opacity:.5;cursor:not-allowed}
