/* ============================================================
   EXECUTE — shared base styles
   Color system: each page sets --fill / --ink / --accent
   ============================================================ */

:root{
  --black:#000;
  --fill:#DAFF00;          /* page signature color (overridden per page) */
  --ink:#000;              /* foreground on fill */
  --accent:#000;
  --silver-1:#fdfdfd;
  --silver-2:#dcdcdc;
  --silver-3:#a8a8a8;
  --frame:14px;
  --radius:30px;
  --font-display:"Helvetica Neue",Helvetica,Arial,sans-serif;
  --font-mono:"Space Mono",ui-monospace,"SF Mono",Menlo,monospace;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  background:var(--black);
  font-family:var(--font-display);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  background:var(--black);
  cursor:none;
}
body{scrollbar-width:none}
body::-webkit-scrollbar{display:none}
@media (pointer:coarse){ body{cursor:auto} }

/* ---------- the coloured page + rounded frame via body background ----------
   No position:fixed overlay → zero scroll glitch on iOS/Android.
   Body is black; .viewport sits inset with border-radius so the body
   shows through as the frame. Works perfectly on all devices. */
.viewport{
  position:relative;
  min-height:calc(100vh - var(--frame) * 2);
  background:var(--fill);
  transition:background .6s var(--ease);
  overflow:hidden;
  margin:var(--frame);
  border-radius:var(--radius);
}
.scroll{display:block}

/* ::after no longer needed — body background is the frame */
.viewport::after{display:none}

/* subtle noise / speckle texture over the fill */
.viewport::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:2;
  background-image:radial-gradient(rgba(0,0,0,.5) .6px,transparent .7px);
  background-size:7px 7px;
  mix-blend-mode:multiply;
  opacity:.12;
}

/* ---------- header ---------- */
.site-head{
  position:sticky;
  top:0;            /* sticks at top of .viewport (already offset by margin) */
  z-index:40;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:30px 46px;
  background:var(--fill);
  transition:background .6s var(--ease);
}
.site-head::after{content:"";position:absolute;left:46px;right:46px;bottom:0;height:2px;background:var(--ink);opacity:0;transition:opacity .3s}
.site-head.stuck::after{opacity:.12}

.logo{
  display:flex;
  align-items:center;
  flex:none;
  text-decoration:none;
}
/* uploaded .EXEcute wordmark, tinted to --ink via mask so it themes per page */
.logo .gl{
  --logo-w:190px; --logo-h:31px;
  position:relative;display:block;
  width:var(--logo-w);height:var(--logo-h);
  transition:transform .35s var(--ease);
}
.logo:hover .gl{transform:translateX(1px) skewX(-2deg)}
.logo .gl i{
  position:absolute;inset:0;display:block;
  background:var(--ink);
  -webkit-mask:url(img/execute-logo.png) left center/contain no-repeat;
          mask:url(img/execute-logo.png) left center/contain no-repeat;
}
.logo .gl .l2,.logo .gl .l3{opacity:0;mix-blend-mode:screen}
@media (prefers-reduced-motion:no-preference){
  .logo:hover .gl .l1{animation:glMain .42s steps(2,end) infinite}
  .logo:hover .gl .l2{opacity:1;background:#ff2e6e;animation:glA .42s steps(2,end) infinite}
  .logo:hover .gl .l3{opacity:1;background:#23f0ff;animation:glB .42s steps(2,end) infinite}
}
@keyframes glMain{
  0%,100%{clip-path:inset(0 0 0 0);transform:translate(0)}
  30%{clip-path:inset(0 0 0 0);transform:translate(-1px,0)}
  31%{clip-path:inset(38% 0 40% 0);transform:translate(2px,0)}
  34%{clip-path:inset(0 0 0 0);transform:translate(0)}
  70%{clip-path:inset(72% 0 8% 0);transform:translate(-2px,0)}
  73%{clip-path:inset(0 0 0 0);transform:translate(0)}
}
@keyframes glA{
  0%,100%{clip-path:inset(0 0 0 0);transform:translate(-2.5px,0)}
  20%{clip-path:inset(15% 0 60% 0);transform:translate(-4px,1px)}
  40%{clip-path:inset(55% 0 20% 0);transform:translate(-2px,-1px)}
  60%{clip-path:inset(80% 0 5% 0);transform:translate(-5px,0)}
  80%{clip-path:inset(30% 0 45% 0);transform:translate(-2px,1px)}
}
@keyframes glB{
  0%,100%{clip-path:inset(0 0 0 0);transform:translate(2.5px,0)}
  20%{clip-path:inset(65% 0 12% 0);transform:translate(4px,-1px)}
  40%{clip-path:inset(10% 0 70% 0);transform:translate(2px,1px)}
  60%{clip-path:inset(40% 0 35% 0);transform:translate(5px,0)}
  80%{clip-path:inset(78% 0 6% 0);transform:translate(2px,-1px)}
}

.nav{
  display:flex;
  align-items:center;
  gap:24px;
  flex:none;
}
.nav a.navlink{
  text-decoration:none;
  color:var(--ink);
  font-weight:800;
  font-style:italic;
  font-size:16.5px;
  letter-spacing:-.01em;
  position:relative;
  opacity:.92;
  transition:opacity .25s;
}
.nav a.navlink::after{
  content:"";
  position:absolute;
  left:0;right:100%;
  bottom:-5px;
  height:2.5px;
  background:var(--ink);
  transition:right .3s var(--ease);
}
.nav a.navlink:hover{opacity:1}
.nav a.navlink:hover::after,
.nav a.navlink[aria-current="page"]::after{right:0}
.nav a.navlink[aria-current="page"]{opacity:1}

.cta-pill{
  text-decoration:none;
  color:var(--ink);
  background:#fff;
  border:2px solid var(--ink);
  border-radius:999px;
  padding:11px 22px 12px;
  font-weight:800;
  font-size:14px;
  letter-spacing:.04em;
  text-transform:uppercase;
  transition:transform .3s var(--ease),background .3s,color .3s;
}
.cta-pill:hover{background:var(--ink);color:var(--fill);transform:translateY(-2px)}

.icon-btn{
  width:42px;height:42px;border-radius:50%;
  background:var(--ink);color:var(--fill);
  display:grid;place-items:center;
  text-decoration:none;
  transition:transform .3s var(--ease);
}
.icon-btn:hover{transform:scale(1.1) rotate(6deg)}
.icon-btn svg{width:20px;height:20px;fill:var(--fill)}

/* language toggle */
.lang{
  display:flex;align-items:center;gap:0;
  border:2px solid var(--ink);border-radius:999px;
  overflow:hidden;font-family:var(--font-mono);
  font-size:11px;font-weight:700;
}
.lang button{
  cursor:none;background:transparent;border:0;color:var(--ink);
  padding:7px 9px;font:inherit;letter-spacing:.05em;opacity:.5;
  transition:background .25s,color .25s,opacity .25s;
}
.lang button.on{background:var(--ink);color:var(--fill);opacity:1}

/* ---------- vertical legal rail ---------- */
.legal-rail{
  position:fixed;
  left:calc(var(--frame) + 14px);
  top:50%;
  transform:translateY(-50%) rotate(180deg);
  writing-mode:vertical-rl;
  z-index:30;
  display:flex;gap:30px;
  font-family:var(--font-mono);
  font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;
}
.legal-rail a{color:var(--ink);text-decoration:none;opacity:.6;transition:opacity .25s}
.legal-rail a:hover{opacity:1}

/* ---------- custom cursor: FPS crosshair ---------- */
.cursor,.cursor-dot{
  position:fixed;top:0;left:0;z-index:9999;
  pointer-events:none;
  mix-blend-mode:difference;
}
.cursor{
  width:30px;height:30px;
  transform:translate(-50%,-50%);
  transition:width .22s var(--ease),height .22s var(--ease);
}
/* vertical + horizontal ticks with a transparent center gap */
.cursor::before,.cursor::after{content:"";position:absolute;}
.cursor::before{
  left:50%;top:0;width:2px;height:100%;transform:translateX(-50%);
  background:linear-gradient(#fff 0 32%,transparent 32% 68%,#fff 68% 100%);
}
.cursor::after{
  top:50%;left:0;height:2px;width:100%;transform:translateY(-50%);
  background:linear-gradient(90deg,#fff 0 32%,transparent 32% 68%,#fff 68% 100%);
}
.cursor-dot{
  width:3px;height:3px;background:#fff;border-radius:50%;
  transform:translate(-50%,-50%);
}
.cursor.is-hover{width:48px;height:48px}
.cursor.is-down{width:20px;height:20px}
@media (pointer:coarse){ .cursor,.cursor-dot{display:none} }

/* ---------- bullet-hole click effect ---------- */
.bullet-hole{
  position:fixed;z-index:9998;pointer-events:none;
  width:16px;height:16px;transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle at 50% 42%, #000 0 32%, rgba(0,0,0,.55) 46%, rgba(0,0,0,0) 72%);
  animation:bulletHole 1s var(--ease) forwards;
}
/* impact shock-ring */
.bullet-hole::before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid rgba(0,0,0,.5);
  animation:bulletRing .45s var(--ease) forwards;
}
/* crack flecks */
.bullet-hole::after{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  background:
    radial-gradient(1.5px 1.5px at 10% 30%, rgba(0,0,0,.6) 99%, transparent),
    radial-gradient(1.5px 1.5px at 88% 60%, rgba(0,0,0,.6) 99%, transparent),
    radial-gradient(1.5px 1.5px at 60% 12%, rgba(0,0,0,.6) 99%, transparent),
    radial-gradient(1.5px 1.5px at 34% 86%, rgba(0,0,0,.6) 99%, transparent);
}
@keyframes bulletHole{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.2)}
  10%{opacity:1;transform:translate(-50%,-50%) scale(1.12)}
  22%{transform:translate(-50%,-50%) scale(1)}
  70%{opacity:1}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1)}
}
@keyframes bulletRing{
  0%{opacity:.9;transform:scale(.3)}
  100%{opacity:0;transform:scale(1.9)}
}
@media (pointer:coarse){ .bullet-hole{display:none} }

/* ---------- generic layout ---------- */
.wrap{max-width:1240px;margin:0 auto;padding:0 56px}
.eyebrow{
  font-family:var(--font-mono);
  font-size:12.5px;letter-spacing:.26em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--ink);display:inline-block}

h1,h2,h3{font-weight:800;letter-spacing:-.03em;line-height:.96}
.display-xl{font-size:clamp(48px,8.5vw,128px);font-style:italic;text-transform:uppercase;line-height:.9}
.display-l{font-size:clamp(40px,6vw,86px);font-style:italic;text-transform:uppercase}
.display-m{font-size:clamp(30px,4vw,56px)}

/* ---------- footer ---------- */
.site-foot{
  position:relative;z-index:5;
  border-top:2px solid var(--ink);
  margin:90px 46px 0;
  padding:40px 0 34px;
}
.foot-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;
}
.foot-grid h4{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;opacity:.6;margin-bottom:16px;font-weight:700;
}
.foot-links{display:flex;flex-direction:column;gap:9px}
.foot-links a{
  color:var(--ink);text-decoration:none;font-weight:700;font-size:17px;
  font-style:italic;width:fit-content;position:relative;opacity:.9;
}
.foot-links a:hover{opacity:1}
.foot-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:2px;background:var(--ink);transition:right .3s var(--ease)}
.foot-links a:hover::after{right:0}
.foot-bottom{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-top:54px;gap:20px;flex-wrap:wrap;
}
.foot-bottom .big-mark{
  font-size:clamp(40px,9vw,120px);font-weight:900;font-style:italic;
  line-height:.8;letter-spacing:-.04em;text-transform:uppercase;
}
/* footer logo with binary-scramble hover */
.foot-logo{position:relative;display:block;width:min(520px,62vw);aspect-ratio:992/178;cursor:none;text-decoration:none}
.foot-logo .fl-img,.foot-logo .fl-bits{
  position:absolute;inset:0;
  -webkit-mask:url(img/execute-logo.png) left center/contain no-repeat;
          mask:url(img/execute-logo.png) left center/contain no-repeat;
}
.foot-logo .fl-img{background:var(--ink);transition:opacity .3s}
.foot-logo .fl-bits{
  color:var(--ink);font-family:var(--font-mono);font-weight:700;
  font-size:11px;line-height:1.08;letter-spacing:.5px;word-break:break-all;
  overflow:hidden;opacity:0;transition:opacity .3s;user-select:none;
}
.foot-logo:hover .fl-img{opacity:0}
.foot-logo:hover .fl-bits{opacity:1}
@media (prefers-reduced-motion:reduce){
  .foot-logo:hover .fl-img{opacity:1}
  .foot-logo:hover .fl-bits{opacity:0}
}
.foot-meta{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;opacity:.6;text-align:right;line-height:1.7}

/* ============================================================
   WORK — case studies
   ============================================================ */
.cases{display:flex;flex-direction:column;gap:64px}
.case{display:grid;grid-template-columns:1.02fr .98fr;gap:44px;align-items:center}
.case:nth-child(even) .case-media{order:2}
.case-media{aspect-ratio:4/3;border-radius:22px;overflow:hidden;border:2px solid var(--ink);background:rgba(0,0,0,.04);display:block}
.case-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--ease)}
.case:hover .case-media img{transform:scale(1.04)}
/* clickable index cards */
.case-title a{color:inherit;text-decoration:none}
.case-title a:hover{opacity:.65}
.case-link{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--ink);text-decoration:none;border-bottom:2px solid var(--ink);padding-bottom:3px;width:fit-content;transition:gap .3s var(--ease)}
.case-link:hover{gap:14px}
/* ---- case-study detail pages ---- */
.detail-hero-img{width:100%;aspect-ratio:16/7;object-fit:cover;border:2px solid var(--ink);border-radius:24px;margin-top:32px;display:block}
.prose{max-width:64ch}
.prose p{font-size:17.5px;line-height:1.62;margin-bottom:18px;font-weight:450}
.prose p:last-child{margin-bottom:0}
.prose strong{font-weight:800}
.prose em{font-style:italic}
.prose ul{list-style:none;margin:20px 0 0;display:flex;flex-direction:column;gap:11px}
.prose li{padding-left:26px;position:relative;font-size:16.5px;line-height:1.5}
.prose li::before{content:"→";position:absolute;left:0;font-weight:700}
.detail-lede{font-size:clamp(20px,2.3vw,27px);line-height:1.4;font-weight:600;max-width:60ch}
.detail-stats{display:flex;gap:40px;flex-wrap:wrap;margin-top:34px}
.detail-stats .cs-n{display:block;font-size:clamp(28px,3vw,44px);font-weight:800;font-style:italic;letter-spacing:-.02em;line-height:1}
.detail-stats .cs-l{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;opacity:.6;margin-top:8px;display:block;max-width:18ch}
.case-nav{display:flex;justify-content:space-between;align-items:center;gap:20px;margin:0 46px;padding:30px 0 0;border-top:2px solid var(--ink)}
.case-nav a{color:var(--ink);text-decoration:none;font-family:var(--font-mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;transition:opacity .25s}
.case-nav a:hover{opacity:.55}
.casehold{
  border:2px solid var(--ink);border-radius:22px;aspect-ratio:4/3;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;padding:24px 26px;
  background:repeating-linear-gradient(135deg, rgba(0,0,0,.06) 0 14px, rgba(0,0,0,0) 14px 28px);
}
.casehold .ch-k{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.5}
.casehold .ch-name{font-size:clamp(30px,4vw,56px);font-weight:800;font-style:italic;text-transform:uppercase;line-height:.9;letter-spacing:-.02em;align-self:flex-start;text-wrap:balance}
.case.pending .case-lede{opacity:.6}
.case-soon{display:inline-block;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;border:1.6px solid var(--ink);border-radius:999px;padding:6px 13px;margin-top:22px;opacity:.6}
.case-no{font-family:var(--font-mono);font-size:13px;letter-spacing:.18em;opacity:.5}
.case-tags{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 6px}
.case-title{font-size:clamp(34px,4.8vw,72px);font-style:italic;text-transform:uppercase;line-height:.88;margin:8px 0 16px}
.case-lede{font-size:19px;line-height:1.45;font-weight:500;max-width:46ch}
.case-stats{display:flex;gap:34px;margin-top:26px;flex-wrap:wrap}
.case-stats .cs-n{display:block;font-size:clamp(26px,2.4vw,34px);font-weight:800;font-style:italic;line-height:1;letter-spacing:-.02em}
.case-stats .cs-l{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;opacity:.6;margin-top:7px;display:block;max-width:16ch}

.worktiles{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.wtile{border:2px solid var(--ink);border-radius:18px;padding:24px 24px 26px;display:flex;flex-direction:column;justify-content:space-between;gap:30px;min-height:158px;text-decoration:none;color:var(--ink);transition:background .35s var(--ease),color .35s,transform .35s var(--ease)}
.wtile:hover{background:var(--ink);color:var(--fill);transform:translateY(-4px)}
.wtile .wt-tag{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.55}
.wtile .wt-name{font-size:clamp(22px,2vw,28px);font-style:italic;text-transform:uppercase;font-weight:800;line-height:.95}

.ecosystem{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.eco{border:2px solid var(--ink);border-radius:18px;padding:24px 26px;text-decoration:none;color:var(--ink);display:flex;flex-direction:column;gap:14px;transition:background .35s var(--ease),color .35s,transform .35s var(--ease)}
.eco:hover{background:var(--ink);color:var(--fill);transform:translateY(-4px)}
.eco .eco-name{font-size:21px;font-style:italic;text-transform:uppercase;font-weight:800}
.eco .eco-url{font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;opacity:.6}
.eco .eco-go{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase}

/* rich ecosystem cards (image-topped) */
.ecogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ecocard{
  border:2px solid var(--ink);border-radius:20px;overflow:hidden;text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;background:transparent;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.ecocard:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(0,0,0,.16)}
.ecocard-img{aspect-ratio:3/2;overflow:hidden;border-bottom:2px solid var(--ink)}
.ecocard-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s var(--ease)}
.ecocard:hover .ecocard-img img{transform:scale(1.05)}
.ecocard-body{padding:24px 26px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
.ecocard-k{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;opacity:.55}
.ecocard h3{font-size:clamp(24px,2.4vw,32px);font-style:italic;text-transform:uppercase;line-height:.95}
.ecocard p{font-size:15.5px;line-height:1.5;font-weight:500;opacity:.85;flex:1}
.ecocard .eco-go{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin-top:6px}

@media (max-width:900px){
  /* switch to block on mobile — DOM order wins, no grid/order conflicts */
  .case{display:block}
  .case-media{display:block;width:100%;margin-bottom:28px}
  .case:nth-child(even) .case-media{order:unset}
  .case-body{display:block}
  .cases{gap:56px}
  /* fix: line-height:.88 causes line overlap on mobile at min font-size */
  .case-title{font-size:clamp(26px,7vw,44px);line-height:.96}
  .case-lede{font-size:16px;max-width:100%}
  .case-stats{gap:16px}
  .case-stats .cs-n{font-size:22px}
  .case-no{font-size:11px}
  /* ecocard */
  .ecocard h3{font-size:clamp(22px,5vw,28px);line-height:.96}
  .worktiles,.ecosystem,.ecogrid{grid-template-columns:1fr}
}

/* ---------- contact popup ---------- */
.modal-scrim{
  position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .4s var(--ease);
}
.modal-scrim.open{opacity:1;pointer-events:auto}
.modal{
  width:min(560px,92vw);
  background:var(--black);
  color:#fff;
  border-radius:26px;
  padding:46px 44px 40px;
  transform:translateY(24px) scale(.97);
  opacity:0;
  transition:transform .5s var(--ease),opacity .5s var(--ease);
  position:relative;
}
.modal-scrim.open .modal{transform:none;opacity:1}
.modal .close{
  position:absolute;top:20px;right:22px;
  width:38px;height:38px;border-radius:50%;
  background:transparent;border:1.5px solid rgba(255,255,255,.4);
  color:#fff;font-size:18px;cursor:none;
  display:grid;place-items:center;transition:background .25s,border-color .25s}
.modal .close:hover{background:#fff;color:#000;border-color:#fff}
.modal .m-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--fill);margin-bottom:14px}
.modal h3{font-size:clamp(28px,4.4vw,40px);font-style:italic;text-transform:uppercase;line-height:.95;margin-bottom:26px}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;opacity:.55;margin-bottom:8px}
.field input,.field textarea{
  width:100%;background:transparent;border:0;border-bottom:1.5px solid rgba(255,255,255,.25);
  color:#fff;font-family:var(--font-display);font-size:18px;padding:8px 0;cursor:none;resize:none;
  transition:border-color .25s}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.3)}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--fill)}
.modal .submit{
  margin-top:8px;width:100%;
  background:var(--fill);color:#000;border:0;border-radius:999px;
  padding:16px;font-family:var(--font-display);font-weight:800;font-size:15px;
  letter-spacing:.04em;text-transform:uppercase;cursor:none;
  transition:transform .3s var(--ease),filter .3s}
.modal .submit:hover{transform:translateY(-2px);filter:brightness(1.05)}
.modal .m-note{font-family:var(--font-mono);font-size:11px;opacity:.45;margin-top:16px;text-align:center}
.modal .m-ok{color:var(--fill);text-align:center;font-family:var(--font-mono);font-size:13px;letter-spacing:.05em;padding:20px 0;display:none}
.modal.done .m-form{display:none}
.modal.done .m-ok{display:block}

/* ---------- page transition curtain ---------- */
.curtain{
  position:fixed;inset:0;z-index:500;background:var(--black);
  transform:scaleY(0);transform-origin:bottom;pointer-events:none;
}
.curtain.in{transform:scaleY(1);transform-origin:bottom;transition:transform .5s var(--ease)}
.curtain.out{transform:scaleY(0);transform-origin:top;transition:transform .5s var(--ease)}

/* ---------- reveal on load/scroll ----------
   Base state is VISIBLE. Hidden state only applies when JS is active
   (html.js) AND motion is allowed — so content never gets stuck hidden. */
@media (prefers-reduced-motion: no-preference){
  html.js [data-reveal].will-reveal{opacity:0;transform:translateY(26px)}
  html.js [data-reveal].will-reveal.seen{opacity:1;transform:none;
    transition:opacity .8s var(--ease),transform .8s var(--ease)}
}

/* ============================================================
   CONTENT-PAGE SYSTEM (Advisory / Domains / Lab / Work / Contact)
   ============================================================ */
.page-hero{padding:40px 0 70px}
.page-hero .wrap{position:relative;z-index:5}
.page-hero h1{
  font-size:clamp(52px,11vw,170px);font-style:italic;text-transform:uppercase;
  line-height:.84;letter-spacing:-.03em;margin:22px 0 0;mix-blend-mode:multiply;
}
.page-hero .lede{
  margin-top:30px;max-width:34ch;font-size:clamp(19px,2.1vw,26px);
  font-weight:500;line-height:1.32;
}
.hero-row{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}
.hero-index{font-family:var(--font-mono);font-size:13px;letter-spacing:.2em;opacity:.55;text-transform:uppercase}

.section{padding:46px 0;position:relative;z-index:5}
.section + .section{border-top:2px solid var(--ink)}
.sec-head{display:grid;grid-template-columns:.4fr 1fr;gap:30px;align-items:start;margin-bottom:38px}
.sec-head .num{font-family:var(--font-mono);font-size:13px;letter-spacing:.18em;opacity:.55;padding-top:10px}
.sec-head h2{font-size:clamp(30px,4.4vw,62px);font-style:italic;text-transform:uppercase;line-height:.92}
.sec-head .k{font-family:var(--font-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;opacity:.6;margin-bottom:14px}

/* card grid */
.grid{display:grid;gap:18px}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.card{
  border:2px solid var(--ink);border-radius:22px;padding:30px 28px 34px;
  background:transparent;position:relative;overflow:hidden;
  transition:background .35s var(--ease),color .35s var(--ease),transform .35s var(--ease);
}
.card:hover{background:var(--ink);color:var(--fill);transform:translateY(-4px)}
.card:hover .card-no,.card:hover .card-k{opacity:.7}
/* capability card with a photo at the top */
.card.has-thumb{padding:0;display:flex;flex-direction:column}
.card-thumb{display:block;width:100%;aspect-ratio:4/3;overflow:hidden;border-bottom:2px solid var(--ink);background:rgba(0,0,0,.06)}
.card-thumb img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.15) contrast(1.02);transition:transform .6s var(--ease),filter .4s}
.card.has-thumb:hover .card-thumb{border-bottom-color:var(--fill)}
.card.has-thumb:hover .card-thumb img{transform:scale(1.05);filter:none}
.card.has-thumb .card-body{padding:24px 26px 30px}
.card .card-no{font-family:var(--font-mono);font-size:12px;letter-spacing:.18em;opacity:.5}
.card h3{font-size:clamp(24px,2.6vw,34px);font-style:italic;text-transform:uppercase;line-height:.96;margin:18px 0 12px}
.card p{font-size:16px;line-height:1.5;opacity:.85;font-weight:500}
.card .card-k{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.5;margin-top:18px}
.card ul{list-style:none;margin-top:16px;display:flex;flex-direction:column;gap:8px}
.card ul li{font-family:var(--font-mono);font-size:13px;letter-spacing:.02em;padding-left:18px;position:relative;opacity:.85}
.card ul li::before{content:"→";position:absolute;left:0}

/* big numbered list rows */
.rows{border-top:2px solid var(--ink)}
.row{
  display:grid;grid-template-columns:80px 1fr auto;gap:24px;align-items:center;
  padding:26px 6px;border-bottom:2px solid var(--ink);cursor:none;
  transition:padding-left .35s var(--ease),background .35s;
}
.row:hover{padding-left:24px}
.row .r-no{font-family:var(--font-mono);font-size:14px;opacity:.5}
.row .r-title{font-size:clamp(24px,3.4vw,46px);font-style:italic;text-transform:uppercase;line-height:.95}
.row .r-meta{font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;opacity:.6;text-align:right}

/* media placeholder */
.media{
  border-radius:22px;overflow:hidden;position:relative;
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,.07) 0 12px, rgba(0,0,0,0) 12px 24px);
  border:2px solid var(--ink);
  display:grid;place-items:center;aspect-ratio:4/3;
}
.media .ph{font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.55;text-align:center;padding:20px}
.media.tall{aspect-ratio:3/4}
.media.wide{aspect-ratio:16/9}
.media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}

/* ============================================================
   GUILD — world-map network, members, partners
   ============================================================ */
.netmap{
  position:relative;z-index:5;margin:0 46px;border-radius:26px;overflow:hidden;
  background:radial-gradient(120% 140% at 50% 0%, #8E8BFF 0%, #6C66F2 45%, #4F49D6 100%);
  border:2px solid var(--ink);
}
.netmap canvas{display:block;width:100%;height:auto}
/* member avatars pinned to network nodes (mood, no labels) */
.netnodes{position:absolute;inset:0;z-index:2;pointer-events:none}
.netnode{
  position:absolute;width:clamp(34px,3.6vw,52px);aspect-ratio:1/1;border-radius:50%;
  transform:translate(-50%,-50%);overflow:hidden;border:2.5px solid #fff;
  box-shadow:0 6px 18px rgba(20,16,60,.45);background:#cfd2f5;pointer-events:auto;
  transition:transform .4s var(--ease),box-shadow .4s;animation:nodefloat 6s ease-in-out infinite;
}
.netnode img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.25) contrast(1.02)}
.netnode:hover{transform:translate(-50%,-50%) scale(1.18);box-shadow:0 10px 26px rgba(20,16,60,.6);z-index:3}
.netnode:hover img{filter:none}
@keyframes nodefloat{0%,100%{margin-top:0}50%{margin-top:-5px}}
@media (prefers-reduced-motion:reduce){.netnode{animation:none}}
.netmap .netcap{
  position:absolute;left:34px;bottom:28px;z-index:3;color:#fff;max-width:30ch;
}
.netmap .netcap .k{font-family:var(--font-mono);font-size:clamp(7px,.75vw,11px);letter-spacing:.22em;text-transform:uppercase;opacity:.8}
.netmap .netcap h3{font-size:clamp(13px,3vw,38px);font-style:italic;text-transform:uppercase;line-height:.95;margin-top:clamp(4px,.6vw,8px)}
.netmap .netstat{
  position:absolute;right:34px;top:30px;z-index:3;display:flex;gap:30px;color:#fff;text-align:right;
}
.netmap .netstat .n{font-size:clamp(16px,3.4vw,46px);font-weight:800;font-style:italic;line-height:1}
.netmap .netstat .l{font-family:var(--font-mono);font-size:clamp(6px,.72vw,10.5px);letter-spacing:.14em;text-transform:uppercase;opacity:.75;margin-top:clamp(3px,.5vw,6px)}

/* member grid */
.members{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.member{display:flex;flex-direction:column;align-items:center;text-align:center}
.member .pf{
  width:100%;aspect-ratio:1/1;border-radius:50%;overflow:hidden;border:2px solid var(--ink);
  background:#e7e7e7;position:relative;transition:transform .4s var(--ease);
}
.member .pf img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1);transition:filter .4s}
.member:hover .pf{transform:translateY(-6px)}
.member:hover .pf img{filter:grayscale(0)}
.member .nm{font-weight:800;font-style:italic;font-size:17px;margin-top:14px;letter-spacing:-.01em}
.member .rl{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;opacity:.6;margin-top:4px}

/* partner wall — 5 x 2 grid of clickable logos */
.partners{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border:2px solid var(--ink);border-radius:22px;overflow:hidden}
.partner{
  aspect-ratio:3/2;display:grid;place-items:center;padding:26px;
  border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);
  background:#fff;transition:background .3s;cursor:none;text-decoration:none;
}
.partner img{max-width:100%;max-height:62px;object-fit:contain;filter:grayscale(1);opacity:.7;transition:filter .35s,opacity .35s,transform .35s}
.partner:hover img{filter:grayscale(0);opacity:1;transform:scale(1.06)}
/* typographic tile for partners without a logo file */
.partner .partner-wm{font-weight:800;font-style:italic;text-transform:uppercase;font-size:clamp(14px,1.3vw,20px);letter-spacing:-.02em;color:#000;opacity:.55;text-align:center;line-height:1;transition:opacity .35s,transform .35s}
.partner:hover .partner-wm{opacity:1;transform:scale(1.04)}
.partner:nth-child(6n){border-right:0}
.partner:nth-child(n+7){border-bottom:0}

/* quote / human statement */
.human-quote{padding:64px 0}
.human-quote p{font-size:clamp(26px,4vw,56px);font-weight:800;font-style:italic;line-height:1.04;letter-spacing:-.02em;text-wrap:balance;max-width:24ch}
.human-quote .accent{-webkit-text-stroke:2px var(--ink);color:transparent}

/* pill tags */
.tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.tag{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;border:1.6px solid var(--ink);border-radius:999px;padding:7px 14px;opacity:.8}

/* big statement */
.statement{padding:70px 0}
.statement p{font-size:clamp(28px,4.6vw,64px);font-weight:800;font-style:italic;text-transform:uppercase;line-height:1.02;letter-spacing:-.02em;text-wrap:balance}
.statement .accent{-webkit-text-stroke:2px var(--ink);color:transparent}

/* CTA band */
.cta-band{margin:30px 46px 0;border:2px solid var(--ink);border-radius:26px;padding:54px 48px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;position:relative;z-index:5}
.cta-band h2{font-size:clamp(30px,4.6vw,64px);font-style:italic;text-transform:uppercase;line-height:.9}
.cta-band .big-btn{cursor:none;background:var(--ink);color:var(--fill);border:0;border-radius:999px;padding:20px 34px;font-family:var(--font-display);font-weight:800;font-size:16px;letter-spacing:.04em;text-transform:uppercase;transition:transform .3s var(--ease)}
.cta-band .big-btn:hover{transform:translateY(-3px) scale(1.02)}

/* ---------- mobile navigation: bottom bar (menu + whatsapp) + bottom sheet ---------- */
.mbar{
  display:none;position:fixed;left:50%;bottom:calc(18px + env(safe-area-inset-bottom,0));transform:translateX(-50%);
  z-index:330;align-items:center;gap:10px;
}
.mtrigger{
  display:flex;align-items:center;gap:11px;background:var(--ink);color:var(--fill);
  border:0;border-radius:999px;padding:14px 26px;cursor:none;
  font-family:var(--font-display);font-weight:800;font-style:italic;text-transform:uppercase;font-size:15px;letter-spacing:.02em;
  box-shadow:0 12px 30px rgba(0,0,0,.4);
}
.mtrigger .bars{display:flex;flex-direction:column;gap:3.5px}
.mtrigger .bars span{display:block;width:18px;height:2.5px;background:var(--fill);border-radius:2px}
.mwa{
  flex:none;width:52px;height:52px;border-radius:50%;background:var(--ink);
  display:grid;place-items:center;text-decoration:none;cursor:none;
  box-shadow:0 12px 30px rgba(0,0,0,.4);
}
.mwa svg{width:24px;height:24px;fill:var(--fill)}

.mscrim{
  display:none;position:fixed;inset:0;z-index:325;background:rgba(0,0,0,.55);
  opacity:0;pointer-events:none;transition:opacity .4s var(--ease);
}
.mscrim.open{opacity:1;pointer-events:auto}

.mnav{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:340;
  background:#0c0c0c;border-radius:26px 26px 0 0;
  transform:translateY(100%);transition:transform .45s var(--ease);
  flex-direction:column;padding:12px 14px calc(20px + env(safe-area-inset-bottom,0));
  max-height:90vh;box-shadow:0 -22px 50px rgba(0,0,0,.45);
}
.mnav.open{transform:none}
.mnav-handle{width:46px;height:5px;border-radius:3px;background:rgba(255,255,255,.25);margin:6px auto 14px;flex:none}
.mnav-links{display:flex;flex-direction:column;gap:9px;overflow-y:auto}
.mnav-links a{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  text-decoration:none;border-radius:16px;padding:17px 22px;
  background:rgba(255,255,255,.07);color:#fff;
  font-weight:800;font-style:italic;text-transform:uppercase;font-size:23px;letter-spacing:-.01em;line-height:1;
  transition:background .2s,color .2s,transform .25s var(--ease);
}
.mnav-links a .idx{font-family:var(--font-mono);font-style:normal;font-weight:700;font-size:11px;opacity:.5;letter-spacing:.12em}
.mnav-links a[aria-current="page"]{background:var(--fill);color:var(--ink)}
.mnav-links a[aria-current="page"] .idx{opacity:.7}
.mnav-links a:active{background:var(--fill);color:var(--ink);transform:scale(.99)}
.mnav-foot{display:flex;flex-wrap:wrap;gap:8px 20px;justify-content:center;padding:16px 6px 4px;border-top:1px solid rgba(255,255,255,.12);margin-top:14px;flex:none}
.mnav-foot a{font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:rgba(255,255,255,.72);text-decoration:none;font-weight:700}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .mbar{display:flex}
  .mscrim{display:block}
  .mnav{display:flex}
  .nav .navlink{display:none}
  .nav .cta-pill{display:none}
  .nav .icon-btn{display:none}
  .site-head{padding:18px 26px;gap:12px}
  .site-head::after{left:26px;right:26px}
  .logo .gl{--logo-w:150px;--logo-h:25px}
  .nav{gap:12px}
  .wrap{padding:0 30px}
  .page-hero{padding:34px 0 72px}
  .section{padding:40px 0}
  .legal-rail{display:none}
  .foot-grid{grid-template-columns:1fr}
  .site-foot{margin:60px 30px 0;padding-bottom:96px}
  .grid.c2,.grid.c3{grid-template-columns:1fr}
  .sec-head{grid-template-columns:1fr;gap:10px}
  .row{grid-template-columns:46px 1fr;gap:12px}
  .row .r-meta{display:none}
  .cta-band{margin:30px 30px 0;padding:34px 28px;flex-direction:column;align-items:flex-start;gap:22px}
  .cta-band .big-btn{width:100%}
  .netmap{margin:0 14px}
  .netnode{width:clamp(28px,8vw,44px)}
  .netnodes{z-index:3}
  .netmap .netcap{left:clamp(12px,3vw,34px);bottom:clamp(10px,2.5vw,28px)}
  .netmap .netstat{right:clamp(12px,3vw,34px);top:clamp(10px,2.5vw,30px);gap:clamp(10px,3vw,30px)}
  .members{grid-template-columns:repeat(2,1fr)}
  /* partner grid: strict 2-col on mobile, no conflicting nth rules */
  .partners{grid-template-columns:repeat(2,1fr);border-radius:16px}
  .partner{
    border-right:2px solid var(--ink) !important;
    border-bottom:2px solid var(--ink) !important;
    background:#fff !important;
    aspect-ratio:1/1;
  }
  .partner:nth-child(2n)  {border-right:0 !important}
  .partner:nth-last-child(-n+2){border-bottom:0 !important}
  /* process map: shrink nodes so labels don't collide on small screens */
  .procnode .pn-ring{width:34px}
  .procnode .pn-sub{display:none}
  .procnode .pn-label{font-size:11px}
  .pm-title h3{font-size:26px}
}
