/* ============================================================
   BlackQC — Institutional / Interactive
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#080808;
  --bg-2:#0c0c0c;
  --bg-3:#111;
  --white:#efefec;
  --muted:rgba(239,239,236,.42);
  --muted2:rgba(239,239,236,.18);
  --muted3:rgba(239,239,236,.10);
  --line:rgba(239,239,236,.09);
  --line2:rgba(239,239,236,.16);
  --orange:#e8581a;
  --orange-soft:rgba(232,88,26,.14);
  --green:#7adfa0;
  --sans:"Geist","helvetica neue",helvetica,arial,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
html{scroll-behavior:auto}
body{background:var(--bg);color:var(--white);font-family:var(--sans);font-size:15px;line-height:1.6;font-weight:400;-webkit-font-smoothing:antialiased;letter-spacing:-.01em;overflow-x:hidden;cursor:none}

::selection{background:var(--orange);color:var(--bg)}

/* utility mono */
.mono{font-family:var(--mono);letter-spacing:0;font-feature-settings:"tnum","ss01"}

/* ============================================================
   CURSOR — with contextual action label
   ============================================================ */
.cursor{position:fixed;top:0;left:0;width:14px;height:14px;border:1px solid var(--white);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s cubic-bezier(.22,1,.36,1),height .3s cubic-bezier(.22,1,.36,1),border-color .3s,background .3s,opacity .3s;mix-blend-mode:difference}
.cursor-dot{position:fixed;top:0;left:0;width:3px;height:3px;background:var(--orange);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
.cursor-label{position:fixed;top:0;left:0;pointer-events:none;z-index:9998;font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--bg);background:var(--orange);padding:5px 9px 4px;border-radius:1px;transform:translate(20px,-50%) scale(.85);opacity:0;transition:opacity .25s,transform .25s cubic-bezier(.22,1,.36,1);white-space:nowrap}
.cursor-label.show{opacity:1;transform:translate(20px,-50%) scale(1)}
.cursor.hover{width:54px;height:54px;border-color:var(--orange);background:rgba(232,88,26,.06);mix-blend-mode:normal}
.cursor.text{width:3px;height:32px;border-radius:1px;border-color:var(--orange);background:var(--orange);mix-blend-mode:normal}
.cursor.hidden{opacity:0}

/* ============================================================
   LOADER
   ============================================================ */
.loader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:18px}
.loader-mark{font-family:var(--mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);display:flex;gap:14px;align-items:center}
.loader-mark .dot{width:4px;height:4px;background:var(--orange);border-radius:50%;animation:lp 1s ease-in-out infinite alternate}
@keyframes lp{from{opacity:.2}to{opacity:1}}
.loader-bar{width:160px;height:1px;background:var(--line);position:relative;overflow:hidden}
.loader-fill{position:absolute;left:0;top:0;height:100%;width:0;background:var(--orange);transition:width .25s ease}
.loader-text{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.loader-pct{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--muted2)}
.loader.done{opacity:0;pointer-events:none;transition:opacity .5s .15s ease}

/* ============================================================
   NOISE & AMBIENT
   ============================================================ */
.noise{position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:128px}
.grain{position:fixed;inset:0;pointer-events:none;z-index:8;background:
  repeating-linear-gradient(to bottom,transparent 0 3px,rgba(255,255,255,.012) 3px 4px);
  mix-blend-mode:overlay;opacity:.6}

/* ============================================================
   HEADER — top HUD strip
   ============================================================ */
header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:22px 32px;pointer-events:none;mix-blend-mode:difference}
.logo{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--white);pointer-events:all;text-decoration:none;position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:10px}
.logo-mark{width:8px;height:8px;border:1px solid var(--orange);position:relative}
.logo-mark::after{content:'';position:absolute;inset:2px;background:var(--orange);animation:blink 2.4s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.logo-text{display:inline-block;overflow:hidden;position:relative}
.logo-text .lt-inner{display:inline-block;transition:transform .45s cubic-bezier(.7,0,.3,1)}
.logo:hover .lt-inner{transform:translateY(-100%)}
.logo-text .lt-clone{position:absolute;top:100%;left:0;color:var(--orange)}

.hdr-meta{display:flex;gap:28px;pointer-events:all;align-items:center}
.hdr-cell{display:flex;flex-direction:column;gap:2px;min-width:0}
.hdr-cell-l{font-family:var(--mono);font-size:8px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted2)}
.hdr-cell-v{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--white);font-feature-settings:"tnum"}
.hdr-cell-v .pulse{display:inline-block;width:5px;height:5px;background:var(--green);border-radius:50%;margin-right:6px;vertical-align:1px;box-shadow:0 0 8px var(--green);animation:blink 1.6s ease-in-out infinite}
.hdr-right-link{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--white);text-decoration:none;border-bottom:1px solid var(--muted2);padding-bottom:2px;transition:border-color .3s,color .3s;pointer-events:all}
.hdr-right-link:hover{border-color:var(--orange);color:var(--orange)}

/* ============================================================
   SECTION PROGRESS RAIL (right side)
   ============================================================ */
.rail{position:fixed;right:22px;top:50%;transform:translateY(-50%);z-index:90;display:flex;flex-direction:column;gap:0;pointer-events:none}
.rail-item{display:flex;align-items:center;gap:10px;padding:8px 0;pointer-events:all;cursor:none;text-align:right;justify-content:flex-end}
.rail-line{width:14px;height:1px;background:var(--muted2);transition:background .3s,width .3s}
.rail-item.active .rail-line{background:var(--orange);width:28px}
.rail-item:hover .rail-line{background:var(--white);width:22px}
.rail-num{font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--muted2);min-width:18px;text-align:left;order:-1;transition:color .3s}
.rail-item.active .rail-num{color:var(--orange)}
.rail-label{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);opacity:0;transform:translateX(8px);transition:opacity .3s,transform .3s;white-space:nowrap;position:absolute;right:48px;background:var(--bg);padding:2px 6px}
.rail-item:hover .rail-label,.rail-item.active .rail-label{opacity:1;transform:translateX(0)}
.rail-item.active .rail-label{color:var(--white)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;height:100svh;min-height:640px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden}
#heroCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}
.hero-vignette{position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse 76% 76% at 50% 50%, transparent 12%, rgba(8,8,8,.55) 60%, rgba(8,8,8,.96) 100%)}
.hero-scanline{position:absolute;left:0;right:0;height:1px;top:0;z-index:1;pointer-events:none;background:linear-gradient(to right,transparent,rgba(232,88,26,.45),transparent);box-shadow:0 0 22px rgba(232,88,26,.25);animation:scan 7s linear infinite;opacity:.6}
@keyframes scan{0%{top:-2%}100%{top:102%}}

/* Hero corner brackets */
.hero-bracket{position:absolute;width:34px;height:34px;border:1px solid var(--muted2);z-index:2;pointer-events:none}
.hero-bracket.tl{top:80px;left:32px;border-right:none;border-bottom:none}
.hero-bracket.tr{top:80px;right:32px;border-left:none;border-bottom:none}
.hero-bracket.bl{bottom:80px;left:32px;border-right:none;border-top:none}
.hero-bracket.br{bottom:80px;right:32px;border-left:none;border-top:none}

.hero-inner{position:relative;z-index:2;max-width:880px;padding:0 28px}
.hero-pre{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:30px;opacity:0;transform:translateY(8px)}
.hero-pre .pulse{width:6px;height:6px;background:var(--orange);border-radius:50%;animation:blink 1.6s ease-in-out infinite;box-shadow:0 0 10px var(--orange)}
.hero-pre.visible{animation:fadeUp .8s .15s cubic-bezier(.22,1,.36,1) forwards}

.hero h1{font-size:clamp(48px,9.5vw,128px);font-weight:300;line-height:.93;letter-spacing:-.045em;color:var(--white);margin-bottom:26px}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .char{display:inline-block;transform:translateY(110%);opacity:0;transition:transform .85s cubic-bezier(.22,1,.36,1),opacity .5s ease;will-change:transform}
.hero h1 .char.visible{transform:translateY(0);opacity:1}
.hero h1 .ital{font-style:italic;font-weight:300;color:var(--orange)}

.hero-sub{font-size:clamp(14px,1.55vw,16px);font-weight:400;color:var(--muted);max-width:460px;margin:0 auto 38px;line-height:1.75;letter-spacing:.005em;opacity:0;transform:translateY(16px)}
.hero-sub.visible{animation:fadeUp .8s .5s cubic-bezier(.22,1,.36,1) forwards}
@keyframes fadeUp{to{opacity:1;transform:none}}

.hero-ctas{display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center;opacity:0;transform:translateY(16px)}
.hero-ctas.visible{animation:fadeUp .8s .65s cubic-bezier(.22,1,.36,1) forwards}

.btn{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--white);text-decoration:none;border:1px solid var(--line2);padding:15px 28px;cursor:none;background:transparent;font-family:var(--sans);transition:border-color .3s,background .3s,transform .15s ease;position:relative;overflow:hidden}
.btn .btn-bg{position:absolute;inset:0;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .55s cubic-bezier(.65,0,.35,1)}
.btn:hover .btn-bg{transform:scaleX(1)}
.btn .btn-text{position:relative;z-index:1;transition:color .3s}
.btn:hover .btn-text{color:var(--bg)}
.btn .btn-arrow{position:relative;z-index:1;transition:transform .3s,color .3s;display:inline-flex}
.btn:hover .btn-arrow{transform:translateX(4px);color:var(--bg)}
.btn:hover{border-color:var(--orange)}

.btn-ghost{border-color:var(--muted3)}
.btn-ghost .btn-bg{background:rgba(239,239,236,.06)}
.btn-ghost:hover{border-color:var(--white)}
.btn-ghost:hover .btn-text,.btn-ghost:hover .btn-arrow{color:var(--white)}

/* Hero readouts (bottom corners) */
.hero-readout{position:absolute;z-index:2;font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;gap:8px;pointer-events:none}
.hero-readout.left{bottom:96px;left:46px;text-align:left;align-items:flex-start}
.hero-readout.right{bottom:96px;right:46px;text-align:right;align-items:flex-end}
.ro-row{display:flex;gap:10px;align-items:center}
.ro-l{color:var(--muted2)}
.ro-v{color:var(--white);font-feature-settings:"tnum";min-width:56px;text-align:right}
.hero-readout.left .ro-v{text-align:left}

.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}
.hero-scroll span{font-family:var(--mono);font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted2)}
.scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,var(--muted2),transparent);animation:sd 2.2s ease-in-out infinite}
@keyframes sd{0%{opacity:0;transform:scaleY(0);transform-origin:top}45%{opacity:1;transform:scaleY(1)}100%{opacity:0;transform:scaleY(1);transform-origin:bottom}}

/* ============================================================
   GLOBAL LAYOUT
   ============================================================ */
main{display:flex;flex-direction:column;align-items:center;padding:0 28px 140px}

/* Anchor / section index labels */
.idx{display:inline-flex;align-items:baseline;gap:14px;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:24px;opacity:0;transform:translateY(8px)}
.idx.in{animation:fadeUp .6s cubic-bezier(.22,1,.36,1) forwards}
.idx::before{content:'';width:24px;height:1px;background:var(--orange)}
.idx-n{color:var(--orange);font-weight:500}

/* Animated divider */
.divider{width:100%;max-width:1200px;height:1px;position:relative;margin:80px auto;overflow:visible}
.divider::before{content:'';position:absolute;top:0;left:0;width:100%;height:1px;background:var(--line);transform:scaleX(0);transform-origin:left;transition:transform 1.2s cubic-bezier(.7,0,.3,1)}
.divider.in::before{transform:scaleX(1)}
.divider-mark{position:absolute;top:-3px;left:50%;width:7px;height:7px;border:1px solid var(--orange);transform:translateX(-50%) rotate(45deg);opacity:0;transition:opacity .4s .8s}
.divider.in .divider-mark{opacity:1}
.divider-mark::after{content:'';position:absolute;inset:1px;background:var(--orange);opacity:.6}

/* ============================================================
   MANIFESTO — big oversized line reveal
   ============================================================ */
.manifesto{max-width:1200px;width:100%;margin:60px auto;padding:0 28px;text-align:left}
.manifesto-title{font-size:clamp(34px,5.5vw,82px);font-weight:300;letter-spacing:-.035em;line-height:1.05;color:var(--muted2)}
.manifesto-title .line{display:block;overflow:hidden;position:relative}
.manifesto-title .line-inner{display:block;color:var(--muted2);transition:color .8s ease}
.manifesto-title .line.lit .line-inner{color:var(--white)}
.manifesto-title .o{color:var(--orange)}
.manifesto-foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:48px;flex-wrap:wrap;gap:24px}
.manifesto-foot-l{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.manifesto-sig{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--muted2);text-align:right}
.manifesto-sig strong{color:var(--white);font-weight:500;display:block;letter-spacing:.14em}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.sec{max-width:680px;margin:0 auto;width:100%;text-align:center;padding:0 28px}
.sec-head{font-size:clamp(28px,4.4vw,52px);font-weight:300;letter-spacing:-.03em;line-height:1.08;color:var(--white);margin-bottom:18px}
.sec-head .o{color:var(--orange);font-style:italic;font-weight:300}
.sec-head .char{display:inline-block;opacity:0;transform:translateY(40%) rotate(2deg);transition:opacity .55s ease,transform .65s cubic-bezier(.22,1,.36,1)}
.sec-head .char.visible{opacity:1;transform:none}
.sec-sub{font-size:14px;font-weight:400;color:var(--muted);line-height:1.75;letter-spacing:.005em;opacity:0;transform:translateY(12px);max-width:560px;margin:0 auto}
.sec-sub.in{animation:fadeUp .7s .2s cubic-bezier(.22,1,.36,1) forwards}

/* ============================================================
   APPROACH — interactive method diagram
   ============================================================ */
.method{max-width:1100px;margin:60px auto 0;width:100%;padding:0 28px;position:relative}
.method-stage{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.005));opacity:0;transform:translateY(20px)}
.method.in .method-stage{animation:fadeUp .8s cubic-bezier(.22,1,.36,1) forwards}
.method-nav{padding:32px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:0}
.method-node{display:flex;align-items:center;gap:18px;padding:18px 0;cursor:none;border-bottom:1px solid var(--line);position:relative;transition:padding .3s}
.method-node:last-child{border-bottom:none}
.method-node-marker{flex-shrink:0;width:22px;height:22px;border:1px solid var(--muted2);border-radius:50%;position:relative;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:9px;color:var(--muted2);transition:border-color .3s,color .3s,background .3s}
.method-node.active .method-node-marker{border-color:var(--orange);color:var(--orange);background:var(--orange-soft)}
.method-node-marker::after{content:'';position:absolute;left:50%;top:100%;width:1px;height:18px;background:var(--line);transform:translateX(-50%)}
.method-node:last-child .method-node-marker::after{display:none}
.method-node-title{font-size:15px;font-weight:500;letter-spacing:-.01em;color:var(--muted);transition:color .3s,transform .3s;flex:1;text-align:left}
.method-node.active .method-node-title{color:var(--white)}
.method-node:hover .method-node-title{color:var(--white);transform:translateX(4px)}
.method-node-arrow{font-family:var(--mono);font-size:10px;color:var(--muted2);opacity:0;transform:translateX(-6px);transition:opacity .3s,transform .3s}
.method-node.active .method-node-arrow{opacity:1;transform:translateX(0);color:var(--orange)}

.method-detail{padding:36px;display:flex;flex-direction:column;gap:18px;min-height:340px;position:relative}
.method-detail-meta{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted2);border-bottom:1px solid var(--line);padding-bottom:14px}
.method-detail-step{color:var(--orange)}
.method-detail-title{font-size:clamp(20px,2.4vw,30px);font-weight:300;letter-spacing:-.02em;line-height:1.15;color:var(--white)}
.method-detail-body{font-size:14px;line-height:1.75;color:var(--muted)}
.method-detail-list{list-style:none;display:flex;flex-direction:column;gap:8px;padding-top:8px}
.method-detail-list li{font-size:12px;color:var(--muted);display:flex;gap:12px;align-items:baseline;line-height:1.55}
.method-detail-list li::before{content:'';width:14px;height:1px;background:var(--orange);flex-shrink:0;transform:translateY(-3px)}
.method-fade{animation:methodFade .5s cubic-bezier(.22,1,.36,1)}
@keyframes methodFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ============================================================
   SERVICES — accordion
   ============================================================ */
.svc-list{max-width:920px;width:100%;margin:60px auto 0;text-align:left;border-top:1px solid var(--line);opacity:0;transform:translateY(20px)}
.svc-list.in{animation:fadeUp .7s cubic-bezier(.22,1,.36,1) forwards}
.svc{border-bottom:1px solid var(--line);position:relative;overflow:hidden;cursor:none}
.svc-head{padding:28px 8px;display:grid;grid-template-columns:64px 1fr 220px 40px;gap:24px;align-items:center;transition:background .35s;position:relative}
.svc-head::before{content:'';position:absolute;left:0;top:0;width:2px;height:100%;background:var(--orange);transform:scaleY(0);transform-origin:top;transition:transform .45s cubic-bezier(.65,0,.35,1)}
.svc.open .svc-head::before,.svc:hover .svc-head::before{transform:scaleY(1)}
.svc:hover .svc-head{background:rgba(232,88,26,.025)}
.svc-n{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--muted2);transition:color .3s}
.svc.open .svc-n,.svc:hover .svc-n{color:var(--orange)}
.svc-title{font-size:clamp(20px,2.6vw,32px);font-weight:300;letter-spacing:-.02em;color:var(--white);line-height:1.1;transition:transform .35s}
.svc:hover .svc-title{transform:translateX(8px)}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;justify-self:end}
.svc-tag{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line2);padding:5px 9px;border-radius:1px;white-space:nowrap}
.svc-toggle{width:32px;height:32px;border:1px solid var(--line2);border-radius:50%;display:flex;align-items:center;justify-content:center;justify-self:end;position:relative;transition:border-color .3s,background .3s}
.svc-toggle::before,.svc-toggle::after{content:'';position:absolute;background:var(--white);transition:transform .35s cubic-bezier(.7,0,.3,1),background .3s}
.svc-toggle::before{width:11px;height:1px}
.svc-toggle::after{width:1px;height:11px}
.svc.open .svc-toggle{border-color:var(--orange);background:var(--orange-soft)}
.svc.open .svc-toggle::after{transform:rotate(90deg);opacity:0}
.svc.open .svc-toggle::before{background:var(--orange)}
.svc-body{max-height:0;overflow:hidden;transition:max-height .55s cubic-bezier(.7,0,.3,1)}
.svc.open .svc-body{max-height:600px}
.svc-body-inner{padding:8px 8px 36px;display:grid;grid-template-columns:1fr 1fr;gap:48px}
.svc-desc{font-size:14px;color:var(--muted);line-height:1.75;letter-spacing:.005em}
.svc-deliver-l{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted2);margin-bottom:14px;display:block}
.svc-deliver{list-style:none;display:flex;flex-direction:column;gap:10px}
.svc-deliver li{font-size:13px;color:var(--white);display:flex;gap:14px;align-items:baseline}
.svc-deliver li .di{font-family:var(--mono);font-size:9px;color:var(--orange);min-width:18px}
.svc-foot{grid-column:1 / -1;display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--line);margin-top:8px;gap:20px;flex-wrap:wrap}
.svc-foot-cell{display:flex;flex-direction:column;gap:4px}
.svc-foot-l{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted2)}
.svc-foot-v{font-family:var(--mono);font-size:12px;color:var(--white)}

/* ============================================================
   STATS — counters + sparklines
   ============================================================ */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);max-width:960px;width:100%;margin:60px auto 0;border:1px solid var(--line);opacity:0;transform:translateY(20px)}
.stats-row.in{animation:fadeUp .7s cubic-bezier(.22,1,.36,1) forwards}
.st{padding:36px 20px 28px;text-align:left;border-right:1px solid var(--line);transition:background .3s;min-width:0;cursor:none;position:relative;overflow:hidden}
.st:last-child{border-right:none}
.st::before{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .55s cubic-bezier(.7,0,.3,1)}
.st:hover::before{transform:scaleX(1)}
.st-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}
.st-n{font-family:var(--mono);font-size:9px;letter-spacing:.22em;color:var(--muted2)}
.st-trend{font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--green)}
.st-trend.down{color:var(--orange)}
.st-v{font-size:clamp(28px,3.6vw,46px);font-weight:300;letter-spacing:-.035em;color:var(--white);line-height:1;font-variant-numeric:tabular-nums;margin-bottom:6px}
.st-v .sfx{color:var(--orange);font-weight:300}
.st-l{font-size:11px;font-weight:400;color:var(--muted);letter-spacing:.02em;line-height:1.5;margin-bottom:18px}
.st-spark{height:32px;width:100%;display:block;opacity:.85}

/* ============================================================
   INSIGHTS — hover preview thumbnails
   ============================================================ */
.ins-list{max-width:920px;width:100%;margin:60px auto 0;text-align:left;border-top:1px solid var(--line);opacity:0;transform:translateY(20px);position:relative}
.ins-list.in{animation:fadeUp .7s cubic-bezier(.22,1,.36,1) forwards}
.ins{display:grid;grid-template-columns:64px 1fr 120px 140px 40px;gap:24px;align-items:center;padding:24px 8px;border-bottom:1px solid var(--line);transition:background .3s,padding .3s;cursor:none;position:relative}
.ins::before{content:'';position:absolute;left:0;top:0;width:2px;height:100%;background:var(--orange);transform:scaleY(0);transform-origin:top;transition:transform .4s}
.ins:hover::before{transform:scaleY(1)}
.ins:hover{background:rgba(232,88,26,.025)}
.ins-n{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--muted2);transition:color .3s}
.ins:hover .ins-n{color:var(--orange)}
.ins-title{font-size:clamp(15px,1.7vw,20px);font-weight:400;color:var(--white);letter-spacing:-.01em;line-height:1.3;transition:transform .3s}
.ins:hover .ins-title{transform:translateX(6px)}
.ins-tag{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line2);padding:5px 9px;text-align:center;justify-self:start}
.ins-date{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--muted);font-feature-settings:"tnum"}
.ins-arrow{font-family:var(--mono);font-size:14px;color:var(--muted2);justify-self:end;transition:transform .3s,color .3s}
.ins:hover .ins-arrow{transform:translateX(6px);color:var(--orange)}

/* Floating image preview */
.ins-preview{position:fixed;top:0;left:0;width:260px;height:340px;pointer-events:none;z-index:120;opacity:0;--tx:-9999px;--ty:-9999px;--sc:.92;transform:translate(var(--tx),var(--ty)) translate(-50%,-50%) scale(var(--sc));transition:opacity .35s,--sc .35s cubic-bezier(.22,1,.36,1);background:var(--bg-3);border:1px solid var(--line2);overflow:hidden}
.ins-preview.show{opacity:1;--sc:1}
.ins-preview-inner{position:absolute;inset:0;background:
  repeating-linear-gradient(135deg,rgba(232,88,26,.05) 0 6px,transparent 6px 14px),
  linear-gradient(180deg,#1a1208,#0a0805)}
.ins-preview-meta{position:absolute;left:14px;right:14px;bottom:14px;font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;gap:6px}
.ins-preview-meta .pt{color:var(--white);font-size:11px;letter-spacing:.06em;text-transform:none;font-family:var(--sans);font-weight:400;line-height:1.3}
.ins-preview-corner{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:9px;letter-spacing:.22em;color:var(--orange);display:flex;gap:8px;align-items:center}
.ins-preview-corner::before{content:'';width:6px;height:6px;background:var(--orange);border-radius:50%;animation:blink 1.4s ease-in-out infinite}

/* ============================================================
   CASE INDEX — filterable horizontal scroll
   ============================================================ */
.cases-wrap{max-width:1200px;width:100%;margin:60px auto 0;padding:0 28px;opacity:0;transform:translateY(20px)}
.cases-wrap.in{animation:fadeUp .7s cubic-bezier(.22,1,.36,1) forwards}
.cases-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:28px;flex-wrap:wrap;gap:20px;border-bottom:1px solid var(--line);padding-bottom:18px}
.cases-filter{display:flex;gap:6px;flex-wrap:wrap}
.cf-btn{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;background:transparent;border:1px solid var(--line2);color:var(--muted);padding:7px 12px;cursor:none;transition:all .3s}
.cf-btn:hover{color:var(--white);border-color:var(--muted)}
.cf-btn.active{color:var(--orange);border-color:var(--orange);background:var(--orange-soft)}
.cases-meta{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.cases-meta .v{color:var(--white);font-feature-settings:"tnum"}

.cases-track{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1px;background:var(--line)}
.case{background:var(--bg);padding:24px 22px;display:flex;flex-direction:column;gap:14px;cursor:none;transition:background .35s,transform .35s;position:relative;min-height:280px;border:1px solid transparent}
.case:hover{background:#0e0e0e}
.case-row{display:flex;justify-content:space-between;align-items:flex-start;font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted2)}
.case-row .v{color:var(--white)}
.case-row .dot{display:inline-block;width:5px;height:5px;background:var(--green);border-radius:50%;margin-right:6px;vertical-align:1px;box-shadow:0 0 6px var(--green)}
.case-row .dot.amber{background:var(--orange);box-shadow:0 0 6px var(--orange)}
.case-title{font-size:17px;font-weight:400;color:var(--white);letter-spacing:-.01em;line-height:1.3;margin-top:auto}
.case-body{font-size:12px;color:var(--muted);line-height:1.6}
.case-foot{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--line);font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.case-foot .arr{color:var(--orange);font-size:12px}
.case.hidden{display:none}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee-wrap{width:100%;overflow:hidden;padding:50px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:80px 0;position:relative}
.marquee-track{display:flex;gap:64px;animation:marquee 32s linear infinite;width:max-content}
.marquee-track span{font-size:clamp(38px,6.6vw,82px);font-weight:300;letter-spacing:-.035em;color:rgba(232,88,26,.13);white-space:nowrap;text-transform:uppercase;font-style:italic}
.marquee-track .mq-dot{color:rgba(232,88,26,.5);font-style:normal}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-block{max-width:780px;width:100%;margin:60px auto 0;border:1px solid var(--line);opacity:0;transform:translateY(20px);display:grid;grid-template-columns:1fr 1fr 1fr}
.contact-block.in{animation:fadeUp .7s cubic-bezier(.22,1,.36,1) forwards}
.cr{display:flex;flex-direction:column;gap:14px;padding:30px 28px;border-right:1px solid var(--line);transition:background .3s;position:relative;cursor:none;text-align:left}
.cr:last-child{border-right:none}
.cr::before{content:'';position:absolute;left:0;top:0;width:100%;height:2px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.7,0,.3,1)}
.cr:hover::before{transform:scaleX(1)}
.cr:hover{background:rgba(232,88,26,.025)}
.cr-label{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted2)}
.cr a{font-size:14px;font-weight:400;color:var(--white);text-decoration:none;border-bottom:1px solid transparent;padding-bottom:1px;transition:border-color .3s,color .3s;word-break:break-all;cursor:none;letter-spacing:-.005em}
.cr a:hover{border-color:var(--orange);color:var(--orange)}
.cr-sub{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

.cta-bottom{margin-top:48px;opacity:0;transform:translateY(14px)}
.cta-bottom.in{animation:fadeUp .7s cubic-bezier(.22,1,.36,1) forwards}

.tagline{margin:80px auto 0;font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--muted2);text-align:center;opacity:0;transform:translateY(8px);display:flex;gap:18px;align-items:center;justify-content:center}
.tagline.in{animation:fadeUp .7s cubic-bezier(.22,1,.36,1) forwards}
.tagline::before,.tagline::after{content:'';width:32px;height:1px;background:var(--line2)}

/* ============================================================
   MODAL
   ============================================================ */
.modal-bg{display:none;position:fixed;inset:0;z-index:200;background:rgba(8,8,8,0);backdrop-filter:blur(0px);align-items:center;justify-content:center;padding:24px;transition:background .4s,backdrop-filter .4s}
.modal-bg.open{display:flex;background:rgba(8,8,8,.86);backdrop-filter:blur(14px)}
.modal{width:100%;max-width:460px;background:var(--bg-3);border:1px solid var(--line2);padding:40px 36px 36px;position:relative;opacity:0;transform:translateY(24px) scale(.97);transition:opacity .4s .1s,transform .4s .1s cubic-bezier(.22,1,.36,1)}
.modal::before{content:'';position:absolute;top:-1px;left:-1px;width:24px;height:1px;background:var(--orange)}
.modal::after{content:'';position:absolute;top:-1px;left:-1px;width:1px;height:24px;background:var(--orange)}
.modal-bg.open .modal{opacity:1;transform:none}
.modal-close{position:absolute;top:20px;right:20px;width:32px;height:32px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:none;font-size:16px;display:flex;align-items:center;justify-content:center;transition:border-color .3s,color .3s,transform .3s;font-family:var(--sans)}
.modal-close:hover{border-color:var(--orange);color:var(--white);transform:rotate(90deg)}
.modal-label{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:20px;display:flex;align-items:center;gap:12px}
.modal-label::after{content:'';flex:1;height:1px;background:var(--line)}
.modal h2{font-size:26px;font-weight:300;letter-spacing:-.03em;color:var(--white);margin-bottom:28px;line-height:1.15}
.modal h2 .o{color:var(--orange);font-style:italic}
.mfield{margin-bottom:22px;position:relative}
.mfield label{display:block;font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--muted2);margin-bottom:8px;transition:color .3s}
.mfield input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line2);color:var(--white);font-family:var(--sans);font-size:15px;font-weight:400;padding:8px 0;outline:none;letter-spacing:-.01em;transition:border-color .3s;cursor:none}
.mfield input:focus{border-color:var(--orange)}
.mfield input::placeholder{color:rgba(239,239,236,.2)}
.input-line{position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.22,1,.36,1)}
.mfield input:focus + .input-line{transform:scaleX(1)}
.modal-submit{margin-top:24px;width:100%;background:transparent;border:1px solid var(--line2);color:var(--white);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;padding:15px;cursor:none;transition:border-color .3s;position:relative;overflow:hidden}
.modal-submit .sub-bg{position:absolute;inset:0;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.7,0,.3,1)}
.modal-submit:hover .sub-bg{transform:scaleX(1)}
.modal-submit .sub-text{position:relative;z-index:1;transition:color .3s}
.modal-submit:hover .sub-text{color:var(--bg)}
.modal-submit:hover{border-color:var(--orange)}
.modal-submit:disabled{opacity:.4;cursor:default}
.modal-foot{margin-top:18px;font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted2);text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}
.modal-foot::before{content:'';width:4px;height:4px;background:var(--green);border-radius:50%}
.modal-success{display:none;text-align:left;padding:8px 0}
.modal-success p{font-size:15px;font-weight:300;color:var(--muted);line-height:1.7}
.modal-success strong{color:var(--white);font-weight:500;font-size:18px;display:block;margin-bottom:8px}
.hp-field{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

/* ============================================================
   COOKIE & FOOTER BAR
   ============================================================ */
.cookie{position:fixed;bottom:0;left:0;right:0;z-index:150;padding:0 32px 56px;pointer-events:none;display:flex;justify-content:center}
.cookie-inner{pointer-events:all;max-width:680px;width:100%;background:var(--bg-3);border:1px solid var(--line2);padding:20px 24px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;transform:translateY(120%);transition:transform .5s cubic-bezier(.22,1,.36,1)}
.cookie-inner.visible{transform:translateY(0)}
.cookie-text{flex:1;min-width:200px;font-family:var(--mono);font-size:10px;font-weight:400;color:var(--muted);line-height:1.7;letter-spacing:.04em}
.cookie-text a{color:rgba(239,239,236,.6);text-decoration:none;border-bottom:1px solid rgba(239,239,236,.2);transition:color .25s;cursor:none}
.cookie-text a:hover{color:var(--white)}
.cookie-btns{display:flex;gap:8px;flex-shrink:0}
.cookie-btn{font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;padding:11px 18px;cursor:none;border:1px solid var(--line2);background:transparent;color:var(--muted);transition:border-color .2s,color .2s,background .2s;white-space:nowrap}
.cookie-btn:hover{border-color:rgba(239,239,236,.36);color:var(--white)}
.cookie-btn.accept{border-color:var(--orange);color:var(--orange)}
.cookie-btn.accept:hover{background:var(--orange);color:var(--bg)}

.fbar{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:18px 32px;pointer-events:none;z-index:50;gap:20px;flex-wrap:wrap}
.fbar-cell{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:rgba(239,239,236,.32);pointer-events:all;display:flex;gap:10px;align-items:center}
.fbar-cell.right{margin-left:auto}
.fbar-cell .v{color:rgba(239,239,236,.65)}
.fbar-cell a{color:inherit;text-decoration:none;transition:color .25s;cursor:none}
.fbar-cell a:hover{color:var(--white)}
.fbar-clock{display:inline-flex;gap:6px;align-items:center}
.fbar-clock .pulse{width:5px;height:5px;background:var(--green);border-radius:50%;box-shadow:0 0 6px var(--green);animation:blink 1.5s ease-in-out infinite}

/* ============================================================
   MOBILE
   ============================================================ */
@media(max-width:900px){
  .stats-row{grid-template-columns:1fr 1fr}
  .st:nth-child(odd){border-right:1px solid var(--line)}
  .st:nth-child(2){border-right:none}
  .st:nth-child(1),.st:nth-child(2){border-bottom:1px solid var(--line)}
  .contact-block{grid-template-columns:1fr}
  .cr{border-right:none;border-bottom:1px solid var(--line)}
  .cr:last-child{border-bottom:none}
  .method-stage{grid-template-columns:1fr}
  .method-nav{border-right:none;border-bottom:1px solid var(--line)}
  .svc-head{grid-template-columns:48px 1fr 40px}
  .svc-tags{display:none}
  .svc-body-inner{grid-template-columns:1fr;gap:28px}
  .ins{grid-template-columns:48px 1fr 100px 30px}
  .ins-date{display:none}
}
@media(max-width:700px){
  body{cursor:auto}
  .cursor,.cursor-dot,.cursor-label,.rail,.hero-bracket,.hero-readout,.ins-preview{display:none!important}
  *{cursor:auto!important}
  header{padding:18px 20px;gap:14px;flex-wrap:wrap}
  .hdr-meta{gap:14px}
  .hdr-cell:nth-child(2){display:none}
  .cookie{padding:0 16px 64px}
  .cookie-inner{padding:16px 18px;gap:14px}
  .cookie-btns{width:100%;justify-content:flex-end}
  main{padding:0 16px 100px}
  .divider{margin:60px auto}
  .manifesto{padding:0 16px}
  .sec{padding:0 16px}
  .method,.cases-wrap{padding:0 16px}
  .svc-head{padding:22px 4px;gap:14px}
  .ins{grid-template-columns:40px 1fr 30px;padding:20px 4px;gap:14px}
  .ins-tag,.ins-date{display:none}
  .stats-row{grid-template-columns:1fr 1fr;max-width:100%}
  .modal{padding:32px 24px 28px}
  .modal h2{font-size:22px}
  .sec-head{font-size:clamp(26px,7vw,38px)}
  .marquee-wrap{margin:54px 0;padding:36px 0}
  .fbar{padding:14px 16px;font-size:8px}
  .fbar-cell:nth-child(2){display:none}
}
@media(max-width:400px){
  .hero h1{font-size:clamp(38px,12vw,56px)}
  .hero-pre{font-size:9px;letter-spacing:.18em}
}
