/* ============================================================
   FXXKING.DE v3.0 — SYSTEM OVERRIDE
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#05060a;
  --bg2:#0a0c12;
  --ink:#eef7f1;
  --dim:#76837c;
  --line:rgba(255,255,255,.10);
  --line-soft:rgba(255,255,255,.06);
  --acid:#00ff9f;
  --cyan:#00e5ff;
  --mag:#ff2bd6;
  --amber:#ffb300;
  --violet:#b44dff;
  --glass:rgba(11,15,14,.55);
  --display:'Anton',Impact,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --body:'Inter',system-ui,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --pad:6vw;
}

html{scrollbar-color:#1b241f var(--bg)}
html.lock{overflow:hidden}
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  font-size:16px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body.no-gl{
  background:
    radial-gradient(ellipse 90% 60% at 50% -10%,rgba(0,255,159,.07),transparent),
    radial-gradient(ellipse 70% 50% at 80% 70%,rgba(255,43,214,.05),transparent),
    var(--bg);
}
::selection{background:var(--acid);color:#000}
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:#1b241f;border:2px solid var(--bg);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:var(--acid)}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.mono{font-family:var(--mono);font-weight:400;letter-spacing:.06em}
.dim{color:var(--dim)}
:focus-visible{outline:1px dashed var(--acid);outline-offset:3px}

/* desktop: hide native cursor in favor of custom */
@media (hover:hover) and (pointer:fine){
  html.cursor-on, html.cursor-on a, html.cursor-on button{cursor:none}
}

/* ============ FIXED WEBGL STAGE ============ */
#gl{
  position:fixed;inset:0;width:100%;height:100%;
  z-index:0;pointer-events:none;
}

/* ============ OVERLAYS ============ */
#flash{
  position:fixed;inset:0;z-index:90;pointer-events:none;opacity:0;
  background:
    linear-gradient(90deg,rgba(255,43,214,.16),transparent 30%,transparent 70%,rgba(0,229,255,.16)),
    rgba(255,255,255,.05);
  mix-blend-mode:screen;
}
#flash.on{animation:flashglitch .22s steps(3) both}
@keyframes flashglitch{
  0%{opacity:1;transform:translateX(-8px)}
  50%{opacity:.6;transform:translateX(10px) scaleY(1.02)}
  100%{opacity:0;transform:none}
}
#noise{
  position:fixed;inset:-100px;z-index:80;pointer-events:none;
  opacity:.06;
}
html.booted #noise{animation:noisejump .45s steps(4) infinite}
@keyframes noisejump{
  0%{transform:translate(0,0)}
  25%{transform:translate(-40px,30px)}
  50%{transform:translate(30px,-50px)}
  75%{transform:translate(-20px,-30px)}
  100%{transform:translate(0,0)}
}

/* ============ HUD ============ */
.hud{position:fixed;inset:0;z-index:60;pointer-events:none}
.hud-corner{position:absolute;width:18px;height:18px;border:1px solid rgba(255,255,255,.22)}
.hud-corner.tl{top:14px;left:14px;border-right:0;border-bottom:0}
.hud-corner.tr{top:14px;right:14px;border-left:0;border-bottom:0}
.hud-corner.bl{bottom:14px;left:14px;border-right:0;border-top:0}
.hud-corner.br{bottom:14px;right:14px;border-left:0;border-top:0}
.hud-section{
  position:absolute;left:28px;bottom:26px;
  font-size:11px;color:var(--acid);letter-spacing:.14em;
}
.hud-section #hud-name{color:var(--ink)}
.hud-coords{
  position:absolute;right:28px;bottom:26px;
  font-size:10px;color:var(--dim);letter-spacing:.14em;
}
.hud-progress{
  position:absolute;top:0;left:0;right:0;height:2px;
  background:rgba(255,255,255,.05);
}
.hud-progress i{
  display:block;height:100%;width:100%;
  background:linear-gradient(90deg,var(--acid),var(--cyan));
  transform-origin:0 50%;transform:scaleX(0);
  box-shadow:0 0 12px var(--acid);
}
.hud-pct{
  position:absolute;right:14px;top:50%;
  font-size:10px;color:var(--dim);letter-spacing:.2em;
  transform:translateY(-50%) rotate(90deg);
}
html:not(.booted) .hud{opacity:0}
.hud{transition:opacity .8s var(--ease)}

/* ============ CURSOR ============ */
#cursor,#cursor-dot{
  position:fixed;top:0;left:0;z-index:200;pointer-events:none;
  border-radius:50%;opacity:0;
}
#cursor{
  width:36px;height:36px;margin:-18px 0 0 -18px;
  border:1.5px solid #fff;
  mix-blend-mode:difference;
  transition:transform .25s var(--ease),opacity .3s;
}
#cursor-dot{
  width:5px;height:5px;margin:-2.5px 0 0 -2.5px;
  background:var(--acid);
  box-shadow:0 0 8px var(--acid);
}
html.cursor-on #cursor,html.cursor-on #cursor-dot{opacity:1}
#cursor.hot{transform:scale(2.1);background:rgba(255,255,255,.08)}

/* ============ LOADER ============ */
html:not(.js) #loader{display:none}
#loader{
  position:fixed;inset:0;z-index:300;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  transition:clip-path .65s var(--ease),visibility 0s .7s;
  clip-path:inset(0 0 0 0);
}
#loader.done{clip-path:inset(0 0 100% 0);visibility:hidden}
.loader-core{width:min(560px,86vw)}
.loader-top{
  display:flex;justify-content:space-between;
  font-size:12px;letter-spacing:.18em;color:var(--acid);
  margin-bottom:10px;
}
#loader-pct{color:var(--ink)}
.loader-bar{height:2px;background:rgba(255,255,255,.08);overflow:hidden}
.loader-bar i{
  display:block;height:100%;width:100%;
  background:var(--acid);box-shadow:0 0 14px var(--acid);
  transform-origin:0 50%;transform:scaleX(0);
}
.loader-log{
  margin-top:18px;font-size:11px;line-height:1.9;
  color:var(--dim);letter-spacing:.08em;min-height:7.6em;
}
.loader-log .ok{color:var(--acid)}
.loader-log .err{color:var(--mag)}

/* ============ NAV ============ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;
  mix-blend-mode:normal;
  transition:transform .8s var(--ease),opacity .8s var(--ease);
}
html.js:not(.booted) nav{transform:translateY(-20px);opacity:0}
.logo{
  font-size:15px;font-weight:700;letter-spacing:.1em;color:var(--ink);
  text-transform:uppercase;
}
.logo .censor{
  background:var(--acid);color:var(--acid);
  padding:0 2px;margin:0 1px;border-radius:2px;
  animation:censorflick 4s steps(1) infinite;
}
@keyframes censorflick{
  0%,92%,100%{background:var(--acid);color:var(--acid)}
  93%,95%{background:var(--mag);color:var(--mag)}
  96%,97%{background:var(--cyan);color:var(--cyan)}
}
.logo .tld{color:var(--acid)}
.nav-links{display:flex;gap:6px;list-style:none}
.nav-links a{
  display:inline-block;
  font-size:11px;letter-spacing:.16em;color:var(--dim);
  padding:8px 14px;border:1px solid transparent;
  transition:color .25s,border-color .25s,background .25s;
  text-transform:uppercase;
}
.nav-links a sup{color:var(--acid);margin-right:6px;font-size:8px}
.nav-links a:hover{color:var(--ink);border-color:var(--line);background:rgba(255,255,255,.03)}
.nav-burger{
  display:none;background:none;border:1px solid var(--line);
  width:44px;height:44px;cursor:pointer;
  flex-direction:column;align-items:center;justify-content:center;gap:7px;
}
.nav-burger span{display:block;width:20px;height:1.5px;background:var(--ink);transition:transform .35s var(--ease)}
html.menu-open .nav-burger span:nth-child(1){transform:translateY(4.25px) rotate(45deg)}
html.menu-open .nav-burger span:nth-child(2){transform:translateY(-4.25px) rotate(-45deg)}

/* ============ CONTENT / SCENES ============ */
#content{position:relative;z-index:10}
.sec{padding:18vh var(--pad)}
.sec-tight{padding:12vh 0}
.sec-head{margin-bottom:7vh;max-width:1200px}
.sec-index{font-size:12px;letter-spacing:.22em;color:var(--acid);margin-bottom:18px}
.sec-title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(3rem,7.5vw,7.5rem);
  line-height:.95;letter-spacing:.01em;
  text-transform:uppercase;
}
.sec-sub{margin-top:18px;color:var(--dim);max-width:520px;font-size:15px}

/* ============ GLITCH TEXT ============ */
.glitch{position:relative;display:inline-block}
.glitch::before,.glitch::after{
  content:attr(data-text);
  position:absolute;inset:0;opacity:0;pointer-events:none;
  -webkit-text-stroke:0;
}
.glitch.on::before{
  opacity:.9;color:var(--mag);z-index:-1;
  animation:gsliceA .26s steps(2) both;
}
.glitch.on::after{
  opacity:.9;color:var(--cyan);z-index:-1;
  animation:gsliceB .26s steps(2) both;
}
@keyframes gsliceA{
  0%{transform:translate(-6px,2px);clip-path:inset(12% 0 55% 0)}
  50%{transform:translate(5px,-2px);clip-path:inset(58% 0 8% 0)}
  100%{transform:translate(-3px,1px);clip-path:inset(30% 0 38% 0);opacity:0}
}
@keyframes gsliceB{
  0%{transform:translate(6px,-2px);clip-path:inset(60% 0 10% 0)}
  50%{transform:translate(-5px,2px);clip-path:inset(5% 0 70% 0)}
  100%{transform:translate(3px,-1px);clip-path:inset(42% 0 28% 0);opacity:0}
}

/* ============ HERO ============ */
.hero{
  min-height:100svh;position:relative;
  display:flex;flex-direction:column;justify-content:center;
  padding:16vh var(--pad) 10vh;
}
.eyebrow{
  font-size:12px;letter-spacing:.22em;color:var(--acid);
  margin-bottom:3vh;
}
.hero-title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(5rem,17.5vw,19rem);
  line-height:.85;letter-spacing:.005em;
  text-transform:uppercase;
  user-select:none;
}
.ht-line{display:block;overflow:hidden;padding:0 .06em;margin:0 -.06em}
.ht-word{display:inline-block;will-change:transform}
html.js .boot-in,
html.js .ht-word{opacity:0}
html.js .ht-word{transform:translateY(110%) rotate(2deg);opacity:1}
html.booted .ht-word{
  transform:none;
  transition:transform 1.1s var(--ease);
}
.ht-line:nth-child(2) .ht-word{transition-delay:.12s}
html.js .boot-in{transform:translateY(24px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
html.booted .boot-in{opacity:1;transform:none;transition-delay:.55s}
.outline{
  color:transparent;
  -webkit-text-stroke:2px var(--ink);
}
@media(max-width:768px){.outline{-webkit-text-stroke-width:1.2px}}

.hero-foot{
  margin-top:5vh;display:flex;justify-content:space-between;
  align-items:flex-end;gap:32px;flex-wrap:wrap;
}
.hero-tag{font-size:13px;letter-spacing:.14em;color:var(--ink);min-height:1.4em}
.hero-stats{display:flex;gap:42px}
.stat b{
  display:block;font-family:var(--display);font-weight:400;
  font-size:clamp(26px,3vw,40px);color:var(--acid);line-height:1;
  text-shadow:0 0 18px rgba(0,255,159,.4);
}
.stat span{font-size:10px;color:var(--dim);letter-spacing:.18em}

.id-card{
  position:absolute;right:var(--pad);top:18vh;
  width:172px;padding:10px 10px 12px;
  background:var(--glass);border:1px solid var(--line);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  transform:rotate(3deg);
  transition:transform .4s var(--ease);
  z-index:2;
}
.id-card:hover{transform:rotate(0) scale(1.04)}
.id-img{position:relative;overflow:hidden}
.id-img img{filter:saturate(.85) contrast(1.1);width:100%;height:auto}
.id-img::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.18) 2px,rgba(0,0,0,.18) 3px);
  pointer-events:none;
}
.id-card:hover .id-img img{animation:idglitch .3s steps(3) both}
@keyframes idglitch{
  0%{transform:translate(2px,0);filter:saturate(2) hue-rotate(40deg)}
  50%{transform:translate(-3px,1px);filter:saturate(.3) hue-rotate(-60deg)}
  100%{transform:none;filter:saturate(.85) contrast(1.1)}
}
.id-card figcaption{
  font-size:8.5px;line-height:1.7;color:var(--dim);
  letter-spacing:.14em;margin-top:8px;
}
.id-barcode{
  margin-top:7px;height:16px;
  background:repeating-linear-gradient(90deg,var(--ink) 0 1px,transparent 1px 3px,var(--ink) 3px 5px,transparent 5px 6px,var(--ink) 6px 10px,transparent 10px 12px);
  opacity:.7;
}

.scroll-cue{
  position:absolute;bottom:4vh;left:50%;transform:translateX(-50%);
  font-size:10px;letter-spacing:.34em;color:var(--dim);
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.cue-line{
  width:1px;height:48px;overflow:hidden;position:relative;
  background:rgba(255,255,255,.12);
}
.cue-line::after{
  content:'';position:absolute;left:0;top:-50%;width:100%;height:50%;
  background:var(--acid);
  animation:cuedrop 1.8s var(--ease) infinite;
}
@keyframes cuedrop{0%{top:-50%}100%{top:110%}}

/* ============ ICON STRIP ============ */
.strip{
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  background:rgba(5,6,10,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  overflow:hidden;padding:14px 0;position:relative;z-index:10;
}
.strip-track{display:flex;width:max-content;animation:stripmove 36s linear infinite}
.strip:hover .strip-track{animation-play-state:paused}
@keyframes stripmove{to{transform:translateX(-50%)}}
.strip-set{display:flex;flex-shrink:0}
.strip-item{
  display:flex;align-items:center;gap:12px;
  padding:0 28px;border-right:1px solid var(--line-soft);
}
.strip-item img{width:30px;height:30px;border-radius:6px;object-fit:cover;filter:saturate(.9)}
.strip-item i{font-style:normal;font-size:10px;letter-spacing:.18em;color:var(--dim);white-space:nowrap}

/* ============ REVEALS ============ */
html.js [data-reveal]{
  opacity:0;transform:translateY(46px);
  transition:opacity 1s var(--ease),transform 1s var(--ease);
  transition-delay:var(--rd,0s);
}
html.js [data-reveal].in,
html.reveal-all [data-reveal]{opacity:1;transform:none}

/* ============ PANELS (NOW) ============ */
.panel-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  max-width:1400px;
}
.panel{
  background:var(--glass);border:1px solid var(--line);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  overflow:hidden;position:relative;
  transition:border-color .3s,transform .5s var(--ease),box-shadow .5s;
}
.panel:hover{
  border-color:var(--acid);
  transform:translateY(-8px);
  box-shadow:0 0 0 1px rgba(0,255,159,.25),0 0 40px rgba(0,255,159,.12),0 30px 60px rgba(0,0,0,.5);
}
.panel-img{overflow:hidden;position:relative;aspect-ratio:16/9}
.panel-img img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.8) contrast(1.05);
  transition:transform .7s var(--ease),filter .4s;
}
.panel:hover .panel-img img{transform:scale(1.06);filter:saturate(1.3) contrast(1.15)}
.panel-img::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.12) 3px,rgba(0,0,0,.12) 4px);
}
.panel-body{padding:24px}
.panel-label{font-size:10px;letter-spacing:.22em;color:var(--acid);margin-bottom:12px}
.panel-body h3{font-size:17px;font-weight:600;line-height:1.35;margin-bottom:8px}
.panel-body p:not(.panel-label){font-size:13.5px;color:var(--dim)}

/* ============ BIG MARQUEE ============ */
.bigmarquee{overflow:hidden;padding:6vh 0;position:relative;z-index:10}
.bigmarquee-track{
  display:flex;width:max-content;
  animation:stripmove 26s linear infinite;
}
.bigmarquee-track span{
  font-family:var(--display);font-weight:400;
  font-size:clamp(4rem,9vw,9rem);line-height:1;
  text-transform:uppercase;white-space:nowrap;
  color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.28);
  flex-shrink:0;
}
.bigmarquee-track em{
  font-style:normal;color:var(--acid);-webkit-text-stroke:0;
  text-shadow:0 0 24px rgba(0,255,159,.5);
  margin:0 .25em;
}

/* ============ WORKS — HORIZONTAL ============ */
#shipped{position:relative}
.works-sticky{
  position:sticky;top:0;height:100svh;overflow:hidden;
  display:flex;align-items:flex-end;
}
.works-head{
  position:absolute;top:10vh;left:var(--pad);z-index:3;
  margin:0;pointer-events:none;
}
.works-head .sec-title{font-size:clamp(2.6rem,6vw,6rem)}
.works-track{
  display:flex;gap:3.5vw;align-items:flex-end;
  padding:0 var(--pad) 8vh;
  will-change:transform;
}
.work{
  flex:0 0 auto;
  width:clamp(330px,36vw,560px);
  background:var(--glass);border:1px solid var(--line);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  transition:border-color .3s,box-shadow .4s;
  position:relative;
}
.work:hover{
  border-color:var(--ac,#00ff9f);
  box-shadow:0 0 0 1px color-mix(in srgb,var(--ac) 40%,transparent),0 0 50px color-mix(in srgb,var(--ac) 14%,transparent);
}
.work-img{position:relative;overflow:hidden;aspect-ratio:16/9;background:#0c0f15}
.work-img img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.75) contrast(1.05);
  transition:filter .35s,transform .8s var(--ease);
}
.work:hover .work-img>img{filter:saturate(1.25) contrast(1.1);transform:scale(1.05)}
.work-img .gclone{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;pointer-events:none;mix-blend-mode:screen;
}
.work:hover .gclone.gr{animation:cloneR .5s steps(4) both}
.work:hover .gclone.gb{animation:cloneB .5s steps(4) both}
@keyframes cloneR{
  0%{opacity:.7;transform:translate(8px,-3px);filter:hue-rotate(-60deg) saturate(3);clip-path:inset(10% 0 60% 0)}
  60%{opacity:.5;transform:translate(-6px,2px);clip-path:inset(55% 0 12% 0)}
  100%{opacity:0;transform:none}
}
@keyframes cloneB{
  0%{opacity:.7;transform:translate(-8px,3px);filter:hue-rotate(120deg) saturate(3);clip-path:inset(62% 0 8% 0)}
  60%{opacity:.5;transform:translate(7px,-2px);clip-path:inset(8% 0 66% 0)}
  100%{opacity:0;transform:none}
}
.work-body{padding:22px 24px 26px}
.work-meta{
  display:flex;justify-content:space-between;
  font-size:10px;letter-spacing:.2em;color:var(--ac,var(--acid));
  margin-bottom:14px;
}
.work-body h3{
  font-family:var(--display);font-weight:400;
  font-size:clamp(20px,2vw,30px);letter-spacing:.02em;
  line-height:1.05;margin-bottom:10px;
}
.work-body p:not(.mono){font-size:13.5px;color:var(--dim)}
.work-stat{
  margin-top:14px;font-size:11px;letter-spacing:.16em;
  color:var(--ink);
  border-top:1px solid var(--line-soft);padding-top:12px;
}

/* ============ CAREER ============ */
.career{max-width:1300px;border-top:1px solid var(--line)}
.career-row{
  display:grid;grid-template-columns:minmax(140px,300px) 1fr;gap:4vw;
  padding:5vh 0;border-bottom:1px solid var(--line);
  transition:background .3s,padding-left .45s var(--ease);
  position:relative;
}
.career-row:hover{background:rgba(255,255,255,.02);padding-left:18px}
.career-row::before{
  content:'';position:absolute;left:0;top:0;height:100%;width:2px;
  background:var(--acid);box-shadow:0 0 16px var(--acid);
  transform:scaleY(0);transform-origin:0 0;
  transition:transform .45s var(--ease);
}
.career-row:hover::before{transform:scaleY(1)}
.career-year{
  font-family:var(--display);font-weight:400;
  font-size:clamp(3.4rem,7vw,7rem);line-height:.9;
  color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.3);
  transition:color .4s,-webkit-text-stroke-color .4s;
  user-select:none;
}
.career-row:hover .career-year{color:var(--acid);-webkit-text-stroke-color:var(--acid)}
.career-info h3{font-size:clamp(18px,1.8vw,24px);font-weight:600;margin-bottom:6px}
.career-co{font-size:11px;letter-spacing:.18em;color:var(--cyan);margin-bottom:12px}
.career-info p:not(.mono){font-size:14px;color:var(--dim);max-width:620px}
.career-tags{margin-top:14px;font-size:10px;letter-spacing:.2em;color:var(--dim)}

/* ============ FLOTT TERMINAL ============ */
.terminal{
  max-width:1100px;margin:0 auto;
  background:rgba(7,10,9,.72);border:1px solid var(--line);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:0 0 60px rgba(0,255,159,.07),0 40px 80px rgba(0,0,0,.5);
}
.terminal-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;border-bottom:1px solid var(--line);
  font-size:11px;letter-spacing:.14em;color:var(--dim);
}
.t-dots{display:flex;gap:7px}
.t-dots i{width:10px;height:10px;border-radius:50%;background:#2a332e}
.t-dots i:nth-child(1){background:#ff5f57}
.t-dots i:nth-child(2){background:#febc2e}
.t-dots i:nth-child(3){background:#28c840}
.t-status{color:var(--acid)}
.terminal-body{
  display:grid;grid-template-columns:1.2fr 1fr;gap:32px;
  padding:clamp(28px,5vw,64px);align-items:center;
}
.flott-badge{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:.2em;color:var(--acid);
  border:1px solid rgba(0,255,159,.3);padding:8px 16px;
  margin-bottom:24px;
}
.flott-badge .pulse{
  width:7px;height:7px;border-radius:50%;background:var(--acid);
  box-shadow:0 0 10px var(--acid);
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.7)}}
.flott-title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(4rem,8vw,8rem);line-height:.9;
  color:var(--acid);text-shadow:0 0 40px rgba(0,255,159,.35);
  margin-bottom:18px;
}
.flott-desc{color:var(--dim);font-size:15px;max-width:420px;margin-bottom:18px}
.flott-err{font-size:11px;letter-spacing:.1em;color:var(--mag);margin-bottom:30px}
.flott-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:300px}
.flott-ring{
  position:absolute;width:300px;height:300px;border-radius:50%;
  border:1px dashed rgba(0,255,159,.3);
  animation:spin 24s linear infinite;
}
.flott-ring::after{
  content:'';position:absolute;inset:24px;border-radius:50%;
  border:1px solid rgba(0,229,255,.15);
}
@keyframes spin{to{transform:rotate(360deg)}}
.flott-character-wrap{
  position:relative;width:200px;
  filter:drop-shadow(0 0 24px rgba(0,255,159,.4));
}
.flott-character-wrap img{width:100%;display:block}
.flott-head{
  --hx:21px;--hy:-63px;--hs:0.76;--hb:7px;
  position:absolute;top:0;left:0;
  animation:flotti-headSwag .6s infinite;
  transform-origin:50% 80%;z-index:20;will-change:transform;
}
.flott-body{
  animation:flotti-bodyPulse .6s infinite;
  transform-origin:bottom center;z-index:10;will-change:transform;
}
@keyframes flotti-headSwag{
  0%{transform:translate(var(--hx),calc(var(--hy) + var(--hb))) scale(var(--hs)) rotate(4deg);animation-timing-function:cubic-bezier(0,0,.2,1)}
  35%{transform:translate(calc(var(--hx) + 1px),calc(var(--hy) - calc(var(--hb) / 3))) scale(var(--hs)) rotate(-3deg);animation-timing-function:ease-in-out}
  65%{transform:translate(var(--hx),var(--hy)) scale(var(--hs)) rotate(0deg);animation-timing-function:ease-in}
  100%{transform:translate(var(--hx),calc(var(--hy) + var(--hb))) scale(var(--hs)) rotate(4deg)}
}
@keyframes flotti-bodyPulse{
  0%{transform:scaleY(.98) scaleX(1.01)}
  35%{transform:scaleY(1.005) scaleX(.995)}
  100%{transform:scaleY(.98) scaleX(1.01)}
}

/* ============ TAG MARQUEES ============ */
#interests .sec-head{padding:0 var(--pad)}
.tagmarquee{display:flex;flex-direction:column;gap:14px;overflow:hidden}
.tag-track{display:flex;width:max-content}
.tag-track.t-left{animation:stripmove 32s linear infinite}
.tag-track.t-right{animation:stripmove 32s linear infinite reverse}
.tag-track span{
  font-family:var(--display);font-weight:400;
  font-size:clamp(2.2rem,5vw,4.4rem);line-height:1.15;
  text-transform:uppercase;white-space:nowrap;flex-shrink:0;
}
.tag-track.t-left span{color:rgba(255,255,255,.85)}
.tag-track.t-right span{color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.3)}
.tag-track em{font-style:normal;color:var(--mag);-webkit-text-stroke:0;margin:0 .3em}
.tag-track.t-left em{color:var(--cyan)}

/* ============ CONTACT ============ */
.contact{
  min-height:90svh;display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;
}
.contact .sec-index{margin-bottom:3vh}
.contact-title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(3.4rem,10.5vw,11rem);
  line-height:.92;text-transform:uppercase;
  margin-bottom:4vh;
}
.contact-sub{color:var(--dim);max-width:480px;font-size:15px;margin-bottom:5vh}
.contact-btns{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}
.btn{
  display:inline-block;position:relative;
  font-family:var(--mono);font-size:12px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:#000;background:var(--acid);
  padding:0;border:1px solid var(--acid);
  transition:box-shadow .3s,background .3s,color .3s;
}
.btn .btn-inner{display:inline-block;padding:18px 38px}
.btn:hover{box-shadow:0 0 30px rgba(0,255,159,.5),0 0 80px rgba(0,255,159,.2)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 30px rgba(0,229,255,.25)}
.contact-note{margin-top:7vh;font-size:10px;letter-spacing:.26em;color:var(--dim)}

/* ============ FOOTER ============ */
footer{
  padding:28px var(--pad) 64px;text-align:center;
  border-top:1px solid var(--line-soft);
  position:relative;z-index:10;
}
footer p{font-size:10px;letter-spacing:.2em;color:var(--dim);line-height:2.2}
footer .censor{background:var(--dim);color:var(--dim);padding:0 2px;border-radius:2px}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .panel-grid{grid-template-columns:1fr 1fr}
  .terminal-body{grid-template-columns:1fr}
  .flott-visual{min-height:260px}
}
@media(max-width:768px){
  :root{--pad:20px}
  .sec{padding:14vh var(--pad)}
  .nav-links{
    display:none;
  }
  html.menu-open .nav-links{
    display:flex;flex-direction:column;gap:0;
    position:fixed;inset:0;z-index:-1;
    background:rgba(5,6,10,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    align-items:flex-start;justify-content:center;
    padding:0 28px;
  }
  html.menu-open .nav-links a{
    font-family:var(--display);font-size:13vw;letter-spacing:.02em;
    color:var(--ink);border:none;padding:2vh 0;
  }
  html.menu-open .nav-links a sup{font-size:12px}
  .nav-burger{display:flex}
  .hero{padding-top:20vh}
  .hero-title{font-size:clamp(4.2rem,21vw,9rem)}
  .id-card{
    position:relative;right:auto;top:auto;
    margin-top:6vh;transform:rotate(2deg);
    width:150px;
  }
  .hero-foot{flex-direction:column;align-items:flex-start}
  .hero-stats{gap:24px;flex-wrap:wrap}
  .scroll-cue{display:none}
  .hud-coords,.hud-pct,.hud-section,.hud-corner{display:none}
  .panel-grid{grid-template-columns:1fr}
  /* horizontal gallery → native swipe */
  .works-sticky{position:relative;height:auto;display:block;overflow:visible}
  .works-head{position:relative;top:auto;left:auto;padding:14vh var(--pad) 0;margin-bottom:5vh}
  .works-track{
    overflow-x:auto;padding:0 var(--pad) 6vh;gap:16px;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
  }
  .work{width:82vw;scroll-snap-align:center}
  .career-row{grid-template-columns:1fr;gap:10px;padding:4vh 0}
  .career-row:hover{padding-left:0}
  .contact{min-height:70svh}
}

/* ============ HERO 3D MODEL ============ */
.hero-3d{
  position:absolute;right:-5vw;top:-6vh;bottom:0;
  width:min(54vw,680px);
  pointer-events:none;z-index:1;
  /* soft radial mask — fades to nothing on all edges, no hard rectangular border */
  -webkit-mask-image:radial-gradient(ellipse 86% 68% at 58% 30%, black 32%, transparent 70%);
  mask-image:radial-gradient(ellipse 86% 68% at 58% 30%, black 32%, transparent 70%);
}
/* ensure hero text always renders above the 3d figure */
.hero-inner{position:relative;z-index:3}
model-viewer.hero-mv{
  width:100%;height:130%;margin-top:-7%;
  background-color:transparent;
  --progress-bar-color:transparent;
  --poster-color:transparent;
  display:block;
}
.hero-mv-r,.hero-mv-b{
  position:absolute;inset:0;z-index:3;
  opacity:0;pointer-events:none;mix-blend-mode:screen;
  clip-path:inset(0 0 100% 0);
}
.hero-mv-r{background:rgba(255,43,214,.72)}
.hero-mv-b{background:rgba(0,229,255,.72)}
/* glitch burst */
.hero-3d.glitching .hero-mv{animation:mv-distort .38s steps(4) both}
.hero-3d.glitching .hero-mv-r{animation:mv-rband .38s steps(5) both}
.hero-3d.glitching .hero-mv-b{animation:mv-bband .38s steps(5) both}
@keyframes mv-distort{
  0%  {filter:saturate(1)}
  12% {transform:translate(7px,-3px) skewX(5deg);filter:saturate(2.8) hue-rotate(50deg) brightness(1.4)}
  28% {transform:translate(-6px,2px) skewX(-4deg);filter:saturate(.3) hue-rotate(-90deg) contrast(2)}
  46% {transform:translate(9px,0) skewX(7deg);filter:saturate(3.5) hue-rotate(170deg) brightness(1.7)}
  65% {transform:translate(-4px,-1px);filter:saturate(1.5)}
  82% {transform:translate(2px,1px)}
  100%{transform:none;filter:none}
}
@keyframes mv-rband{
  0%  {opacity:0;clip-path:inset(0 0 100% 0)}
  18% {opacity:.9;clip-path:inset(8% 0 40% 0);transform:translateX(10px)}
  40% {opacity:.7;clip-path:inset(52% 0 6% 0);transform:translateX(-8px)}
  65% {opacity:.5;clip-path:inset(28% 0 33% 0);transform:translateX(5px)}
  85% {opacity:.2;clip-path:inset(70% 0 2% 0)}
  100%{opacity:0;clip-path:inset(0 0 100% 0);transform:none}
}
@keyframes mv-bband{
  0%  {opacity:0;clip-path:inset(100% 0 0 0)}
  18% {opacity:.9;clip-path:inset(58% 0 10% 0);transform:translateX(-10px)}
  40% {opacity:.7;clip-path:inset(4% 0 60% 0);transform:translateX(8px)}
  65% {opacity:.5;clip-path:inset(36% 0 22% 0);transform:translateX(-4px)}
  85% {opacity:.2;clip-path:inset(5% 0 72% 0)}
  100%{opacity:0;clip-path:inset(100% 0 0 0);transform:none}
}
@media(max-width:768px){
  .hero-3d{width:130vw;right:-15vw;opacity:.55}
}

/* ============ CRAZY CAROUSELS ============ */
[data-crazy-carousel] .work-img{position:relative}
.carousel-slide{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.75) contrast(1.05);
  opacity:0;z-index:1;
}
.carousel-slide.is-active{opacity:1;z-index:2}
.work:hover .carousel-slide.is-active{
  filter:saturate(1.25) contrast(1.1);
  transform:scale(1.05);
  transition:filter .35s,transform .8s var(--ease);
}

/* — glitch-slice (Catan/Carcassonne) — */
[data-crazy-carousel="glitch-slice"] .carousel-slide.entering{
  opacity:1;z-index:4;
  animation:gslice-in .55s steps(7) forwards;
}
[data-crazy-carousel="glitch-slice"] .carousel-slide.leaving{
  z-index:3;
  animation:gslice-out .55s steps(7) forwards;
}
@keyframes gslice-in{
  0%  {clip-path:inset(0 0 99% 0);filter:saturate(4) brightness(2.2) hue-rotate(60deg);transform:translateX(14px)}
  14% {clip-path:inset(4% 0 54% 0);filter:saturate(3) hue-rotate(-40deg);transform:translateX(-10px)}
  28% {clip-path:inset(49% 0 12% 0);filter:saturate(2) brightness(1.5);transform:translateX(8px)}
  43% {clip-path:inset(18% 0 28% 0);filter:saturate(1.8) hue-rotate(20deg);transform:translateX(-4px)}
  57% {clip-path:inset(0 0 44% 0);filter:saturate(1.3);transform:none}
  71% {clip-path:inset(0 0 18% 0);filter:saturate(1.1)}
  86% {clip-path:inset(0 0 5% 0)}
  100%{clip-path:inset(0);filter:saturate(.75) contrast(1.05);transform:none}
}
@keyframes gslice-out{
  0%  {opacity:1;filter:saturate(.75) contrast(1.05);clip-path:inset(0);transform:none}
  18% {filter:saturate(3.5) hue-rotate(-70deg) brightness(1.4);clip-path:inset(0);transform:translateX(-10px)}
  35% {filter:saturate(.4) contrast(2);clip-path:inset(25% 0 22% 0);transform:translateX(7px)}
  55% {clip-path:inset(58% 0 4% 0);opacity:.6;transform:translateX(-5px)}
  75% {clip-path:inset(80% 0 0% 0);opacity:.3}
  100%{opacity:0;clip-path:inset(0 0 100% 0);transform:none}
}

/* — vhs-burn (Pearl's/Jelly/Tropicats) — */
[data-crazy-carousel="vhs-burn"] .carousel-slide.entering{
  opacity:1;z-index:4;
  animation:vhs-in .5s steps(6) forwards;
}
[data-crazy-carousel="vhs-burn"] .carousel-slide.leaving{
  z-index:3;
  animation:vhs-out .5s steps(6) forwards;
}
@keyframes vhs-in{
  0%  {transform:scaleY(.015) scaleX(1.12);filter:brightness(5) saturate(0);opacity:1}
  17% {transform:scaleY(.07) scaleX(1.08);filter:brightness(4) hue-rotate(140deg) saturate(2)}
  33% {transform:scaleY(.22) scaleX(1.04);filter:brightness(2.5) hue-rotate(-40deg)}
  50% {transform:scaleY(.52) scaleX(1.01);filter:brightness(1.8) saturate(1.8)}
  67% {transform:scaleY(.78) scaleX(1.003);filter:brightness(1.3) saturate(1.2)}
  83% {transform:scaleY(.94);filter:brightness(1.05)}
  100%{transform:none;filter:saturate(.75) contrast(1.05)}
}
@keyframes vhs-out{
  0%  {opacity:1;transform:none;filter:saturate(.75) contrast(1.05)}
  20% {filter:saturate(3) brightness(2.2) hue-rotate(-20deg);transform:scaleY(.96) translateY(3px)}
  40% {filter:brightness(4) saturate(.5) contrast(2);transform:scaleY(.45) scaleX(1.06) translateY(-6px)}
  65% {filter:brightness(6) saturate(0);transform:scaleY(.08) scaleX(1.1) translateY(2px)}
  100%{transform:scaleY(0) scaleX(1.15);opacity:0}
}

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  html.js [data-reveal],html.js .boot-in,html.js .ht-word{opacity:1;transform:none}
  .strip-track,.bigmarquee-track,.tag-track{animation:none}
  #gl,#noise{display:none}
}
