/* === Mir Kotov - The Trip v2 / Horizontal monolithic trip === */

@font-face{font-display:swap;font-family:Indivisible;font-style:normal;font-weight:1 999;src:local(IndivisibleVariable),url(https://mirkotov.com/fonts/IndivisibleVariable.woff2) format('woff2')}

:root{
  --w-bg:#0c0c0c;
  --w-fg:#f0ece6;
  --w-accent:#ee382b;
  --w-fg2:rgba(240,236,230,.55);
  --w-border:rgba(240,236,230,.12);

  --font-display:Indivisible,'Inter',helvetica,arial,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --font-gothic:'UnifrakturMaguntia',serif;

  --ease-out:cubic-bezier(.165,.84,.44,1);
  --ease-inout:cubic-bezier(.76,0,.24,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;cursor:none!important}
html,body{
  background:var(--w-bg);color:var(--w-fg);
  font-family:var(--font-display);
  overflow:hidden;height:100vh;width:100vw;
  transition:background 1.2s var(--ease-inout),color 1.2s var(--ease-inout);
}
body{font:500 1rem/1.4 var(--font-display);overscroll-behavior:none;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
::selection{background:var(--w-accent);color:var(--w-bg)}

#trip-webgl{position:fixed;inset:0;width:100vw;height:100vh;z-index:0;pointer-events:none;opacity:.7;mix-blend-mode:screen}
.trip-grain{position:fixed;inset:0;z-index:50;pointer-events:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.4'/></svg>");opacity:.18;mix-blend-mode:overlay;animation:grainShift .8s steps(4) infinite}
@keyframes grainShift{0%{transform:translate(0,0)}25%{transform:translate(-2%,1%)}50%{transform:translate(1%,-2%)}75%{transform:translate(-1%,-1%)}100%{transform:translate(2%,2%)}}

#cursor{position:fixed;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 60%);pointer-events:none;z-index:40;transform:translate(-50%,-50%);mix-blend-mode:screen;left:50%;top:50%}
#cursor-dot{position:fixed;width:14px;height:14px;border-radius:50%;background:var(--w-fg);pointer-events:none;z-index:41;transform:translate(-50%,-50%);mix-blend-mode:difference;transition:width .25s var(--ease-out),height .25s var(--ease-out);left:50%;top:50%}
#cursor-dot.large{width:88px;height:88px;box-shadow:0 0 24px 6px rgba(255,255,255,.35)}
/* Hide custom cursor on touch devices and restore native cursor */
@media(hover:none),(pointer:coarse),(max-width:760px){
  #cursor,#cursor-dot{display:none!important}
  *,*::before,*::after{cursor:auto!important}
  a,button,.cat-card,.phw-item,.dir-frame,.exit-btn,.fs-frame,.minimap li,#trip-minimap li{cursor:pointer!important}
  input[type="range"]{cursor:pointer!important}
}

/* Persistent logo */
#trip-logo{position:fixed;top:clamp(20px,2.5vw,36px);left:50%;transform:translateX(-50%);z-index:30;display:flex;gap:.02em;font-family:var(--font-display);font-weight:600;font-size:clamp(18px,2.2vw,28px);letter-spacing:.04em;color:var(--w-fg);mix-blend-mode:difference;transition:transform 1.2s var(--ease-inout),font-family .8s,font-size .8s;pointer-events:none;user-select:none}
#trip-logo .fl{display:inline-block;transition:transform .6s var(--ease-out)}

/* Title */
#trip-title{position:fixed;top:clamp(16px,2vw,28px);left:clamp(16px,2.5vw,32px);z-index:30;font-family:var(--font-mono);font-size:11px;color:var(--w-fg);display:flex;flex-direction:column;gap:2px;pointer-events:none;text-transform:uppercase;letter-spacing:.18em}
.trip-title-num{opacity:.5;font-size:10px}
.trip-title-name{font-size:13px;font-weight:500;letter-spacing:.22em}
.trip-title-sub{opacity:.5;font-size:10px;font-style:italic;letter-spacing:.1em;text-transform:none}

/* Audio toggle */
#trip-audio{position:fixed;bottom:clamp(16px,2vw,28px);right:clamp(16px,2.5vw,32px);z-index:30;width:44px;height:44px;border-radius:50%;background:transparent;border:1px solid var(--w-border);color:var(--w-fg);display:grid;place-items:center;pointer-events:auto}

/* Horizontal progress rail at top */
#trip-progress{position:fixed;left:0;top:0;height:2px;width:100vw;z-index:35;background:transparent;pointer-events:none}
#trip-progress-bar{height:100%;width:0%;background:var(--w-accent);transition:width .15s linear;box-shadow:0 0 10px var(--w-accent)}

/* Horizontal minimap (bottom) */
#trip-minimap{position:fixed;bottom:clamp(20px,3vh,36px);left:50%;transform:translateX(-50%);z-index:30;font-family:var(--font-mono);font-size:11px;color:var(--w-fg2)}
#trip-minimap ol{list-style:none;display:flex;gap:18px}
#trip-minimap li{display:flex;align-items:center;gap:8px;cursor:pointer!important;opacity:.4;transition:opacity .4s,color .4s;pointer-events:auto;text-transform:uppercase;letter-spacing:.18em;font-size:10px}
#trip-minimap li::before{content:'';width:24px;height:1px;background:var(--w-fg);transition:width .4s,background .4s}
#trip-minimap li.active{opacity:1;color:var(--w-fg)}
#trip-minimap li.active::before{width:48px;background:var(--w-accent);height:2px}

#trip-exit-link{position:fixed;bottom:clamp(16px,2vw,28px);left:clamp(16px,2.5vw,32px);z-index:30;font-family:var(--font-mono);font-size:11px;color:var(--w-fg);opacity:.5;text-transform:uppercase;letter-spacing:.18em}
#trip-exit-link:hover{opacity:1;color:var(--w-accent)}

/* Mobile gesture hint - shown briefly per world entry */
#gesture-hint{
  position:fixed;left:50%;bottom:64px;transform:translateX(-50%);z-index:38;
  display:none;align-items:center;gap:10px;
  padding:10px 18px;border:1px solid var(--w-border);border-radius:999px;
  background:rgba(0,0,0,.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  font-family:var(--font-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--w-fg);
  pointer-events:none;opacity:0;transition:opacity .4s,bottom .4s;
}
#gesture-hint.is-show{display:flex;opacity:1}
#gesture-hint #gh-icon{font-size:14px;color:var(--w-accent);animation:ghBob 1.4s ease-in-out infinite}
@keyframes ghBob{0%,100%{transform:translate(0)}50%{transform:translate(-3px,-1px)}}
@media(min-width:761px){#gesture-hint{display:none!important}}

/* Scroll hint - bottom right corner */
#trip-hint{position:fixed;bottom:clamp(16px,2vw,28px);right:clamp(70px,8vw,100px);z-index:30;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.3em;opacity:.6;color:var(--w-fg);pointer-events:none;animation:hintPulse 2.4s ease-in-out infinite}
@keyframes hintPulse{0%,100%{opacity:.4}50%{opacity:.9}}

/* === HORIZONTAL STACK === */
#trip-stack{
  position:fixed;left:0;top:0;
  display:flex;
  height:100vh;
  /* Width set inline by JS = worldCount * 100vw */
  will-change:transform;
  z-index:10;
}

section[data-world]{
  flex:0 0 100vw;
  width:100vw;height:100vh;
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(60px,8vh,120px) clamp(24px,4vw,80px);
}

/* === World 0: Threshold === */
[data-world="threshold"]{text-align:center;flex-direction:column;gap:1rem;padding:0;align-items:center;justify-content:center;overflow:hidden}
.thr-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:contrast(1.05) saturate(.9);pointer-events:none}
.thr-veil{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at 50% 50%,rgba(0,0,0,.25) 0%,rgba(0,0,0,.55) 60%,rgba(0,0,0,.85) 100%);pointer-events:none}
.thr-def{position:relative;z-index:2;display:flex;flex-direction:column;gap:.6rem;font-family:var(--font-mono);text-shadow:0 2px 24px rgba(0,0,0,.6)}
.thr-term{font-family:var(--font-display);font-size:clamp(72px,12vw,200px);line-height:.95;letter-spacing:-.02em;font-weight:600;mix-blend-mode:difference}
.thr-type{font-style:italic;opacity:.7;font-size:13px}
.thr-pron{opacity:.6;font-size:14px;letter-spacing:.1em}
.thr-text{max-width:540px;margin:1.4rem auto 0;line-height:1.7;opacity:.9;font-family:var(--font-display)}
.thr-enter{margin-top:3rem;display:inline-flex;gap:.6em;align-items:center;font-family:var(--font-mono);font-size:12px;letter-spacing:.3em;text-transform:uppercase;opacity:.6;animation:thrPulse 2.4s ease-in-out infinite}
@keyframes thrPulse{0%,100%{opacity:.4}50%{opacity:.9}}

/* === World 1: Planet Briefing === */
[data-world="planet-briefing"]{padding:0;align-items:stretch;justify-content:stretch}
.brief-stage{position:relative;width:100%;height:100%;perspective:1400px;overflow:hidden}
.planet-canvas{position:absolute;inset:0;z-index:1}
.cards-orbit{position:absolute;inset:0;z-index:2;pointer-events:none;display:flex;align-items:center;justify-content:center}
.cat-card{
  position:absolute;
  width:clamp(180px,18vw,260px);
  height:clamp(240px,24vw,360px);
  border:1px solid rgba(124,92,255,.4);
  background:rgba(2,5,13,.6);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  box-shadow:0 0 40px rgba(124,92,255,.25),inset 0 0 20px rgba(124,92,255,.1);
  transform-style:preserve-3d;
  pointer-events:auto;
  cursor:none!important;
  transition:transform .8s var(--ease-out),opacity .6s,border-color .4s,box-shadow .6s;
  will-change:transform,opacity;
  display:flex;flex-direction:column;
  font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.25em;color:#e6f0ff;
}
.cat-card .cc-img{flex:1;width:100%;height:100%;overflow:hidden;position:relative}
.cat-card .cc-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.8) contrast(1.1)}
.cat-card .cc-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(2,5,13,.9) 100%)}
.cat-card .cc-meta{position:absolute;bottom:14px;left:14px;right:14px;z-index:2;display:flex;justify-content:space-between;align-items:flex-end}
.cat-card .cc-num{opacity:.5;font-size:9px}
.cat-card .cc-label{font-size:11px;letter-spacing:.2em;color:#e6f0ff;text-shadow:0 0 12px rgba(124,92,255,.6)}
.cat-card.is-active{
  border-color:#7c5cff;
  box-shadow:0 0 80px rgba(124,92,255,.6),inset 0 0 30px rgba(124,92,255,.2);
  transform:translate(-50%,-50%) scale(1.15)!important;
}
.cat-card.is-active .cc-label{color:#fff;text-shadow:0 0 20px #7c5cff}
.brief-hud{position:absolute;left:clamp(20px,3vw,40px);top:50%;transform:translateY(-50%);z-index:5;font-family:var(--font-mono);font-size:11px;color:#7c5cff;text-transform:uppercase;letter-spacing:.3em;display:flex;flex-direction:column;gap:6px;pointer-events:none}
.brief-hud b{display:block;color:#fff;font-size:24px;font-weight:500;letter-spacing:.04em;text-transform:none;margin-top:6px}
.brief-readout{position:absolute;right:clamp(20px,3vw,40px);bottom:clamp(60px,8vh,100px);z-index:5;font-family:var(--font-mono);font-size:10px;color:#7c5cff;text-transform:uppercase;letter-spacing:.25em;text-align:right;display:flex;flex-direction:column;gap:4px;pointer-events:none;opacity:.7}

/* HUD scan corner brackets */
.brief-corner{position:absolute;width:32px;height:32px;border:1px solid #7c5cff;z-index:4;pointer-events:none;opacity:.6}
.brief-corner.tl{top:20px;left:20px;border-right:none;border-bottom:none}
.brief-corner.tr{top:20px;right:20px;border-left:none;border-bottom:none}
.brief-corner.bl{bottom:20px;left:20px;border-right:none;border-top:none}
.brief-corner.br{bottom:20px;right:20px;border-left:none;border-top:none}

/* === World 2: Acid Gothic === */
[data-world="acid-gothic"]{flex-direction:column;gap:2rem;background:radial-gradient(circle at 30% 50%,#1a0d2e 0%,#0a0418 100%)}
.acid-stage{position:relative;width:100%;max-width:1400px;height:70vh;display:flex;align-items:center;justify-content:center}
.acid-svg{width:100%;height:100%;overflow:visible}
.acid-svg text{
  font-family:'UnifrakturMaguntia',serif;
  font-size:clamp(80px,18vw,260px);
  fill:url(#acidGrad);
  filter:url(#acidWarp);
  animation:acidShift 6s ease-in-out infinite;
}
@keyframes acidShift{0%,100%{transform:translateY(0) skewX(0)}33%{transform:translateY(-12px) skewX(2deg)}66%{transform:translateY(8px) skewX(-2deg)}}
.acid-tag{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.4em;opacity:.7;color:#ffe066}

/* Curling tendril SVG paths */
.acid-curl{
  position:absolute;
  width:80%;height:80%;
  pointer-events:none;
  opacity:.4;
  mix-blend-mode:screen;
}
.acid-curl path{
  fill:none;stroke:url(#acidGrad);stroke-width:1.5;
  stroke-linecap:round;
  animation:curlPulse 8s ease-in-out infinite;
}
@keyframes curlPulse{
  0%,100%{stroke-dashoffset:0;opacity:.3}
  50%{stroke-dashoffset:-200;opacity:.7}
}

/* === Planet briefing: lock indicator === */
.brief-lock-bar{position:absolute;left:50%;bottom:6vh;transform:translateX(-50%);z-index:6;width:min(420px,46vw);height:2px;background:rgba(124,92,255,.15);overflow:hidden}
.brief-lock-bar::after{content:'';position:absolute;left:0;top:0;bottom:0;width:var(--lock-progress,0%);background:#7c5cff;box-shadow:0 0 12px #7c5cff;transition:width .15s linear}
.brief-lock-text{position:absolute;left:50%;bottom:calc(6vh + 14px);transform:translateX(-50%);z-index:6;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.3em;color:#7c5cff;opacity:.8;white-space:nowrap}

/* === World: Director POV - vertical film strip (replaces 3D cinema) === */
[data-world="director-pov"]{padding:0;align-items:stretch;justify-content:stretch;background:#0a0203}
.dir-stage{position:relative;width:100%;height:100%;overflow:hidden;color:#ffe5d9}
.dir-bg{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse at 50% 50%,#1a0508 0%,#000 80%);pointer-events:none}
.dir-hud{position:absolute;top:0;left:0;right:0;z-index:5;padding:0;pointer-events:none;height:120px}
/* Invisible scroll proxy: tall scrollable area used to capture vertical scroll for reel switching */
.dir-strip-wrap{
  position:absolute;inset:0;
  overflow-y:auto;overflow-x:hidden;
  scrollbar-width:none;
  scroll-behavior:auto;
  z-index:4;
  pointer-events:none; /* lets wheel/click pass through; scroll set programmatically */
}
.dir-strip-wrap::-webkit-scrollbar{display:none}
.dir-strip-spacer{
  width:100%;
  /* tall enough to allow scroll - actual height set by JS based on reel count */
  height:500vh;
}
/* Bring back cinema canvas visible behind */
.dir-stage .cinema-canvas{position:absolute;inset:0;z-index:1;pointer-events:none}
.dir-stage .cinema-canvas canvas{display:block;width:100%;height:100%}
.dir-stage .cinema-vignette{position:absolute;inset:0;z-index:2;background:radial-gradient(ellipse at 50% 50%,transparent 30%,rgba(0,0,0,.6) 80%,rgba(0,0,0,.95) 100%);pointer-events:none}
.dir-stage .cinema-hud{position:absolute;inset:0;z-index:3;pointer-events:none}
.dir-vscroll-hint{position:absolute;right:24px;top:50%;transform:translateY(-50%);width:2px;height:120px;background:rgba(255,255,255,.15);z-index:6;pointer-events:none}
.dir-vscroll-hint::after{content:'';position:absolute;left:-1px;width:4px;height:30px;top:var(--vp,0%);background:var(--w-accent);transition:top .15s linear;box-shadow:0 0 10px var(--w-accent)}
.dir-vscroll-arrow{position:absolute;right:18px;top:calc(50% + 80px);z-index:6;font-family:var(--font-mono);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:#fff;opacity:.55;pointer-events:none;animation:phvHintPulse 2s ease-in-out infinite}

/* Director frame - active (centered) state */
.dir-frame.is-active{border-color:var(--w-accent);box-shadow:0 14px 60px rgba(238,56,43,.6)}

/* Video modal (sample reel viewer) */
#video-modal{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);opacity:0;pointer-events:none;transition:opacity .4s}
#video-modal.is-open{opacity:1;pointer-events:auto}
#video-modal .vm-video{position:relative;width:min(1040px,80vw);max-height:72vh;aspect-ratio:16/9;background:#000;border:1px solid rgba(255,255,255,.2);box-shadow:0 0 80px rgba(238,56,43,.3);display:flex;flex-direction:column;overflow:hidden}
#video-modal video{flex:1;width:100%;min-height:0;display:block;background:#000;cursor:none!important}

/* Custom controls bar */
#video-modal .vm-controls{
  display:flex;align-items:center;gap:14px;
  padding:10px 16px;
  background:rgba(0,0,0,.85);
  border-top:1px solid rgba(255,255,255,.1);
  font-family:var(--font-mono);
  color:#fff;
}
#video-modal .vm-play,#video-modal .vm-mute,#video-modal .vm-fs{
  width:34px;height:34px;border-radius:50%;
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.25);background:transparent;color:#fff;cursor:none!important;
  transition:background .25s,border-color .25s,transform .25s;
  flex-shrink:0;
}
#video-modal .vm-play:hover,#video-modal .vm-mute:hover,#video-modal .vm-fs:hover{background:var(--w-accent);border-color:var(--w-accent);transform:scale(1.08)}
#video-modal .vm-time{font-size:10px;letter-spacing:.15em;color:rgba(255,255,255,.7);min-width:38px;text-align:center}
#video-modal .vm-scrub{
  flex:1;
  appearance:none;-webkit-appearance:none;
  height:4px;border-radius:2px;
  background:linear-gradient(90deg,var(--w-accent) 0%,var(--w-accent) calc(var(--p,0)*100%),rgba(255,255,255,.18) calc(var(--p,0)*100%),rgba(255,255,255,.18) 100%);
  cursor:none!important;outline:none;
}
#video-modal .vm-scrub::-webkit-slider-thumb{
  appearance:none;-webkit-appearance:none;
  width:14px;height:14px;border-radius:50%;
  background:#fff;border:2px solid var(--w-accent);
  box-shadow:0 0 8px var(--w-accent);
  cursor:none!important;
}
#video-modal .vm-scrub::-moz-range-thumb{
  width:14px;height:14px;border-radius:50%;
  background:#fff;border:2px solid var(--w-accent);
  box-shadow:0 0 8px var(--w-accent);cursor:none!important;
}
#video-modal .vm-close,#video-modal .vm-prev,#video-modal .vm-next{
  position:fixed;font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#fff;
  border:1px solid rgba(255,255,255,.3);background:transparent;cursor:none!important;
  transition:background .3s,color .3s,border-color .3s,transform .3s;
}
#video-modal .vm-close{top:24px;right:24px;padding:10px 18px;border-radius:999px}
#video-modal .vm-close:hover{background:#fff;color:#000}
#video-modal .vm-prev,#video-modal .vm-next{
  top:50%;transform:translateY(-50%);
  width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;
  font-size:20px;letter-spacing:0;
}
#video-modal .vm-prev{left:24px}
#video-modal .vm-next{right:24px}
#video-modal .vm-prev:hover,#video-modal .vm-next:hover{background:var(--w-accent);border-color:var(--w-accent);transform:translateY(-50%) scale(1.1)}
#video-modal .vm-title{position:fixed;top:24px;left:24px;font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#fff}
#video-modal .vm-counter{position:fixed;top:48px;left:24px;font-family:var(--font-mono);font-size:10px;letter-spacing:.3em;color:rgba(255,255,255,.5)}
#video-modal .vm-thumbs{
  position:fixed;left:50%;bottom:30px;transform:translateX(-50%);
  display:flex;gap:8px;z-index:2;
  pointer-events:auto;
}
#video-modal .vm-thumb{
  width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(255,255,255,.3);background:transparent;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;
  color:rgba(255,255,255,.6);cursor:none!important;
  transition:background .3s,color .3s,border-color .3s,transform .3s;
}
#video-modal .vm-thumb:hover{color:#fff;border-color:#fff;transform:translateY(-2px)}
#video-modal .vm-thumb.is-active{background:var(--w-accent);border-color:var(--w-accent);color:#fff;box-shadow:0 0 12px var(--w-accent)}
.cinema-stage{position:relative;width:100%;height:100%;overflow:hidden;background:radial-gradient(ellipse at 50% 60%,#1a0508 0%,#000 80%)}
.cinema-canvas{position:absolute;inset:0;z-index:1}
.cinema-canvas canvas{display:block;width:100%;height:100%}
.cinema-vignette{position:absolute;inset:0;z-index:2;background:radial-gradient(ellipse at 50% 50%,transparent 30%,rgba(0,0,0,.6) 80%,rgba(0,0,0,.95) 100%);pointer-events:none}
.cinema-hud{position:absolute;inset:0;z-index:3;pointer-events:none}
.cinema-corner{position:absolute;width:36px;height:36px;border:1px solid #ee382b;opacity:.7}
.cinema-corner.tl{top:24px;left:24px;border-right:none;border-bottom:none}
.cinema-corner.tr{top:24px;right:24px;border-left:none;border-bottom:none}
.cinema-corner.bl{bottom:24px;left:24px;border-right:none;border-top:none}
.cinema-corner.br{bottom:24px;right:24px;border-left:none;border-top:none}
.cinema-meta{position:absolute;left:42px;top:42px;font-family:var(--font-mono);font-size:11px;color:#ffe5d9;text-transform:uppercase;letter-spacing:.3em;display:flex;flex-direction:column;gap:4px}
.cinema-meta b{font-family:var(--font-display);font-size:22px;font-weight:500;letter-spacing:.04em;text-transform:none;color:#fff;text-shadow:0 0 12px rgba(238,56,43,.6);margin-top:4px}
.cinema-now{position:absolute;right:42px;top:42px;font-family:var(--font-mono);font-size:10px;color:#ee382b;text-transform:uppercase;letter-spacing:.3em;text-align:right;display:flex;flex-direction:column;gap:4px}
.cn-line{display:block}
.cinema-now .cn-line:last-child{animation:recBlink 1.4s ease-in-out infinite}
@keyframes recBlink{0%,100%{opacity:.4}50%{opacity:1}}

/* === World 3: Photo (works list) === */
[data-world="photo-kinetic"]{flex-direction:column;align-items:flex-start;justify-content:center;background:var(--w-bg);gap:0;padding:0}
.photo-world{width:100%;height:100%;padding:8vh clamp(40px,6vw,120px);display:flex;flex-direction:column;gap:4vh}
.phw-header{display:flex;flex-direction:column;gap:6px}
.phw-tag{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.4em;opacity:.5}
.phw-title{font-family:var(--font-gothic);font-size:clamp(48px,7vw,120px);line-height:.9;letter-spacing:-.02em;color:var(--w-fg)}
.phw-hint{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.3em;opacity:.4}
.phw-list{
  flex:1;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.4rem;
  align-content:start;
  overflow-y:auto;scrollbar-width:none;
  scroll-behavior:smooth;
  /* visible scroll position indicator on the right */
  background:linear-gradient(90deg,transparent calc(100% - 2px),rgba(0,0,0,.05) calc(100% - 2px));
}
.phw-list::-webkit-scrollbar{display:none}
/* Vertical scroll indicator for photo world */
.phw-vscroll-hint{
  position:absolute;right:24px;top:50%;transform:translateY(-50%);
  width:2px;height:120px;background:rgba(0,0,0,.1);
  z-index:5;pointer-events:none;
}
.phw-vscroll-hint::after{
  content:'';position:absolute;left:-1px;width:4px;height:30px;
  top:var(--vp,0%);background:var(--w-accent);
  transition:top .15s linear;
  box-shadow:0 0 8px var(--w-accent);
}
.phw-vscroll-arrow{
  position:absolute;right:18px;top:calc(50% + 80px);
  font-family:var(--font-mono);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:#0c0c0c;opacity:.5;
  z-index:5;pointer-events:none;
  animation:phvHintPulse 2s ease-in-out infinite;
}
@keyframes phvHintPulse{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(4px);opacity:.85}}
.phw-item{
  position:relative;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  cursor:pointer!important;
  transition:transform .5s var(--ease-out),box-shadow .5s,border-color .4s;
  display:flex;flex-direction:column;
}
.phw-item:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.18);border-color:var(--w-accent)}
.phw-item-cover{position:relative;aspect-ratio:4/3;overflow:hidden;background:#222}
.phw-item-cover img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) contrast(1.05);transition:transform .8s var(--ease-out)}
.phw-item:hover .phw-item-cover img{transform:scale(1.06)}
.phw-reel{
  position:absolute;right:14px;bottom:14px;
  width:48px;height:48px;border-radius:50%;
  background:rgba(0,0,0,.7);border:1px solid #fff;
  display:grid;place-items:center;color:#fff;
  font-family:var(--font-mono);font-size:14px;
  transition:background .3s,transform .3s;
  z-index:2;
}
.phw-item:hover .phw-reel{background:var(--w-accent);transform:scale(1.1)}
.phw-item-meta{padding:14px 16px 18px;display:flex;flex-direction:column;gap:4px;color:#0c0c0c}
.phw-item-cat{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.3em;opacity:.55}
.phw-item-title{font-family:var(--font-display);font-size:18px;font-weight:500;line-height:1.2}
.phw-item-year{font-family:var(--font-mono);font-size:11px;opacity:.5}

/* === Film strip viewer (overlay) === */
.fs-overlay{
  position:fixed;inset:0;z-index:300;
  background:rgba(0,0,0,.95);
  display:none;align-items:center;justify-content:center;
  padding:5vh 5vw;flex-direction:column;gap:3vh;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  opacity:0;transition:opacity .5s;
}
.fs-overlay.is-open{display:flex;opacity:1}
.fs-head{display:flex;justify-content:space-between;align-items:flex-end;width:100%;color:#fff;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.3em}
.fs-head h3{font-family:var(--font-display);font-size:clamp(28px,3.5vw,52px);font-weight:500;letter-spacing:-.02em;text-transform:none;color:#fff}
.fs-head .fs-meta{opacity:.5;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.fs-close{cursor:pointer!important;font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;color:#fff;border:1px solid rgba(255,255,255,.3);padding:10px 18px;border-radius:999px;transition:background .3s,color .3s}
.fs-close:hover{background:#fff;color:#000}

.fs-strip-wrap{
  width:100%;flex:1;
  position:relative;
  overflow:hidden;
  background:#000;
  border-top:6px solid #1a1a1a;border-bottom:6px solid #1a1a1a;
}
.fs-strip{
  display:flex;gap:12px;
  padding:36px 12px;
  height:100%;align-items:center;
  will-change:transform;
}
.fs-frame{
  position:relative;
  flex:0 0 auto;
  height:80%;aspect-ratio:3/4;
  border:2px solid #fff;
  background:#111;
  overflow:hidden;
}
.fs-frame img{width:100%;height:100%;object-fit:cover}
.fs-frame::before,.fs-frame::after{
  content:'';position:absolute;left:0;right:0;
  height:18px;
  background-image:repeating-linear-gradient(90deg,#1a1a1a 0,#1a1a1a 14px,#000 14px,#000 28px);
  background-size:28px 18px;
  z-index:2;
}
.fs-frame::before{top:-22px}
.fs-frame::after{bottom:-22px}
/* sprocket holes top/bottom of strip */
.fs-strip-wrap::before,.fs-strip-wrap::after{
  content:'';position:absolute;left:0;right:0;height:18px;z-index:3;
  background-image:radial-gradient(circle at 14px 9px,#000 0,#000 4px,transparent 5px);
  background-size:28px 18px;
  background-color:#1a1a1a;
}
.fs-strip-wrap::before{top:0}
.fs-strip-wrap::after{bottom:0}

.fs-controls{display:flex;justify-content:center;gap:1.4rem;color:#fff;font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase}
.fs-ctrl{cursor:pointer!important;padding:10px 22px;border:1px solid rgba(255,255,255,.3);border-radius:999px;transition:background .3s,color .3s}
.fs-ctrl:hover{background:#fff;color:#000}

/* === Cinema screen video element === */
.cinema-screen-video{position:absolute;width:0;height:0;overflow:hidden;opacity:0;pointer-events:none}

/* === Cannes Laureate Modal === */
#cannes-modal{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .5s}
#cannes-modal.is-open{opacity:1;pointer-events:auto}
#cannes-modal .cm-back{position:absolute;inset:0;background:radial-gradient(circle at 50% 45%,rgba(60,30,8,.96) 0%,rgba(0,0,0,.99) 80%);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}
#cannes-modal .cm-card{
  position:relative;
  width:min(680px,90vw);
  max-height:88vh;
  padding:60px 56px 44px;
  background:linear-gradient(155deg,#1a0e08 0%,#0a0608 60%,#1a0e08 100%);
  border:1px solid rgba(233,196,122,.4);
  color:#e9c47a;
  box-shadow:0 0 80px rgba(233,196,122,.25), inset 0 0 60px rgba(233,196,122,.05);
  text-align:center;
  font-family:var(--font-display);
  transform:scale(.5);
  opacity:0;
  transition:transform .9s cubic-bezier(.165,.84,.44,1),opacity .9s;
}
#cannes-modal.is-open .cm-card{transform:scale(1);opacity:1}
.cm-corner{position:absolute;width:36px;height:36px;border:1px solid #e9c47a;opacity:.7}
.cm-corner.cm-tl{top:14px;left:14px;border-right:none;border-bottom:none}
.cm-corner.cm-tr{top:14px;right:14px;border-left:none;border-bottom:none}
.cm-corner.cm-bl{bottom:14px;left:14px;border-right:none;border-top:none}
.cm-corner.cm-br{bottom:14px;right:14px;border-left:none;border-top:none}
.cm-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:#c89f5e;margin-bottom:22px}
.cm-palm{font-size:54px;margin-bottom:8px;filter:hue-rotate(20deg) saturate(1.3) drop-shadow(0 0 12px rgba(233,196,122,.6))}
.cm-title{font-family:var(--font-display);font-size:clamp(38px,5vw,72px);letter-spacing:.18em;font-weight:300;color:#fff;text-shadow:0 0 24px rgba(233,196,122,.4);margin-bottom:8px}
.cm-name{font-family:var(--font-display);font-size:clamp(32px,4vw,56px);letter-spacing:.04em;font-weight:600;background:linear-gradient(180deg,#fff 0%,#e9c47a 60%,#9c7a44 100%);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:16px}
.cm-cat{font-family:var(--font-mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:#c89f5e;margin-bottom:28px}
.cm-body{font-family:var(--font-display);font-size:15px;line-height:1.7;color:#d6c4a3;max-width:42ch;margin:0 auto 30px}
.cm-meta{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:#9c7a44;border-top:1px solid rgba(233,196,122,.18);padding-top:18px;margin-bottom:28px}
.cm-close{font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#e9c47a;background:transparent;border:1px solid rgba(233,196,122,.5);border-radius:999px;padding:12px 28px;cursor:none!important;transition:background .3s,color .3s}
.cm-close:hover{background:#e9c47a;color:#0a0608}

/* === World 4: Video Cinema (horizontal scroll-snap) === */
[data-world="video-cinema"]{padding:0;align-items:stretch;justify-content:stretch}
/* Vertical stack for video world - clips fall into view, then zoom in */
.cin-stack{
  position:absolute;inset:0;
  overflow-y:auto;overflow-x:hidden;
  scrollbar-width:none;
  scroll-behavior:smooth;
  perspective:1400px;
  background:#000;
}
.cin-stack::-webkit-scrollbar{display:none}
.cin-clip{
  position:relative;
  width:100vw;height:100vh;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  transform-origin:center center;
  /* zoom-in is driven by JS scroll position */
}
.cin-clip-inner{
  position:absolute;inset:0;
  transform-origin:center center;
  will-change:transform,opacity;
}
.cin-clip img,.cin-clip video{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.85)}
.cin-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,transparent 30%,transparent 70%,rgba(0,0,0,.6) 100%);pointer-events:none}
.cin-cap{position:absolute;left:clamp(24px,4vw,80px);bottom:clamp(40px,6vw,80px);font-family:var(--font-mono);font-size:12px;color:#fff;letter-spacing:.18em;text-transform:uppercase;display:flex;flex-direction:column;gap:6px;z-index:3}
.cin-cap b{font-family:var(--font-display);font-size:clamp(28px,4vw,64px);font-weight:500;letter-spacing:-.01em;text-transform:none}

/* Vertical scroll hint for video */
.cin-vscroll-hint{
  position:absolute;right:24px;top:50%;transform:translateY(-50%);
  width:2px;height:120px;background:rgba(255,255,255,.15);
  z-index:6;pointer-events:none;
}
.cin-vscroll-hint::after{
  content:'';position:absolute;left:-1px;width:4px;height:30px;
  top:var(--vp,0%);background:var(--w-accent);
  transition:top .15s linear;box-shadow:0 0 10px var(--w-accent);
}
.cin-vscroll-arrow{
  position:absolute;right:18px;top:calc(50% + 80px);z-index:6;
  font-family:var(--font-mono);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:#fff;opacity:.5;
  pointer-events:none;
  animation:phvHintPulse 2s ease-in-out infinite;
}

/* === World 5: Manifesto === */
[data-world="manifesto"]{flex-direction:column;padding:8vh clamp(40px,8vw,200px);background:#000!important;color:#fff;align-items:flex-start;justify-content:center}
.man-text{font-family:var(--font-mono);font-size:clamp(16px,1.5vw,22px);line-height:1.9;max-width:62ch;white-space:pre-wrap;position:relative}
.man-text::after{content:'_';animation:caret 1s steps(2) infinite;color:#fff}
@keyframes caret{50%{opacity:0}}
.man-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.4em;opacity:.4;margin-bottom:3rem}

/* === World 6: Exit === */
[data-world="exit"]{flex-direction:column;text-align:center;gap:1.5rem}
.exit-mark{font-family:var(--font-display);font-size:clamp(48px,8vw,120px);font-weight:500;letter-spacing:-.02em}
.exit-line{font-family:var(--font-mono);font-size:11px;opacity:.5;letter-spacing:.3em;text-transform:uppercase}
.exit-actions{display:flex;gap:1.4rem;margin-top:2rem;flex-wrap:wrap;justify-content:center}
.exit-btn{padding:14px 28px;border:1px solid var(--w-fg);border-radius:999px;font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;transition:background .35s,color .35s,border-color .35s}
.exit-btn:hover{background:var(--w-fg);color:var(--w-bg)}
.exit-btn.primary{background:var(--w-accent);border-color:var(--w-accent);color:var(--w-bg)}

/* Reveal */
.rv{opacity:0;transform:translateX(40px);transition:opacity 1.2s var(--ease-out),transform 1.2s var(--ease-out)}
.rv.is-in{opacity:1;transform:none}

/* Mobile */
@media(max-width:760px){
  #trip-logo{font-size:14px}
  #trip-title{font-size:9px}
  .kin-stack{font-size:clamp(40px,12vw,100px)}
  .kin-grid{grid-template-columns:repeat(2,1fr)}
  .cat-card{width:60vw;height:80vw}
  #trip-webgl{opacity:.4}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.2s!important}
  #trip-webgl,.trip-grain{display:none}
}
