/* ═══════════════════════════════════════════════════════════════
   KPR Experience v3.0 — Cinematic CSS
   12 Designwelten · Browser-Mockups · 20 interactive systems
   ═══════════════════════════════════════════════════════════════ */

/* ─── Fonts ───────────────────────────────────────────────── */
@font-face{font-family:'Inter';src:url('/fonts/Inter-Regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Inter';src:url('/fonts/Inter-Bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Space Grotesk';src:url('/fonts/SpaceGrotesk-Bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Playfair Display';src:url('/fonts/PlayfairDisplay-Bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'EB Garamond';src:url('/fonts/EBGaramond-Regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'IBM Plex Mono';src:url('/fonts/IBMPlexMono-Regular.woff2') format('woff2');font-weight:400;font-display:swap}

/* ─── Custom Properties ───────────────────────────────────── */
:root{
  --font-body:'Inter',system-ui,sans-serif;
  --font-display:'Space Grotesk','Inter',sans-serif;
  --font-serif:'Playfair Display','EB Garamond',Georgia,serif;
  --font-mono:'IBM Plex Mono',monospace;
  --kpr-bright:#00E5FF;--kpr-accent:#FF3DDE;
  --bg-1:#0A0A0F;--bg-2:#12121A;--bg-3:#1A1A25;
  --text-1:#F0F0F5;--text-2:#A0A0B0;--text-3:#606070;
  --radius:16px;--radius-sm:8px;--radius-xs:4px;
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
}

/* ─── Reset & Base ────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
.exp-body{background:var(--bg-1);color:var(--text-1);font-family:var(--font-body);overflow:hidden;height:100vh;width:100vw;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
::selection{background:var(--kpr-bright);color:var(--bg-1)}

/* ─── Canvas ──────────────────────────────────────────────── */
#exp-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.4}

/* ═══════════════════════════════════════════════════════════════
   CUSTOM CURSOR
   ═══════════════════════════════════════════════════════════════ */
.custom-cursor,.custom-cursor *{cursor:none!important}
.cursor-wrap{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;mix-blend-mode:difference}
.cursor-dot{position:absolute;width:8px;height:8px;background:#fff;border-radius:50%;transition:opacity .15s}
.cursor-ring{position:absolute;width:44px;height:44px;border:2px solid rgba(255,255,255,.35);border-radius:50%;transition:border-color .4s}
@media(pointer:coarse){.cursor-wrap{display:none}.custom-cursor,.custom-cursor *{cursor:auto!important}}

/* ═══════════════════════════════════════════════════════════════
   BOOT SEQUENCE
   ═══════════════════════════════════════════════════════════════ */
.boot-seq{position:fixed;inset:0;z-index:10000;background:#000;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);color:#00FF41;transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
.boot-seq.boot-exit{opacity:0;transform:scale(1.15);pointer-events:none}
.boot-inner{max-width:480px;width:90%}
.boot-logo{font-size:clamp(1.2rem,3vw,1.6rem);letter-spacing:.3em;margin-bottom:2rem;text-shadow:0 0 20px rgba(0,255,65,.4);animation:fadeInUp .6s var(--ease-out) both}
.boot-line{font-size:.68rem;line-height:2;opacity:0;animation:fadeInUp .3s var(--ease-out) forwards;color:#40FF70}
.boot-line:nth-child(odd){color:#00FF41}
.boot-bar-wrap{height:4px;background:rgba(0,255,65,.1);border-radius:2px;margin:1.5rem 0 1rem;overflow:hidden}
.boot-bar{height:100%;background:linear-gradient(90deg,#00FF41,#40FF70);border-radius:2px;width:0;transition:width .25s var(--ease-out);box-shadow:0 0 12px rgba(0,255,65,.5)}
#boot-status{font-size:.75rem;color:#00FF41;text-shadow:0 0 10px rgba(0,255,65,.3);min-height:1.2em}

/* ═══ INTRO ═══════════════════════════════════════════════════ */
.exp-intro{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:var(--bg-1);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.exp-intro.hidden{opacity:0;transform:scale(1.05);pointer-events:none}
.intro-grain{position:absolute;inset:0;background: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='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.08'/%3E%3C/svg%3E");opacity:.5;pointer-events:none}
.intro-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.5;animation:orbFloat 10s ease-in-out infinite}
.intro-orb--1{width:500px;height:500px;background:radial-gradient(circle,rgba(0,229,255,.35),transparent);top:-10%;left:-5%;animation-delay:0s}
.intro-orb--2{width:400px;height:400px;background:radial-gradient(circle,rgba(255,61,222,.25),transparent);bottom:-10%;right:-5%;animation-delay:-3s}
.intro-orb--3{width:300px;height:300px;background:radial-gradient(circle,rgba(88,80,236,.3),transparent);top:50%;left:50%;animation-delay:-6s}
.intro-sweep{position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(0,229,255,.04) 50%,transparent 60%);animation:sweep 4s linear infinite}
.intro-content{position:relative;text-align:center;max-width:clamp(500px,60vw,1000px);padding:2rem}
.intro-eyebrow{display:block;font-family:var(--font-mono);font-size:clamp(.7rem,.9vw,.85rem);color:var(--kpr-bright);letter-spacing:.25em;text-transform:uppercase;margin-bottom:1.5rem}
.intro-headline{font-family:var(--font-display);font-size:clamp(2.5rem,7vw,7rem);line-height:1.05;margin-bottom:1.5rem;background:linear-gradient(135deg,var(--text-1) 30%,var(--kpr-bright) 50%,var(--text-1) 70%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:textShine 4s linear infinite}
.intro-line{display:block}
.intro-sub{font-size:clamp(.95rem,1.5vw,1.4rem);color:var(--text-2);line-height:1.6;margin-bottom:2rem;max-width:clamp(400px,40vw,700px);margin-inline:auto}
.intro-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem}
.intro-meta{font-size:.8rem;color:var(--text-3);font-family:var(--font-mono)}
.intro-hint{display:block;margin-top:2.5rem;color:var(--text-3);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;animation:float 2.5s ease-in-out infinite}
.intro-hint::after{content:'';display:block;width:20px;height:20px;margin:12px auto 0;border-right:2px solid var(--text-3);border-bottom:2px solid var(--text-3);transform:rotate(45deg);animation:bounceArrow 2s ease-in-out infinite}
.anim-intro{opacity:0;transform:translateY(30px)}
.anim-intro.anim-intro--go{animation:fadeInUp .8s var(--ease-out) forwards}
/* Fallback: if JS fails to add --go class, show content after 4s */
@keyframes introFallback{0%,99%{opacity:0;transform:translateY(30px)}100%{opacity:1;transform:translateY(0)}}
.anim-intro:not(.anim-intro--go){animation:introFallback 0s 4s forwards}

/* ═══ HUD ═════════════════════════════════════════════════════ */
.exp-hud{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:rgba(10,10,15,.7);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06);opacity:0;transform:translateY(-100%);transition:all .5s var(--ease-out)}
.exp-hud.visible{opacity:1;transform:translateY(0)}
.hud-logo{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--text-1)}
.hud-logo span{color:var(--kpr-bright)}
.hud-progress{display:flex;align-items:center;gap:.75rem}
.hud-progress-track{width:120px;height:3px;border-radius:2px;background:rgba(255,255,255,.1);overflow:hidden}
.hud-progress-fill{height:100%;background:linear-gradient(90deg,var(--kpr-bright),var(--kpr-accent));border-radius:2px;transition:width .6s var(--ease-out);width:8.33%}
.hud-progress-label{font-family:var(--font-mono);font-size:.75rem;color:var(--text-3);min-width:40px}
.hud-actions{display:flex;gap:.5rem}

/* ═══ BUTTONS ═════════════════════════════════════════════════ */
.exp-btn{display:inline-flex;align-items:center;justify-content:center;padding:.65rem 1.5rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;letter-spacing:.03em;transition:all .3s var(--ease-out);white-space:nowrap;position:relative;overflow:hidden;will-change:transform}
.exp-btn--primary{background:linear-gradient(135deg,var(--kpr-bright),#00B8D4);color:var(--bg-1);box-shadow:0 0 20px rgba(0,229,255,.2)}
.exp-btn--primary::before{content:'';position:absolute;inset:-2px;border-radius:inherit;background:linear-gradient(135deg,var(--kpr-bright),var(--kpr-accent),var(--kpr-bright));background-size:300% 300%;opacity:0;transition:opacity .4s;animation:gradientShift 4s ease infinite;z-index:-1}
.exp-btn--primary:hover{transform:translateY(-2px);box-shadow:0 0 30px rgba(0,229,255,.4)}
.exp-btn--primary:hover::before{opacity:1}
.exp-btn--ghost{background:transparent;color:var(--text-2);border:1px solid rgba(255,255,255,.12)}
.exp-btn--ghost:hover{color:var(--text-1);border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.04)}
.exp-btn--lg{padding:.85rem 2rem;font-size:.95rem;border-radius:var(--radius)}
.exp-btn--sm{padding:.45rem 1rem;font-size:.78rem}
.exp-btn--nav{padding:.45rem .8rem;font-size:.82rem}

/* Ripple FX */
.ripple-fx{position:absolute;border-radius:50%;background:rgba(255,255,255,.2);transform:scale(0);animation:rippleExpand .6s ease-out forwards;pointer-events:none;z-index:5}

/* ═══ TRANSITION ══════════════════════════════════════════════ */
.exp-transition{position:fixed;inset:0;z-index:80;pointer-events:none;display:flex}
.wipe-panel{flex:1;background:var(--bg-1);transform:scaleY(0);transform-origin:top;transition:none}
.exp-transition.playing .wipe-panel{animation:wipeIn .35s var(--ease-out) forwards,wipeOut .35s var(--ease-out) .4s forwards}
.exp-transition.playing .wipe-panel:nth-child(2){animation-delay:.04s,.44s}
.exp-transition.playing .wipe-panel:nth-child(3){animation-delay:.08s,.48s}
.exp-transition.playing .wipe-panel:nth-child(4){animation-delay:.12s,.52s}
.exp-transition.playing .wipe-panel:nth-child(5){animation-delay:.16s,.56s}
.exp-transition-label{position:fixed;top:50%;left:50%;z-index:81;transform:translate(-50%,-50%);font-family:var(--font-display);font-size:clamp(1.5rem,4vw,2.5rem);color:var(--text-1);letter-spacing:.15em;text-transform:uppercase;opacity:0;pointer-events:none}
.exp-transition-label.visible{animation:labelPop .7s var(--ease-spring) forwards}

/* ═══ SCENES — BASE ═══════════════════════════════════════════ */
.exp-scenes{position:fixed;inset:0;z-index:10}
.exp-scene{position:absolute;inset:0;opacity:0;visibility:hidden;transform:scale(.98);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out),visibility .6s;display:flex;align-items:center;justify-content:center;overflow:hidden}
.exp-scene.active{opacity:1;visibility:visible;transform:scale(1)}
.exp-scene.leaving{opacity:0;visibility:hidden;transform:scale(1.04)}
.scene-bg{position:absolute;inset:0;z-index:0}
.exp-scene.active .scene-bg{animation:breathe 8s ease-in-out infinite}
.scene-inner{position:relative;z-index:1;width:100%;max-width:clamp(320px,92vw,2800px);padding:calc(48px + clamp(.5rem,2vh,2rem)) clamp(1rem,5vw,6rem) calc(2rem + 44px + clamp(.5rem,2vh,1.5rem));margin:0 auto;min-height:80vh;display:flex;flex-direction:column;justify-content:center;box-sizing:border-box}
.scene-inner--split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,10rem);align-items:center}
.scene-inner--center{display:flex;flex-direction:column;align-items:center;text-align:center;justify-content:center}
.scene-tag{display:inline-block;font-family:var(--font-mono);font-size:clamp(.68rem,1vw,.95rem);color:var(--kpr-bright);letter-spacing:.2em;text-transform:uppercase;margin-bottom:clamp(.5rem,1.5vh,1.2rem)}
.exp-scene.active .scene-tag{animation:tagPulse 3s ease-in-out infinite}
.scene-h1{font-family:var(--font-display);font-size:clamp(2rem,5vw,5rem);line-height:1.1;margin-bottom:clamp(1rem,2vh,2rem);min-height:1.2em}
.scene-sub{font-size:clamp(.88rem,1.4vw,1.35rem);color:var(--text-2);line-height:1.65;margin-bottom:clamp(1rem,2vh,2rem);max-width:clamp(320px,35vw,650px)}
.scene-chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{display:inline-block;padding:clamp(.25rem,.5vh,.5rem) clamp(.6rem,1vw,1.2rem);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:999px;font-size:clamp(.68rem,.9vw,.88rem);color:var(--text-2);font-family:var(--font-mono);transition:all .2s;cursor:default}
.chip.selected{background:rgba(0,229,255,.15);border-color:var(--kpr-bright);color:var(--kpr-bright)}

/* Stagger animations for scene elements */
.exp-scene.active .anim-el{opacity:0;animation:sceneElIn .7s var(--ease-out) forwards}
.exp-scene.active .anim-el:nth-child(1){animation-delay:.15s}
.exp-scene.active .anim-el:nth-child(2){animation-delay:.3s}
.exp-scene.active .anim-el:nth-child(3){animation-delay:.45s}
.exp-scene.active .anim-el:nth-child(4){animation-delay:.6s}
.exp-scene.active .anim-el:nth-child(5){animation-delay:.75s}
.exp-scene.leaving .anim-el{opacity:0}

/* ═══════════════════════════════════════════════════════════════
   BROWSER MOCKUP — reusable component with 3D tilt
   ═══════════════════════════════════════════════════════════════ */
.mockup{border-radius:clamp(10px,1.2vw,20px);overflow:hidden;box-shadow:0 25px 80px rgba(0,0,0,.5),0 8px 20px rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.08);max-width:clamp(320px,42vw,900px);width:100%;transition:transform .25s ease-out,box-shadow .4s;will-change:transform;transform-style:preserve-3d}
.mockup:hover{box-shadow:0 35px 100px rgba(0,0,0,.6),0 15px 40px rgba(0,0,0,.35)}
.exp-scene.active .mockup{animation:mockupIn .9s var(--ease-spring) .3s both}
.exp-scene.active .s1-mockup{animation:none}
.mockup-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.05)}
.mockup-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.12)}
.mockup-dot:first-child{background:#FF5F57}
.mockup-dot:nth-child(2){background:#FEBC2E}
.mockup-dot:nth-child(3){background:#28C840}
.mockup-url{margin-left:auto;font-family:var(--font-mono);font-size:.6rem;color:var(--text-3);background:rgba(255,255,255,.04);padding:3px 10px;border-radius:4px}
.mockup-body{min-height:clamp(260px,35vh,550px);position:relative;overflow:hidden}
/* Shimmer sweep on mockup body */
.mockup-body::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);transform:skewX(-15deg);animation:shimmerSweep 5s ease-in-out infinite;pointer-events:none;z-index:10}

/* Bar variants */
.mockup-bar--dark{background:rgba(20,20,30,.95);border-color:rgba(255,255,255,.04)}
.mockup-bar--terminal{background:#1a1a2e}
.mockup-bar--playful{background:linear-gradient(90deg,#FF6B9D10,#C44EFF10,#00D2FF10)}
.mockup-bar--editorial{background:#f5f0e8;border-color:#e0d8c8}
.mockup-bar--editorial .mockup-dot{opacity:.5}
.mockup-bar--editorial .mockup-url{color:#8a7d6b;background:rgba(0,0,0,.04)}
.mockup-bar--nature{background:linear-gradient(90deg,#F5EDE3,#EDE5D8);border-color:#DDD5C8}
.mockup-bar--nature .mockup-dot{opacity:.6}
.mockup-bar--nature .mockup-url{color:#6B7B5C;background:rgba(0,0,0,.04)}

.mockup--dark{border-color:rgba(255,255,255,.04)}
.mockup--playful{border-radius:16px;border-color:rgba(255,107,157,.15)}
.mockup--terminal{border-color:#1a332a;box-shadow:0 25px 80px rgba(0,60,30,.4),0 0 40px rgba(0,255,65,.06)}
.mockup--editorial{border-color:#ddd5c8;box-shadow:0 25px 60px rgba(0,0,0,.25)}
.mockup--nature{border-color:#c8d5b8;box-shadow:0 25px 60px rgba(40,80,20,.2)}

/* 3D Tilt on special elements too */
.s6-hud,.s8-composition,.s11-glass-grid{transition:transform .25s ease-out;will-change:transform;transform-style:preserve-3d}

/* ═══════════════════════════════════════════════════════════════
   SCENE 1 — MINIMALIST
   ═══════════════════════════════════════════════════════════════ */
.s1-bg{position:absolute;inset:0;background:linear-gradient(170deg,#0D0D14 0%,#0F0F18 40%,#111118 100%)}
.s1-gradient{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(255,255,255,.01),transparent)}
.s1-shape{position:absolute;border:1px solid rgba(255,255,255,.03);border-radius:50%;animation:orbit 30s linear infinite}
.s1-shape--1{width:clamp(250px,30vw,600px);height:clamp(250px,30vw,600px);top:5%;right:-5%}
.s1-shape--2{width:clamp(120px,15vw,300px);height:clamp(120px,15vw,300px);bottom:15%;left:5%;animation-delay:-10s;animation-duration:20s}
.s1-shape--3{width:clamp(40px,5vw,80px);height:clamp(40px,5vw,80px);top:50%;left:40%;background:rgba(0,229,255,.03);animation-delay:-20s}

/* ── S1 Layout — Direct Fullscreen (no window frame) ────── */
/* HUD top ~48px, Nav bottom ~60px from edge + ~40px height */
.s1-layout{display:flex;flex-direction:column;align-items:center;justify-content:space-between;width:100%;max-width:100%;height:100vh;height:100dvh;padding:calc(48px + .5rem) 0 calc(2rem + 44px + .5rem);position:relative;z-index:1;box-sizing:border-box}

/* Top: Tag + Headline */
.s1-top{text-align:center;flex-shrink:0;padding:0 clamp(.5rem,2vw,2rem)}
.s1-top .scene-tag{margin-bottom:clamp(.1rem,.2vh,.2rem);font-size:clamp(.55rem,.9vw,.95rem)}
.s1-top .scene-h1{margin-bottom:clamp(.05rem,.1vh,.1rem);font-size:clamp(1.1rem,2.5vw,3.5rem)}
.s1-top .scene-sub{color:var(--text-2);font-size:clamp(.5rem,.85vw,1rem);margin:0 auto}

/* Center: Design fills ALL remaining space — no frame */
.s1-center{flex:1;display:flex;align-items:stretch;justify-content:center;width:100%;min-height:0;overflow:hidden;padding:clamp(.15rem,.25vh,.25rem) 0}

/* S1 Mockup: frameless, borderless, fills entire center */
.s1-mockup{max-width:100%!important;width:100%!important;max-height:100%;display:flex;flex-direction:column;border-radius:0!important;box-shadow:none!important;border:none!important}
.s1-mockup .mockup-bar{display:none!important}
.s1-mockup .mockup-body{flex:1;min-height:0}
.s1-mockup:hover{box-shadow:none!important}

/* Mockup internals — scale with viewport */
.mockup-body--s1{background:#FAFAFA;color:#1a1a1a;padding:0;position:relative;display:flex;flex-direction:column}
.s1m-nav{display:flex;justify-content:space-between;align-items:center;padding:clamp(6px,1vh,16px) clamp(10px,2vw,28px);border-bottom:1px solid #eee;flex-shrink:0}
.s1m-logo{font-family:var(--font-display);font-size:clamp(.7rem,1.2vw,1.6rem);font-weight:700;color:#111}
.s1m-links{font-size:clamp(.4rem,.7vw,.85rem);color:#888;letter-spacing:.1em}
.s1m-hero{display:flex;align-items:center;justify-content:space-between;padding:clamp(10px,3vh,48px) clamp(10px,2vw,28px);flex:1;min-height:0}
.s1m-hero-text{font-family:var(--font-display);font-size:clamp(1rem,3vw,4rem);line-height:1.1;font-weight:700;color:#111}
.s1m-hero-text em{font-style:normal;color:#0066FF}
.s1m-hero-circle{width:clamp(28px,6vw,120px);height:clamp(28px,6vw,120px);border-radius:50%;background:linear-gradient(135deg,#0066FF,#00AAFF);flex-shrink:0;animation:pulse 3s ease-in-out infinite}
.s1m-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:clamp(3px,.8vw,12px);padding:0 clamp(10px,2vw,28px) clamp(6px,1.2vh,18px);flex-shrink:0}
.s1m-card{height:clamp(24px,6vh,100px);border-radius:clamp(3px,.5vw,10px);background:#F0F0F0;transition:all .3s var(--ease-out);position:relative;overflow:hidden}
.s1m-card:hover{transform:translateY(-2px)}
.s1m-card--accent{background:linear-gradient(135deg,#0066FF,#00AAFF)}
.s1m-card--interactive{cursor:pointer}
.s1m-card--interactive:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,.1)}
.s1m-card--interactive.expanded{height:clamp(48px,12vh,180px)}
.s1m-card-label{position:absolute;bottom:clamp(3px,.5vh,8px);left:clamp(4px,.6vw,12px);font-size:clamp(.4rem,.65vw,.75rem);font-weight:600;color:#555;opacity:0;transition:opacity .3s}
.s1m-card--interactive:hover .s1m-card-label,.s1m-card--interactive.expanded .s1m-card-label{opacity:1}
.s1m-card--accent .s1m-card-label{color:#fff}
.s1m-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;border-top:1px solid #eee;flex-shrink:0}
.s1m-stat{text-align:center;padding:clamp(4px,1.2vh,16px) clamp(3px,.8vw,10px);background:#FAFAFA}
.s1m-stat-val{display:block;font-family:var(--font-display);font-size:clamp(.65rem,1.5vw,2rem);font-weight:700;color:#111;font-variant-numeric:tabular-nums}
.s1m-stat-lbl{display:block;font-size:clamp(.35rem,.6vw,.7rem);color:#888;letter-spacing:.05em;margin-top:1px}
.s1m-footer{display:flex;justify-content:space-between;align-items:center;padding:clamp(4px,1vh,14px) clamp(10px,2vw,28px);border-top:1px solid #eee;background:#fff;flex-shrink:0}
.s1m-footer-text{font-size:clamp(.35rem,.7vw,.75rem);color:#999;font-style:italic}
.s1m-footer-btn{font-size:clamp(.35rem,.7vw,.75rem);color:#0066FF;font-weight:600;cursor:pointer;transition:color .2s}
.s1m-footer-btn:hover{color:#0044CC}

/* Clean Glow — S1 gets subtle border glow instead of shadow */
.mockup.clean-glow{box-shadow:0 20px 60px rgba(0,102,255,.2),0 0 30px rgba(0,229,255,.1)!important;border-color:rgba(0,229,255,.2)!important;transition:box-shadow 1s var(--ease-out),border-color 1s}
.s1-mockup.clean-glow{box-shadow:none!important;border:none!important}

/* ── Clutter Items — viewport-scaled positions ──────────── */
.s1-clutter-item{position:absolute;padding:clamp(5px,1vh,14px) clamp(6px,1.2vw,18px);border-radius:clamp(6px,.5vw,10px);font-size:clamp(.45rem,.8vw,.85rem);color:#1a1a1a;cursor:pointer;animation:clutterIn .5s var(--ease-spring) both;transition:transform .3s var(--ease-spring),opacity .3s;display:flex;align-items:center;gap:clamp(2px,.3vw,6px);font-weight:600;box-shadow:0 4px 12px rgba(0,0,0,.2);z-index:2}
.s1-clutter-item:hover{transform:scale(1.08);box-shadow:0 6px 18px rgba(0,0,0,.25)}
.s1-clutter-item.removing{transform:scale(0) rotate(20deg);opacity:0}
.s1-cl-x{font-size:clamp(.6rem,1vw,1.2rem);opacity:.5;margin-left:clamp(2px,.3vw,6px);transition:opacity .2s}
.s1-clutter-item:hover .s1-cl-x{opacity:1}
.s1-cl--cookie{bottom:0;left:0;right:0;background:#FFF3CD;border:1px solid #FFE69C;border-radius:0;animation-delay:.2s}
.s1-cl--popup{top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#FF6B6B,#FF3D3D);color:#fff;padding:clamp(8px,1.5vh,22px) clamp(10px,2vw,28px);border-radius:clamp(8px,.6vw,14px);font-size:clamp(.5rem,.9vw,.95rem);box-shadow:0 8px 24px rgba(255,61,61,.3);animation-delay:.5s;z-index:4}
.s1-cl--chat{bottom:clamp(40px,8vh,100px);right:clamp(6px,1vw,16px);background:#4CAF50;color:#fff;border-radius:clamp(12px,1vw,20px) clamp(12px,1vw,20px) 4px clamp(12px,1vw,20px);animation-delay:.8s}
.s1-cl--banner{top:55%;left:clamp(4px,.8vw,12px);background:linear-gradient(135deg,#FF9800,#F57C00);color:#fff;border-radius:clamp(6px,.5vw,10px);animation-delay:1s}
.s1-cl--video{top:clamp(4px,.6vh,10px);right:clamp(4px,.8vw,12px);background:linear-gradient(135deg,#E53935,#C62828);color:#fff;border-radius:clamp(6px,.5vw,10px);animation-delay:.3s}
.s1-cl--social{bottom:clamp(70px,14vh,160px);left:clamp(4px,.8vw,12px);background:linear-gradient(135deg,#1877F2,#1565C0);color:#fff;border-radius:clamp(8px,.6vw,14px) clamp(8px,.6vw,14px) clamp(8px,.6vw,14px) 4px;animation-delay:.6s}
.s1-cl--notif{top:35%;right:clamp(4px,.8vw,12px);background:#333;color:#fff;border-radius:clamp(6px,.5vw,10px);animation-delay:.9s;box-shadow:0 4px 12px rgba(0,0,0,.3)}
.s1-cl--survey{top:20%;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#9C27B0,#7B1FA2);color:#fff;border-radius:clamp(6px,.5vw,10px);animation-delay:1.1s;z-index:3}

/* ── Score Overlay (inside mockup) ────────────────────────── */
.s1-score-overlay{position:absolute;inset:0;background:rgba(250,250,250,.96);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(.4rem,1.2vh,1.5rem);z-index:10;animation:fadeInUp .5s var(--ease-out)}
.s1-score-overlay[hidden]{display:none}
.s1-score-grade{font-family:var(--font-display);font-size:clamp(2rem,6vw,7rem);font-weight:700;background:linear-gradient(135deg,#0066FF,#00AAFF);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.s1-score-details{display:flex;gap:clamp(.8rem,2.5vw,3rem)}
.s1-score-row{display:flex;flex-direction:column;align-items:center;gap:.2rem}
.s1-score-row span:first-child{font-family:var(--font-mono);font-size:clamp(.45rem,.8vw,.85rem);color:#888;text-transform:uppercase;letter-spacing:.1em}
.s1-score-row span:last-child{font-weight:700;color:#111;font-size:clamp(.6rem,1.2vw,1.3rem)}
.s1-retry-btn{margin-top:clamp(.2rem,.5vh,.6rem);background:rgba(0,102,255,.08);border:1px solid rgba(0,102,255,.2);color:#0066FF;padding:clamp(.25rem,.6vh,.6rem) clamp(.6rem,1.5vw,1.5rem);border-radius:var(--radius-sm);font-size:clamp(.55rem,.9vw,.9rem);font-family:var(--font-mono);cursor:pointer;transition:all .25s}
.s1-retry-btn:hover{background:rgba(0,102,255,.15);transform:scale(1.05)}

/* ── Bottom HUD Bar ───────────────────────────────────────── */
.s1-hud{flex-shrink:0;width:100%;max-width:100%;display:flex;align-items:center;justify-content:space-between;gap:clamp(.4rem,1.5vw,2.5rem);padding:clamp(.25rem,.6vh,.6rem) clamp(.8rem,2vw,2.5rem);background:rgba(255,255,255,.04);border-top:1px solid rgba(255,255,255,.06);border-radius:0;font-family:var(--font-mono)}
.s1-hud-left{display:flex;align-items:center;gap:clamp(.3rem,1vw,1rem);flex:1;min-width:0}
.s1-hud-label{font-size:clamp(.5rem,.8vw,.9rem);color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .5s}
.s1-hud-label.completed{color:#4ADE80}
.s1-hud-meter{flex:1;height:clamp(3px,.5vh,6px);background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden;min-width:60px}
.s1-hud-meter-fill{height:100%;width:0;background:linear-gradient(90deg,var(--kpr-bright),#00B8D4);border-radius:3px;transition:width .6s var(--ease-out)}
.s1-hud.done .s1-hud-meter-fill{background:linear-gradient(90deg,#4ADE80,#22C55E)}
.s1-hud-pct{font-size:clamp(.55rem,.95vw,1rem);font-weight:700;color:var(--kpr-bright);min-width:2.5rem;text-align:right;transition:color .5s}
.s1-hud.done .s1-hud-pct{color:#4ADE80}
.s1-hud-right{display:flex;align-items:center;gap:clamp(.25rem,.7vw,.8rem);flex-shrink:0}
.s1-hud-timer{font-size:clamp(.65rem,1.2vw,1.4rem);font-weight:700;color:var(--kpr-bright);font-variant-numeric:tabular-nums}
.s1-hud-best{font-size:clamp(.45rem,.8vw,.85rem);color:#4ADE80;display:flex;align-items:center;gap:.2rem}
.s1-hud-best em{font-style:normal;font-weight:700}

/* ═══════════════════════════════════════════════════════════════
   SCENE 2 — ELEGANT
   ═══════════════════════════════════════════════════════════════ */
.s2-bg{position:absolute;inset:0;background:linear-gradient(160deg,#0D0A07,#1A1510,#0D0A07)}
.s2-shimmer{position:absolute;inset:0;background:radial-gradient(ellipse 50% 40% at 60% 40%,rgba(212,175,55,.06),transparent)}
.s2-light{position:absolute;width:200px;height:200px;top:20%;right:15%;background:radial-gradient(circle,rgba(212,175,55,.08),transparent);border-radius:50%;filter:blur(40px);animation:float 8s ease-in-out infinite}
.s2-services{list-style:none;display:grid;gap:.4rem;font-size:.85rem;color:var(--text-2)}
.s2-services li::before{content:'—';color:#D4AF37;margin-right:.5rem}

/* Elegant Mockup */
.mockup-body--s2{background:linear-gradient(170deg,#1a1510,#0d0a07);padding:0}
.s2m-hero{position:relative;min-height:clamp(180px,25vh,400px);overflow:hidden;background:linear-gradient(135deg,#2a2015,#1a1510)}
.s2m-overlay{position:absolute;inset:0;background:linear-gradient(to top,#0d0a07,transparent 50%)}
.s2m-text{position:absolute;bottom:16px;left:18px;z-index:1}
.s2m-label{display:block;font-family:var(--font-mono);font-size:.5rem;color:#D4AF37;letter-spacing:.3em;margin-bottom:4px}
.s2m-title{display:block;font-family:var(--font-serif);font-size:clamp(1.1rem,2vw,2.2rem);color:#F5F0E8;margin-bottom:2px}
.s2m-location{display:block;font-size:.6rem;color:#A09080}
.s2m-divider{display:block;width:30px;height:1px;background:#D4AF37;margin:8px 0;transition:width .6s}
.mockup-body--s2:hover .s2m-divider{width:60px}
.s2m-price{display:block;font-family:var(--font-mono);font-size:.65rem;color:#D4AF37}
.s2m-nav{display:flex;justify-content:center;gap:1.5rem;padding:12px;border-top:1px solid rgba(212,175,55,.1);font-size:.55rem;color:#A09080;letter-spacing:.12em;text-transform:uppercase}

/* ═══════════════════════════════════════════════════════════════
   SCENE 3 — CREATIVE
   ═══════════════════════════════════════════════════════════════ */
.s3-bg{position:absolute;inset:0;background:linear-gradient(135deg,#150520,#0A0A1A,#051520)}
.s3-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:orbFloat 12s ease-in-out infinite}
.s3-blob--1{width:300px;height:300px;background:radial-gradient(circle,#FF6B9D,transparent);top:10%;left:10%}
.s3-blob--2{width:250px;height:250px;background:radial-gradient(circle,#C44EFF,transparent);bottom:20%;right:5%;animation-delay:-4s}
.s3-blob--3{width:200px;height:200px;background:radial-gradient(circle,#00D2FF,transparent);top:60%;left:50%;animation-delay:-8s}
.s3-vibes{display:flex;gap:.5rem}
.s3-vibe{padding:.4rem .9rem;border-radius:999px;font-size:.75rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:var(--text-2);transition:all .3s}
.s3-vibe.active{background:rgba(255,107,157,.15);border-color:#FF6B9D;color:#FF6B9D}

/* Creative Mockup */
.mockup-body--s3{background:linear-gradient(135deg,#1a0530,#0a0a1a);padding:0;overflow:hidden}
.s3m-hero{padding:24px 18px 12px;text-align:center}
.s3m-big{display:block;font-family:var(--font-display);font-size:clamp(1.5rem,2.8vw,3.2rem);line-height:1.1;background:linear-gradient(135deg,#FF6B9D,#C44EFF,#00D2FF);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.s3m-big em{font-style:normal}
.s3m-cards{display:flex;gap:8px;padding:8px 18px 14px;justify-content:center}
.s3m-card{text-align:center;padding:12px 10px;border-radius:14px;font-size:.55rem;color:#DDD;width:80px;animation:cardBob 3s ease-in-out infinite}
.s3m-card span{display:block;font-size:1.3rem;margin-bottom:4px}
.s3m-card--1{background:linear-gradient(135deg,rgba(255,107,157,.2),rgba(255,107,157,.05));border:1px solid rgba(255,107,157,.2)}
.s3m-card--2{background:linear-gradient(135deg,rgba(196,78,255,.2),rgba(196,78,255,.05));border:1px solid rgba(196,78,255,.2);animation-delay:-.5s}
.s3m-card--3{background:linear-gradient(135deg,rgba(0,210,255,.2),rgba(0,210,255,.05));border:1px solid rgba(0,210,255,.2);animation-delay:-1s}
.s3m-shapes{position:absolute;bottom:10px;right:10px;display:flex;gap:6px}
.s3m-shape{animation:float 4s ease-in-out infinite}
.s3m-shape--circle{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#FF6B9D,#C44EFF);opacity:.5}
.s3m-shape--square{width:16px;height:16px;border-radius:4px;background:linear-gradient(135deg,#C44EFF,#00D2FF);opacity:.5;animation-delay:-1.5s}
.s3m-shape--triangle{width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:18px solid rgba(0,210,255,.4);animation-delay:-3s}

/* ═══════════════════════════════════════════════════════════════
   SCENE 4 — SAAS / DASHBOARD
   ═══════════════════════════════════════════════════════════════ */
.s4-bg{position:absolute;inset:0;background:linear-gradient(170deg,#080810,#0E0E1A,#080810)}
.s4-grid-bg{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.03) 1px,transparent 1px);background-size:32px 32px;opacity:.5}
.s4-glow{position:absolute;width:500px;height:500px;top:30%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(88,80,236,.08),transparent);border-radius:50%;filter:blur(60px)}

.mockup-body--s4{background:#0E0E1A;display:flex;min-height:clamp(300px,42vh,650px)}
.s4m-sidebar{width:110px;background:rgba(255,255,255,.02);border-right:1px solid rgba(255,255,255,.04);padding:12px 8px}
.s4m-sidebar-item{padding:6px 8px;font-size:.55rem;color:var(--text-3);border-radius:6px;margin-bottom:4px;cursor:default;white-space:nowrap}
.s4m-sidebar-item.active{background:rgba(88,80,236,.15);color:#9D96FF}
.s4m-main{flex:1;padding:14px}
.s4m-kpis{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px}
.s4m-kpi{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:8px;padding:10px;text-align:center}
.s4m-kpi--green .s4m-kpi-val{color:#4ADE80}
.s4m-kpi-val{display:block;font-family:var(--font-display);font-size:clamp(1rem,2vw,2rem);font-weight:700;color:#9D96FF}
.s4m-kpi-lbl{font-size:.5rem;color:var(--text-3)}
.s4m-chart{display:flex;align-items:flex-end;gap:clamp(4px,1vw,12px);height:clamp(60px,12vh,150px);padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.s4m-bar{flex:1;background:linear-gradient(to top,rgba(88,80,236,.3),rgba(88,80,236,.6));border-radius:4px 4px 0 0;height:var(--h);transition:height 1s var(--ease-out)}
.s4m-bar--accent{background:linear-gradient(to top,rgba(0,229,255,.4),rgba(0,229,255,.8))}
.s4m-table{margin-top:10px}
.s4m-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.03);font-size:.55rem;color:var(--text-2)}
.s4m-badge{padding:2px 6px;border-radius:4px;font-size:.45rem;font-weight:600}
.s4m-badge--green{background:rgba(74,222,128,.15);color:#4ADE80}
.s4m-badge--yellow{background:rgba(250,204,21,.15);color:#FACC15}
.s4m-badge--blue{background:rgba(96,165,250,.15);color:#60A5FA}

/* ═══════════════════════════════════════════════════════════════
   SCENE 5 — RETRO
   ═══════════════════════════════════════════════════════════════ */
.scene-5{font-family:var(--font-mono)}
.scene-5 .scene-h1{font-family:var(--font-mono);color:#00FF41;text-shadow:0 0 20px rgba(0,255,65,.3)}
.scene-5 .scene-tag{color:#00FF41}
.scene-5 .scene-sub{color:#80C784}

.s5-bg{position:absolute;inset:0;background:#050A05}
.s5-crt{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,255,65,.02) 2px,rgba(0,255,65,.02) 4px);pointer-events:none}
.s5-flicker{position:absolute;inset:0;animation:crtFlicker 0.1s infinite;opacity:.015;background:#fff}
.s5-vignette{position:absolute;inset:0;background:radial-gradient(ellipse 70% 70% at center,transparent,rgba(0,0,0,.5))}
.s5-glow-line{position:absolute;left:0;right:0;height:2px;background:rgba(0,255,65,.08);animation:scan 6s linear infinite;top:0}
.s5-blink{animation:blink 1s step-end infinite}

/* Retro Terminal Mockup */
.mockup-body--s5{background:#0a0f0a;padding:clamp(12px,2vh,24px) clamp(14px,2vw,28px);font-family:var(--font-mono);font-size:clamp(.6rem,.9vw,.9rem);color:#00FF41;line-height:1.6;min-height:clamp(280px,38vh,550px);cursor:pointer;transition:background .3s}
.mockup-body--s5:hover{background:#080d08}
.mockup-body--s5:active{background:#060a06}
.s5m-ascii{font-size:.4rem;line-height:1.2;color:#00FF41;text-shadow:0 0 10px rgba(0,255,65,.4);margin-bottom:12px;white-space:pre}
.s5m-lines{line-height:1.8}
.s5m-prompt{color:#888}
.s5m-cmd{color:#00FF41}
.s5m-output{color:#40A040}
.s5m-cursor{animation:blink .8s step-end infinite;color:#00FF41}

/* ═══════════════════════════════════════════════════════════════
   SCENE 6 — CYBERPUNK
   ═══════════════════════════════════════════════════════════════ */
.s6-bg{position:absolute;inset:0;background:linear-gradient(180deg,#05050F,#0A0520,#0F0A20)}
.s6-circuit{position:absolute;inset:0;background-image:
  linear-gradient(rgba(0,229,255,.03) 1px,transparent 1px),
  linear-gradient(90deg,rgba(0,229,255,.03) 1px,transparent 1px);
  background-size:40px 40px}
.s6-neon{position:absolute;height:2px;background:linear-gradient(90deg,transparent,var(--kpr-bright),transparent);filter:blur(1px);opacity:.3;animation:scan 8s linear infinite}
.s6-neon--1{top:25%;left:0;right:0}
.s6-neon--2{top:70%;left:0;right:0;animation-delay:-4s;background:linear-gradient(90deg,transparent,var(--kpr-accent),transparent)}
.s6-scan{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(255,61,222,.01) 3px,rgba(255,61,222,.01) 6px)}

.scene-6 .scene-h1{font-family:var(--font-display)}
.s6-glitch{position:relative;display:inline-block}
.s6-glitch::before,.s6-glitch::after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;height:100%;clip-path:inset(0)}
.s6-glitch::before{color:var(--kpr-bright);animation:glitch1 3s infinite;left:2px}
.s6-glitch::after{color:var(--kpr-accent);animation:glitch2 3s infinite;left:-2px}
.s6-stats{display:flex;flex-direction:column;gap:.3rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text-3)}

/* Cyberpunk HUD */
.s6-hud{display:flex;flex-direction:column;gap:clamp(12px,2vh,24px);max-width:clamp(280px,30vw,560px);width:100%}
.s6-hud-panel{background:rgba(0,229,255,.03);border:1px solid rgba(0,229,255,.15);border-radius:4px;padding:16px;display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;overflow:hidden;animation:hudBreathe 4s ease-in-out infinite}
.s6-hud-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--kpr-bright),transparent)}
.s6-hud-title{font-family:var(--font-mono);font-size:.6rem;color:var(--kpr-accent);letter-spacing:.3em;align-self:flex-start}
.s6-hud-ring-wrap{position:relative;width:clamp(80px,12vw,160px);height:clamp(80px,12vw,160px);display:flex;align-items:center;justify-content:center}
.s6-hud-ring{position:absolute;inset:0;border-radius:50%;border:2px solid rgba(0,229,255,.2);animation:orbit 10s linear infinite}
.s6-hud-ring::after{content:'';position:absolute;width:8px;height:8px;background:var(--kpr-bright);border-radius:50%;top:-4px;left:50%;box-shadow:0 0 15px var(--kpr-bright)}
.s6-hud-ring-inner{position:absolute;inset:15px;border-radius:50%;border:1px solid rgba(255,61,222,.15);animation:orbit 7s linear reverse infinite}
.s6-hud-ring-text{font-family:var(--font-display);font-size:clamp(1.2rem,2.2vw,2.5rem);color:var(--kpr-bright);text-shadow:0 0 20px rgba(0,229,255,.4)}
.s6-hud-label{font-family:var(--font-mono);font-size:.55rem;color:var(--text-3);letter-spacing:.2em}
.s6-hud-bars{display:flex;flex-direction:column;gap:8px;background:rgba(0,229,255,.02);border:1px solid rgba(0,229,255,.08);border-radius:4px;padding:12px}
.s6-hud-bar{display:flex;align-items:center;gap:8px;height:16px}
.s6-hud-bar span{flex:1;height:6px;border-radius:3px;background:rgba(0,229,255,.1);overflow:hidden;position:relative}
.s6-hud-bar span::after{content:'';position:absolute;inset:0;border-radius:3px;background:linear-gradient(90deg,var(--kpr-bright),var(--kpr-accent));transform-origin:left;transition:transform .8s var(--ease-out)}
.s6-hud-bar span[style*="90%"]::after{transform:scaleX(.9)}
.s6-hud-bar span[style*="72%"]::after{transform:scaleX(.72)}
.s6-hud-bar span[style*="45%"]::after{transform:scaleX(.45)}
.s6-hud-bar em{font-family:var(--font-mono);font-size:.5rem;color:var(--text-3);font-style:normal;width:24px}

/* ═══════════════════════════════════════════════════════════════
   SCENE 7 — NATURE
   ═══════════════════════════════════════════════════════════════ */
.s7-bg{position:absolute;inset:0;background:linear-gradient(170deg,#0A1208,#141E10,#0A1208)}
.s7-blob-bg{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3}
.s7-blob-bg--1{width:400px;height:400px;background:radial-gradient(circle,rgba(76,175,80,.2),transparent);top:10%;left:20%;animation:float 12s ease-in-out infinite}
.s7-blob-bg--2{width:300px;height:300px;background:radial-gradient(circle,rgba(139,195,74,.15),transparent);bottom:10%;right:10%;animation:float 10s ease-in-out infinite reverse}

.scene-7 .scene-tag{color:#8BC34A}
.scene-7 .scene-h1{color:#E8F5E9}
.s7-benefits{display:flex;flex-direction:column;gap:.6rem}
.s7-benefit{display:flex;align-items:center;gap:.75rem;font-size:clamp(.85rem,1.1vw,1.15rem)}
.s7-benefit span{font-size:clamp(1.2rem,1.8vw,2rem)}
.s7-benefit strong{color:#AED581;margin-right:.3rem}

/* Nature Mockup */
.mockup-body--s7{background:linear-gradient(170deg,#F5EDE3,#EDE5D8);padding:0;color:#3E2E1C}
.s7m-hero{position:relative;min-height:clamp(100px,15vh,220px);background:linear-gradient(135deg,#8BC34A33,#4CAF5022);overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.s7m-hero-text{font-family:var(--font-serif);font-size:clamp(.9rem,1.4vw,1.6rem);line-height:1.3;color:#2E4620;position:relative;z-index:1}
.s7m-hero-text em{font-style:normal;color:#4CAF50}
.s7m-leaf{position:absolute;width:30px;height:30px;border-radius:0 50%;opacity:.3}
.s7m-leaf--1{background:#4CAF50;top:10px;left:10px;transform:rotate(-30deg);animation:float 5s ease-in-out infinite}
.s7m-leaf--2{background:#8BC34A;bottom:10px;right:15px;transform:rotate(150deg);animation:float 6s ease-in-out infinite reverse}
.s7m-cards{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:12px}
.s7m-card{background:#fff;border-radius:10px;overflow:hidden;text-align:center;font-size:.6rem;color:#5C4033;padding-bottom:8px;transition:transform .3s,box-shadow .3s}
.s7m-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,.15)}
.s7m-card-img{height:clamp(50px,7vh,100px);background:linear-gradient(135deg,#AED581,#81C784)}
.s7m-card-img--2{background:linear-gradient(135deg,#FFCC80,#A5D6A7)}
.s7m-card span{display:block;margin-top:6px}

/* ═══════════════════════════════════════════════════════════════
   SCENE 8 — AVANTGARDE
   ═══════════════════════════════════════════════════════════════ */
.s8-bg{position:absolute;inset:0;background:linear-gradient(180deg,#FAFAFA,#F0F0F0)}
.s8-vignette{position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at center,transparent,rgba(0,0,0,.08))}
.scene-8 .scene-tag{color:#333}
.scene-8 .scene-h1{color:#111;font-size:clamp(2.5rem,6vw,6rem)}
.s8-strike{position:relative;color:#FF3D3D}
.s8-strike::after{content:'';position:absolute;left:-4px;right:-4px;top:55%;height:4px;background:#FF3D3D;transform:rotate(-2deg)}

/* Avantgarde Composition */
.s8-composition{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,clamp(70px,10vh,140px));gap:clamp(8px,1.2vw,20px);width:100%;max-width:clamp(360px,65vw,1200px);margin-top:clamp(1rem,3vh,3rem)}
.s8-block{border-radius:0;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;transition:transform .3s}
.s8-block:hover{transform:scale(1.05)!important}
.s8-block-text{font-family:var(--font-display);font-weight:700;letter-spacing:.1em;line-height:1}
.s8-block--hero{grid-column:1/3;grid-row:1/3;background:#111;color:#fff;font-size:2rem}
.s8-block--hero .s8-block-text{font-size:2.2rem}
.s8-block--tall{grid-column:3;grid-row:1/4;background:linear-gradient(180deg,#FF3D3D,#FF6B3D);color:#fff;writing-mode:vertical-rl}
.s8-block--tall .s8-block-text--vertical{font-size:1rem;letter-spacing:.3em}
.s8-block--overlay{grid-column:4;grid-row:1/3;background:#FFEB3B;color:#111;text-align:center;z-index:1;transform:rotate(2deg);box-shadow:8px 8px 0 rgba(0,0,0,.1)}
.s8-block--overlay .s8-block-text{font-size:.7rem;line-height:1.5;font-weight:700}
.s8-block--accent{grid-column:1;grid-row:3;background:#00BCD4}
.s8-block--small{grid-column:2;grid-row:3;background:#111;color:#FFEB3B;font-family:var(--font-mono);font-size:.8rem}
.s8-quote{grid-column:3/5;grid-row:3;display:flex;align-items:center;font-family:var(--font-serif);font-style:italic;font-size:.85rem;color:#333;padding:0 8px}

/* ═══════════════════════════════════════════════════════════════
   SCENE 9 — CORPORATE
   ═══════════════════════════════════════════════════════════════ */
.s9-bg{position:absolute;inset:0;background:linear-gradient(170deg,#0A0A14,#0E0E1C,#0A0A14)}
.s9-pattern{position:absolute;inset:0;background-image:radial-gradient(rgba(96,165,250,.03) 1px,transparent 1px);background-size:30px 30px}
.s9-accent-line{position:absolute;top:0;left:8%;width:2px;height:100%;background:linear-gradient(to bottom,transparent,rgba(96,165,250,.15),transparent)}
.scene-9 .scene-tag{color:#60A5FA}
.scene-9 .scene-h1{color:var(--text-1)}

.s9-process{display:flex;align-items:center;gap:.6rem;margin-top:.75rem;flex-wrap:wrap}
.s9-step{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--text-2);transition:all .4s var(--ease-out)}
.s9-step-num{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:rgba(96,165,250,.12);border:1px solid rgba(96,165,250,.3);color:#60A5FA;font-family:var(--font-mono);font-size:.65rem;font-weight:700}
.s9-step-line{width:20px;height:1px;background:rgba(96,165,250,.2)}

/* Corporate Mockup */
.mockup-body--s9{background:#0C0C18;padding:0}
.s9m-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid rgba(96,165,250,.08)}
.s9m-logo{font-family:var(--font-display);font-size:.8rem;color:#F0F0F5;font-weight:700;letter-spacing:.05em}
.s9m-nav{font-size:.5rem;color:#606070;letter-spacing:.1em}
.s9m-hero{padding:clamp(20px,4vh,50px) clamp(14px,2vw,28px);text-align:center;font-family:var(--font-display);font-size:clamp(.9rem,1.5vw,1.6rem);color:#D0D0E0;line-height:1.4;border-bottom:1px solid rgba(96,165,250,.06)}
.s9m-hero strong{color:#60A5FA}
.s9m-cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:12px}
.s9m-card{text-align:center;padding:12px 6px;background:rgba(96,165,250,.04);border:1px solid rgba(96,165,250,.08);border-radius:8px;font-size:.55rem;color:var(--text-2);transition:all .3s}
.s9m-card:hover{background:rgba(96,165,250,.08);border-color:rgba(96,165,250,.2);transform:translateY(-2px)}
.s9m-card-icon{font-size:1.2rem;margin-bottom:4px}

/* ═══════════════════════════════════════════════════════════════
   SCENE 10 — EDITORIAL
   ═══════════════════════════════════════════════════════════════ */
.s10-bg{position:absolute;inset:0;background:linear-gradient(170deg,#FAF7F2,#F0ECE4)}
.s10-texture{position:absolute;inset:0;background: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='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E")}
.scene-10 .scene-tag{color:#8A7D6B}
.scene-10 .scene-h1{color:#1a1a1a;font-family:var(--font-serif);font-size:clamp(2.5rem,5vw,5rem)}
.scene-10 .scene-sub{color:#5A5040}
.s10-pullquote{font-family:var(--font-serif);font-style:italic;font-size:1rem;color:#8A7D6B;border-left:3px solid #D4C5A9;padding-left:1rem;line-height:1.6}

/* Editorial Mockup */
.mockup-body--s10{background:#FAF7F2;padding:0;display:flex;color:#1a1a1a}
.s10m-spread{display:flex;width:100%;min-height:clamp(250px,35vh,500px)}
.s10m-page{padding:16px;flex:1}
.s10m-page--left{background:linear-gradient(135deg,#D4C5A9,#C4B599);display:flex;flex-direction:column;justify-content:flex-end;position:relative;transition:filter .6s}
.s10m-page--left:hover{filter:brightness(1.1)}
.s10m-img{position:absolute;inset:0;background:linear-gradient(135deg,#B0A58E,#8A7D6B);opacity:.6}
.s10m-caption{position:relative;font-size:.45rem;color:#F0ECE4;letter-spacing:.15em;text-transform:uppercase;font-family:var(--font-mono)}
.s10m-page--right{display:flex;flex-direction:column;background:#FAF7F2;padding:20px 16px}
.s10m-issue{font-family:var(--font-mono);font-size:.45rem;color:#8A7D6B;letter-spacing:.15em;margin-bottom:8px}
.s10m-title{font-family:var(--font-serif);font-size:clamp(.9rem,1.5vw,1.8rem);line-height:1.2;color:#1a1a1a;margin-bottom:8px}
.s10m-line{width:30px;height:1px;background:#D4C5A9;margin-bottom:8px}
.s10m-drop{float:left;font-family:var(--font-serif);font-size:2.2rem;line-height:.8;margin-right:4px;margin-top:2px;color:#1a1a1a}
.s10m-body-text{font-family:'EB Garamond',var(--font-serif);font-size:.6rem;line-height:1.7;color:#5A5040}

/* ═══════════════════════════════════════════════════════════════
   SCENE 11 — GLASSMORPHISM
   ═══════════════════════════════════════════════════════════════ */
.s11-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0A0520,#150A30,#0A1030)}
.s11-aurora-blob{position:absolute;border-radius:50%;filter:blur(100px);opacity:.5;animation:auroraShift 12s ease-in-out infinite}
.s11-aurora-blob--1{width:500px;height:500px;background:radial-gradient(circle,rgba(138,43,226,.3),transparent);top:-15%;left:20%;animation-delay:0s}
.s11-aurora-blob--2{width:400px;height:400px;background:radial-gradient(circle,rgba(0,229,255,.25),transparent);bottom:-10%;right:10%;animation-delay:-4s}
.s11-aurora-blob--3{width:350px;height:350px;background:radial-gradient(circle,rgba(255,61,222,.2),transparent);top:40%;left:60%;animation-delay:-8s}

.scene-11 .scene-tag{color:#B388FF}
.scene-11 .scene-h1{background:linear-gradient(135deg,#B388FF,#00E5FF);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Glass Cards Grid */
.s11-glass-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.5vw,28px);max-width:clamp(360px,65vw,1200px);width:100%;margin-top:clamp(1rem,3vh,3rem)}
.s11-glass{background:rgba(255,255,255,.06);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:clamp(12px,1.5vw,24px);padding:clamp(14px,2.5vh,36px);display:flex;flex-direction:column;gap:clamp(4px,1vh,12px);transition:transform .3s,border-color .3s;position:relative;overflow:hidden}
.s11-glass:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.2)}
.s11-glass::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);animation:shimmerSweep 6s ease-in-out infinite;pointer-events:none}
.s11-glass--big{grid-column:1/2;grid-row:1/2}
.s11-glass--wide{grid-column:1/4}
.s11-glass-icon{font-size:clamp(1.2rem,2vw,2.5rem);opacity:.8}
.s11-glass-title{font-size:clamp(.6rem,.9vw,.9rem);color:var(--text-3);font-family:var(--font-mono);letter-spacing:.05em}
.s11-glass-val{font-family:var(--font-display);font-size:clamp(1.3rem,2.5vw,3rem);font-weight:700;background:linear-gradient(135deg,#B388FF,#00E5FF);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.s11-glass-bar{height:4px;border-radius:2px;background:rgba(255,255,255,.08);overflow:hidden;margin-top:4px}
.s11-glass-bar span{display:block;height:100%;border-radius:2px;background:linear-gradient(90deg,var(--kpr-bright),#B388FF);transition:width 1.5s var(--ease-out)}
.s11-glass-bar--purple span{background:linear-gradient(90deg,#B388FF,var(--kpr-accent))}

/* ═══════════════════════════════════════════════════════════════
   SCENE 12 — BRUTALIST / FINALE
   ═══════════════════════════════════════════════════════════════ */
.s12-bg{position:absolute;inset:0;background:#FAFAFA}
.s12-noise{position:absolute;inset:0;background: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='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E")}
.s12-line{position:absolute;background:#111}
.s12-line--1{top:12%;left:0;right:0;height:3px}
.s12-line--2{bottom:18%;left:0;right:0;height:3px}
.s12-line--3{left:10%;top:0;bottom:0;width:3px}
.s12-line--4{right:12%;top:0;bottom:0;width:3px}

.scene-12 .scene-tag{color:#111;font-size:.8rem;letter-spacing:.3em}
.scene-12 .scene-h1{color:#111;font-size:clamp(3rem,8vw,8rem);letter-spacing:-.02em;line-height:.95}

.s12-profile{margin-top:clamp(1rem,3vh,3rem);border:3px solid #111;padding:0;width:100%;max-width:clamp(340px,45vw,750px)}
.s12-profile-title{background:#111;color:#FAFAFA;padding:10px 16px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.2em}
.s12-profile-row{display:flex;justify-content:space-between;padding:10px 16px;border-bottom:2px solid #111;transition:background .2s}
.s12-profile-row:last-child{border-bottom:none}
.s12-profile-row:hover{background:rgba(0,0,0,.03)}
.s12-label{font-family:var(--font-mono);font-size:.65rem;color:#555;letter-spacing:.15em}
.s12-value{font-family:var(--font-display);font-size:clamp(.85rem,1.2vw,1.3rem);color:#111;font-weight:700}

.s12-cta-text{color:#333;font-size:clamp(1rem,1.5vw,1.6rem);margin-top:clamp(1rem,2vh,2.5rem);margin-bottom:clamp(.75rem,1.5vh,1.5rem)}
.s12-actions{display:flex;gap:1rem;flex-wrap:wrap}
.scene-12 .exp-btn--primary{background:#111;color:#FAFAFA;box-shadow:none;border-radius:0}
.scene-12 .exp-btn--primary:hover{background:#333;box-shadow:4px 4px 0 #111}
.scene-12 .exp-btn--ghost{color:#111;border-color:#111;border-width:2px;border-radius:0}

/* ═══ SCENE NAV ═══════════════════════════════════════════════ */
.exp-scene-nav{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%);z-index:50;display:flex;align-items:center;gap:1rem;background:rgba(10,10,15,.7);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:.5rem 1.2rem;opacity:0;transition:opacity .5s}
.exp-scene-nav.visible{opacity:1}

/* ═══ LITE TOGGLE ═════════════════════════════════════════════ */
.exp-lite-toggle{position:fixed;bottom:2rem;right:2rem;z-index:50;font-size:.72rem;color:var(--text-3);opacity:0;transition:opacity .5s}
.exp-lite-toggle.visible{opacity:1}
.exp-lite-toggle label{display:flex;align-items:center;gap:.4rem;cursor:pointer}

/* ═══ PANEL ═══════════════════════════════════════════════════ */
.exp-panel{position:fixed;inset:0;z-index:200;border:0;background:transparent;max-width:none;max-height:none;width:100%;height:100%;padding:0}
.exp-panel::backdrop{background:rgba(0,0,0,.7);backdrop-filter:blur(8px)}
.exp-panel[open]{display:flex;align-items:center;justify-content:flex-end}
.panel-inner{width:100%;max-width:540px;height:100%;background:var(--bg-2);border-left:1px solid rgba(255,255,255,.06);overflow-y:auto;display:flex;flex-direction:column;animation:slideInRight .4s var(--ease-out)}
.panel-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.06)}
.panel-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700}
.panel-subtitle{font-size:.8rem;color:var(--text-3);margin-top:.25rem}
.panel-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1rem;color:var(--text-2);border:1px solid rgba(255,255,255,.06);transition:all .2s}
.panel-close:hover{background:rgba(255,255,255,.04);color:var(--text-1)}
.panel-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.06)}
.panel-tab{flex:1;padding:.75rem 1rem;font-size:.82rem;color:var(--text-3);border-bottom:2px solid transparent;transition:all .2s}
.panel-tab.active{color:var(--kpr-bright);border-color:var(--kpr-bright)}
.panel-tabpanel{display:none;padding:1.5rem;flex:1;overflow-y:auto}
.panel-tabpanel.active{display:block}
.pfield{margin-bottom:1rem}
.pfield label{display:block;font-size:.78rem;color:var(--text-2);margin-bottom:.35rem;font-weight:600}
.pfield input,.pfield select,.pfield textarea{width:100%;padding:.6rem .8rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);color:var(--text-1);font-size:.85rem;font-family:var(--font-body);outline:none;transition:border-color .2s}
.pfield input:focus,.pfield select:focus,.pfield textarea:focus{border-color:var(--kpr-bright)}
.pfield select{cursor:pointer}
.pfield textarea{resize:vertical}
.pfield--toggle{display:flex;align-items:flex-start}
.pfield--toggle label{display:flex;align-items:flex-start;gap:.5rem;font-size:.75rem;color:var(--text-3);cursor:pointer}
.pfield--toggle input{width:auto;margin-top:2px}
.pfield-chips{display:flex;flex-wrap:wrap;gap:.4rem}
.p-dropzone{border:2px dashed rgba(255,255,255,.1);border-radius:var(--radius-sm);padding:1.25rem;text-align:center;font-size:.82rem;color:var(--text-3);cursor:pointer;transition:all .2s}
.p-dropzone:hover,.p-dropzone.drag-over{border-color:var(--kpr-bright);background:rgba(0,229,255,.03)}
.p-dropzone-btn{display:inline;background:none;color:var(--kpr-bright);text-decoration:underline;font-size:.82rem;padding:0;cursor:pointer;border:none}
.p-dropzone-hint{font-size:.7rem;margin-top:.5rem;color:var(--text-3)}
.p-file-list{margin-top:.5rem}
.p-file-item{display:flex;align-items:center;justify-content:space-between;padding:.4rem .6rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-xs);margin-bottom:.4rem;font-size:.75rem;color:var(--text-2)}
.p-file-remove{background:none;border:none;color:var(--text-3);font-size:.8rem;cursor:pointer;padding:0 .3rem}
.p-file-remove:hover{color:#FF5050}
.p-time-chips{display:flex;gap:.4rem;flex-wrap:wrap}
.p-time-chip{padding:.4rem .8rem;border-radius:999px;font-size:.75rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:var(--text-2);transition:all .2s}
.p-time-chip.active{background:rgba(0,229,255,.1);border-color:var(--kpr-bright);color:var(--kpr-bright)}
.p-booking-embed{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-sm);padding:2rem;text-align:center}
.p-booking-embed h3{font-size:.9rem;margin-bottom:.5rem}
.p-booking-placeholder{font-size:.78rem;color:var(--text-3)}

.panel-footer{margin-top:auto;padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:.75rem}
.panel-error{background:rgba(255,80,80,.1);border:1px solid rgba(255,80,80,.2);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.78rem;color:#FF5050}
.panel-footer-actions{display:flex;justify-content:flex-end;gap:.75rem}

/* ═══ THANK YOU ═══════════════════════════════════════════════ */
.exp-thankyou{position:fixed;inset:0;z-index:180;background:var(--bg-1);display:flex;align-items:center;justify-content:center;padding:2rem}
.exp-thankyou[hidden]{display:none}
.ty-inner{max-width:540px;text-align:center}
.ty-check{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--kpr-bright),#00B8D4);color:var(--bg-1);font-size:2.5rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;animation:scaleIn .6s var(--ease-spring)}
.ty-headline{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2rem);margin-bottom:1.5rem}
.ty-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:1.5rem;margin-bottom:1rem;text-align:left}
.ty-card--lead{display:flex;justify-content:space-between;align-items:center}
.ty-card-label{font-size:.75rem;color:var(--text-3);font-family:var(--font-mono)}
.ty-card-value{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--kpr-bright);margin-top:.25rem}
.ty-copy{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:1rem;cursor:pointer;transition:all .2s}
.ty-copy:hover{background:rgba(255,255,255,.1)}
.ty-expect{font-size:.9rem;color:var(--text-2);margin-bottom:1.5rem}
.ty-booking-placeholder{font-size:.78rem;color:var(--text-3);margin-top:.75rem}
.ty-home{margin-top:1.5rem}

/* ═══ KEYFRAMES ═══════════════════════════════════════════════ */
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes sceneElIn{from{opacity:0;transform:translateY(25px)}to{opacity:1;transform:translateY(0)}}
@keyframes mockupIn{from{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(20px,-30px) scale(1.1)}66%{transform:translate(-15px,20px) scale(.95)}}
@keyframes sweep{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
@keyframes orbit{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.8}}
@keyframes wipeIn{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@keyframes wipeOut{from{transform:scaleY(1)}to{transform:scaleY(0)}}
@keyframes labelPop{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}30%{opacity:1;transform:translate(-50%,-50%) scale(1.05)}60%{opacity:1;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-50%) scale(1)}}
@keyframes slideInRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
@keyframes scaleIn{from{transform:scale(0)}to{transform:scale(1)}}
@keyframes scan{from{top:0}to{top:100%}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes crtFlicker{0%{opacity:.015}50%{opacity:.02}100%{opacity:.015}}
@keyframes glitch1{0%,100%{clip-path:inset(0);transform:translate(0)}20%{clip-path:inset(20% 0 60% 0);transform:translate(2px)}40%{clip-path:inset(0);transform:translate(0)}60%{clip-path:inset(50% 0 20% 0);transform:translate(-2px)}80%{clip-path:inset(0);transform:translate(0)}}
@keyframes glitch2{0%,100%{clip-path:inset(0);transform:translate(0)}30%{clip-path:inset(40% 0 30% 0);transform:translate(-2px)}50%{clip-path:inset(0);transform:translate(0)}70%{clip-path:inset(10% 0 70% 0);transform:translate(2px)}90%{clip-path:inset(0);transform:translate(0)}}
@keyframes auroraShift{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-20px) scale(1.15)}66%{transform:translate(-20px,30px) scale(.9)}}
@keyframes shimmerSweep{0%,100%{left:-100%}50%{left:150%}}
@keyframes rippleExpand{to{transform:scale(1);opacity:0}}
@keyframes gradientShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.02)}}
@keyframes tagPulse{0%,100%{text-shadow:0 0 0 transparent}50%{text-shadow:0 0 12px currentColor}}
@keyframes cardBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes hudBreathe{0%,100%{box-shadow:0 0 0 rgba(0,229,255,0)}50%{box-shadow:0 0 25px rgba(0,229,255,.08),inset 0 0 15px rgba(0,229,255,.03)}}
@keyframes textShine{to{background-position:200% center}}
@keyframes bounceArrow{0%,100%{transform:rotate(45deg) translate(0,0);opacity:.3}50%{transform:rotate(45deg) translate(4px,4px);opacity:.8}}
@keyframes rainbowBg{0%{filter:hue-rotate(0deg)}25%{filter:hue-rotate(90deg)}50%{filter:hue-rotate(180deg)}75%{filter:hue-rotate(270deg)}100%{filter:hue-rotate(360deg)}}

/* ═══ LITE MODE ═══════════════════════════════════════════════ */
.lite-mode .intro-orb,.lite-mode .intro-sweep,.lite-mode #exp-canvas,
.lite-mode .s6-scan,.lite-mode .s5-crt,.lite-mode .s5-flicker,
.lite-mode .s6-circuit,.lite-mode .s6-neon{display:none}
.lite-mode .s11-aurora-blob{animation:none}
.lite-mode .s3-blob{animation:none}
.lite-mode .cursor-wrap{display:none}
.lite-mode .boot-seq{display:none}

/* ═══ RESPONSIVE ══════════════════════════════════════════════ */

/* ═══ ULTRA-WIDE (1920px+) ═══════════════════════════════════ */
@media(min-width:1920px){
  .scene-inner{padding:calc(48px + clamp(1rem,3vh,3rem)) clamp(3rem,6vw,10rem) calc(2rem + 44px + clamp(.5rem,2vh,2rem))}
  .scene-inner--split{gap:clamp(4rem,8vw,14rem)}
  .mockup{max-width:clamp(600px,38vw,1000px)}
  .mockup-body{min-height:clamp(350px,40vh,700px)}
  .scene-h1{font-size:clamp(3rem,4.5vw,6rem)}
  .scene-sub{font-size:clamp(1.05rem,1.2vw,1.5rem);max-width:clamp(450px,30vw,750px)}
  .s6-hud{max-width:clamp(400px,28vw,600px)}
  .s6-hud-ring-wrap{width:clamp(120px,10vw,200px);height:clamp(120px,10vw,200px)}
  .s8-composition{max-width:clamp(700px,55vw,1400px);grid-template-rows:repeat(3,clamp(100px,12vh,180px))}
  .s11-glass-grid{max-width:clamp(700px,55vw,1400px)}
  .s11-glass{padding:clamp(24px,3vh,48px)}
  .s12-profile{max-width:clamp(500px,35vw,900px)}
  .s12-recommendation{max-width:clamp(500px,35vw,900px)}
  .s12-profile-row{padding:clamp(12px,1.5vh,24px) clamp(16px,2vw,32px)}
  .s12-value{font-size:clamp(.9rem,1.2vw,1.4rem)}
  .s12-label{font-size:clamp(.7rem,.9vw,1rem)}
  .s4m-kpi-val{font-size:clamp(1.5rem,2vw,2.5rem)}
  .s4m-sidebar{width:clamp(120px,10vw,200px)}
  .s4m-sidebar-item{font-size:clamp(.6rem,.8vw,.85rem);padding:clamp(8px,1vh,14px) clamp(10px,1vw,16px)}
  .mockup-body--s4{min-height:clamp(400px,45vh,750px)}
  .mockup-body--s5{min-height:clamp(380px,42vh,650px);font-size:clamp(.75rem,.9vw,1rem)}
  .intro-headline{font-size:clamp(4rem,6vw,7rem)}
  .intro-sub{font-size:clamp(1.1rem,1.3vw,1.5rem);max-width:clamp(500px,35vw,750px)}
  .s10m-spread{min-height:clamp(350px,38vh,600px)}
  .s10m-title{font-size:clamp(1.3rem,1.6vw,2.2rem)}
  .s10m-body-text{font-size:clamp(.7rem,.8vw,.95rem)}
  .s3m-big{font-size:clamp(2.2rem,3vw,4rem)}
  .s3m-card{width:clamp(80px,8vw,140px);padding:clamp(12px,1.5vh,24px) clamp(10px,1vw,18px)}
  .scene-prompt{font-size:clamp(.8rem,.9vw,1rem);padding:clamp(.6rem,1vh,1rem) clamp(1rem,1.5vw,2rem)}
  .s1m-hero-text{font-size:clamp(2rem,3vw,4.5rem)}
  .s2m-title{font-size:clamp(1.5rem,2vw,2.8rem)}
  .s2m-hero{min-height:clamp(220px,30vh,400px)}
  .s7m-cards{grid-template-columns:1fr 1fr;gap:clamp(10px,1.2vw,20px)}
  .s7m-card-img{height:clamp(60px,8vh,120px)}
  .s7m-hero{min-height:clamp(130px,18vh,250px)}
  .s9m-hero{padding:clamp(28px,4vh,60px) clamp(16px,2vw,32px)}
  .chip{font-size:clamp(.75rem,.9vw,.95rem);padding:clamp(.3rem,.6vh,.6rem) clamp(.8rem,1.2vw,1.5rem)}
  .hud-dots{gap:clamp(6px,.5vw,12px)}
  .hud-dot{width:clamp(8px,.6vw,14px);height:clamp(8px,.6vw,14px)}
  .exp-hud{padding:1rem 2rem}
}

/* ═══ SUPER ULTRA-WIDE (2560px+) ═════════════════════════════ */
@media(min-width:2560px){
  .scene-inner{padding:calc(52px + clamp(1.5rem,4vh,5rem)) clamp(5rem,8vw,16rem) calc(2rem + 48px + clamp(1rem,3vh,3rem))}
  .mockup{max-width:clamp(750px,35vw,1200px)}
  .scene-h1{font-size:clamp(4rem,4vw,7rem)}
  .s8-composition{max-width:clamp(900px,50vw,1800px);grid-template-rows:repeat(3,clamp(120px,14vh,220px))}
  .s11-glass-grid{max-width:clamp(900px,50vw,1800px)}
  .s11-glass-val{font-size:clamp(2rem,2.5vw,4rem)}
  .s11-glass-icon{font-size:clamp(2rem,2vw,3.5rem)}
  .s6-hud-panel{padding:clamp(20px,3vh,40px)}
  .s6-hud-ring-wrap{width:clamp(160px,9vw,240px);height:clamp(160px,9vw,240px)}
  .s6-hud-ring-text{font-size:clamp(2rem,2.5vw,3.5rem)}
  .s12-profile{max-width:clamp(600px,30vw,1000px)}
  .s12-recommendation{max-width:clamp(600px,30vw,1000px)}
  .intro-headline{font-size:clamp(5rem,5.5vw,9rem)}
  .scene-12 .scene-h1{font-size:clamp(5rem,7vw,10rem)}
  .s1-top .scene-h1{font-size:clamp(2.2rem,3vw,4rem)}
  .s1-top .scene-sub{font-size:clamp(.8rem,1vw,1.2rem)}
  .s1-top .scene-tag{font-size:clamp(.8rem,1vw,1.1rem)}
  .exp-hud{padding:1.1rem 2.5rem}
  .exp-scene-nav{padding:.6rem 1.5rem;gap:1.2rem}
}

/* ═══ 4K ULTRA-WIDE CURVED (3440px+) ═════════════════════════ */
@media(min-width:3440px){
  .scene-inner{padding:calc(56px + 3rem) clamp(8rem,12vw,24rem) calc(2.5rem + 52px + 2rem)}
  .scene-h1{font-size:clamp(5rem,4.5vw,9rem)}
  .scene-sub{font-size:clamp(1.3rem,1.3vw,2rem);max-width:clamp(600px,28vw,1000px)}
  .scene-tag{font-size:clamp(.9rem,1vw,1.3rem)}
  .mockup{max-width:clamp(900px,32vw,1500px)}
  .mockup-body{min-height:clamp(500px,45vh,900px)}
  .s1-top .scene-h1{font-size:clamp(2.8rem,3.5vw,5rem)}
  .s1-top .scene-sub{font-size:clamp(.9rem,1.1vw,1.5rem)}
  .s1-top .scene-tag{font-size:clamp(.9rem,1.1vw,1.3rem)}
  .s1m-hero-text{font-size:clamp(3rem,3.5vw,6rem)}
  .s1m-stat-val{font-size:clamp(1.2rem,2vw,3rem)}
  .s1m-stat-lbl{font-size:clamp(.5rem,.7vw,.9rem)}
  .s1m-logo{font-size:clamp(1rem,1.3vw,2rem)}
  .s1m-links{font-size:clamp(.55rem,.8vw,1rem)}
  .s1m-footer-text,.s1m-footer-btn{font-size:clamp(.5rem,.8vw,1rem)}
  .s1-clutter-item{font-size:clamp(.6rem,1vw,1.1rem);padding:clamp(8px,1.2vh,18px) clamp(10px,1.5vw,24px)}
  .s1-cl--popup{font-size:clamp(.7rem,1.1vw,1.2rem);padding:clamp(12px,2vh,28px) clamp(14px,2.5vw,36px)}
  .s1-hud-label{font-size:clamp(.7rem,1vw,1.1rem)}
  .s1-hud-timer{font-size:clamp(.9rem,1.3vw,1.8rem)}
  .s1-hud-pct{font-size:clamp(.75rem,1.1vw,1.3rem)}
  .s1-score-grade{font-size:clamp(4rem,7vw,10rem)}
  .s1-score-row span:first-child{font-size:clamp(.6rem,.9vw,1rem)}
  .s1-score-row span:last-child{font-size:clamp(.85rem,1.3vw,1.6rem)}
  .s1-retry-btn{font-size:clamp(.7rem,1vw,1.1rem);padding:clamp(.4rem,.7vh,.8rem) clamp(.8rem,1.8vw,2rem)}
  .intro-headline{font-size:clamp(6rem,6vw,11rem)}
  .intro-sub{font-size:clamp(1.3rem,1.4vw,2rem)}
  .exp-hud{padding:1.2rem 3rem}
  .hud-logo{font-size:1.3rem}
  .hud-progress-label{font-size:.9rem}
  .exp-scene-nav{padding:.7rem 1.8rem;gap:1.4rem;bottom:2.5rem}
  .exp-btn--nav{padding:.55rem 1rem;font-size:.95rem}
  .s8-composition{max-width:clamp(1100px,48vw,2200px);grid-template-rows:repeat(3,clamp(150px,15vh,280px))}
  .s11-glass-grid{max-width:clamp(1100px,48vw,2200px)}
  .s12-profile{max-width:clamp(700px,28vw,1200px)}
  .s12-recommendation{max-width:clamp(700px,28vw,1200px)}
}

/* ═══ SHORT SCREENS / LAPTOPS (height ≤ 700px) ═══════════════ */
@media(max-height:700px){
  .s1-top .scene-h1{font-size:clamp(1rem,2vw,1.8rem)}
  .s1-top .scene-sub{font-size:clamp(.45rem,.7vw,.7rem)}
  .s1-top .scene-tag{font-size:clamp(.5rem,.8vw,.8rem);margin-bottom:.05rem}
  .s1-layout{padding:calc(42px + .3rem) 0 calc(2rem + 38px + .3rem)}
  .s1m-hero{padding:clamp(6px,1.5vh,20px) clamp(10px,2vw,28px)}
  .s1m-card{height:clamp(20px,4vh,50px)}
  .s1m-card--interactive.expanded{height:clamp(36px,8vh,90px)}
  .s1m-stat{padding:clamp(3px,.8vh,8px) clamp(3px,.6vw,6px)}
  .s1-hud{padding:clamp(.15rem,.4vh,.35rem) clamp(.8rem,2vw,2.5rem)}
  .scene-inner{padding:calc(42px + .3rem) clamp(1rem,5vw,6rem) calc(2rem + 38px + .3rem)}
  .scene-h1{font-size:clamp(1.5rem,4vw,3.5rem)}
  .scene-sub{font-size:clamp(.75rem,1.2vw,1.1rem)}
}

/* ═══ VERY SHORT SCREENS (height ≤ 500px — landscape phones) ═ */
@media(max-height:500px){
  .s1-top{display:none}
  .s1-layout{padding:calc(36px + .2rem) 0 calc(1.5rem + 34px + .2rem)}
  .s1-hud{padding:clamp(.1rem,.3vh,.25rem) clamp(.5rem,1.5vw,1.5rem)}
  .s1m-nav{padding:4px 8px}
  .s1m-hero{padding:4px 8px}
  .s1m-grid{padding:0 8px 4px}
  .s1m-stat{padding:2px 4px}
  .s1m-footer{padding:3px 8px}
  .exp-hud{padding:.4rem .8rem}
  .exp-scene-nav{bottom:.5rem;padding:.3rem .6rem}
}

/* ═══ RESPONSIVE — TABLET (≤1024px) ══════════════════════════ */
@media(max-width:1024px){
  .scene-inner--split{gap:clamp(1.5rem,4vw,6rem)}
  .mockup{max-width:clamp(320px,55vw,600px)}
  .scene-h1{font-size:clamp(1.8rem,4.5vw,4rem)}
}

/* ═══ RESPONSIVE — MOBILE (≤768px) ════════════════════════════ */
@media(max-width:768px){
  .scene-inner{padding:calc(42px + .4rem) clamp(.75rem,4vw,1.5rem) calc(1rem + 38px + .4rem);min-height:auto}
  .scene-inner--split{grid-template-columns:1fr;gap:1.5rem;text-align:center}
  .scene-inner--split > :first-child{order:0}
  .scene-inner--split > :last-child{order:1}
  .mockup{max-width:clamp(280px,90vw,500px);margin:0 auto}
  .mockup-body{min-height:clamp(220px,35vh,350px)}
  .scene-h1{font-size:clamp(1.5rem,6vw,2.5rem)}
  .scene-sub{margin-inline:auto;max-width:90vw;font-size:clamp(.8rem,3vw,1.1rem)}
  .scene-tag{font-size:clamp(.6rem,2.5vw,.85rem)}
  .scene-chips{justify-content:center}
  .s2-services{text-align:left;max-width:85vw;margin:0 auto}
  .s3-vibes{justify-content:center}
  .s7-benefits{align-items:center}
  .s8-composition{grid-template-columns:1fr 1fr;grid-template-rows:auto;max-width:90vw;margin-inline:auto}
  .s8-block--hero{grid-column:1/3}
  .s8-block--tall{grid-column:1;grid-row:auto;writing-mode:horizontal-tb}
  .s8-block--tall .s8-block-text--vertical{writing-mode:horizontal-tb;font-size:.8rem}
  .s8-block--overlay{grid-column:2;grid-row:auto;transform:rotate(1deg)}
  .s8-block--accent{grid-column:1}
  .s8-block--small{grid-column:2}
  .s8-quote{grid-column:1/3;font-size:.75rem;justify-content:center}
  .s9-process{justify-content:center}
  .s6-hud{max-width:90vw;margin:0 auto}
  .s4m-sidebar{width:60px}
  .s4m-sidebar-item{font-size:.4rem}
  .s11-glass-grid{grid-template-columns:1fr 1fr;max-width:90vw;margin-inline:auto}
  .s11-glass--big{grid-column:auto}
  .s11-glass--wide{grid-column:1/3}
  .s12-profile{max-width:90vw;margin-inline:auto}
  .s12-actions{justify-content:center}
  .exp-scene-nav{bottom:.8rem;padding:.35rem .7rem;gap:.6rem}
  .exp-lite-toggle{bottom:.8rem;right:.8rem}
  .exp-hud{padding:.5rem 1rem}
  .hud-logo{font-size:.85rem}
  .intro-headline{font-size:clamp(2rem,9vw,3.5rem)}
  .intro-sub{font-size:clamp(.85rem,3vw,1.2rem)}
  .s10m-spread{flex-direction:column}
  .s10m-page--left{min-height:100px}
  .s1-quote{text-align:left;max-width:85vw;margin-inline:auto}
  .s1-layout{padding:calc(42px + .3rem) 0 calc(.8rem + 38px + .3rem)}
  .s1-top .scene-h1{font-size:clamp(1.1rem,5vw,2rem)}
  .s1-top .scene-sub{font-size:clamp(.5rem,2.5vw,.75rem)}
  .s1-top .scene-tag{font-size:clamp(.5rem,2vw,.7rem)}
  .s1-mockup{max-width:100%!important}
  .s1m-hero-text{font-size:clamp(.9rem,5vw,2rem)}
  .s1m-hero-circle{width:clamp(24px,8vw,50px);height:clamp(24px,8vw,50px)}
  .s1m-stat-val{font-size:clamp(.6rem,3.5vw,1.1rem)}
  .s1m-card{height:clamp(24px,6vh,50px)}
  .s1-clutter-item{font-size:clamp(.4rem,2.5vw,.65rem);padding:clamp(4px,1vh,8px) clamp(5px,2vw,10px)}
  .s1-cl--popup{font-size:clamp(.45rem,3vw,.7rem);padding:clamp(6px,1.5vh,12px) clamp(8px,3vw,16px)}
  .s1-hud{max-width:100%;flex-direction:column;gap:.3rem;padding:clamp(.2rem,.5vh,.4rem) clamp(.5rem,3vw,1rem)}
  .s1-hud-left{width:100%}
  .s1-hud-right{width:100%;justify-content:center}
  .s1-hud-label{font-size:clamp(.45rem,2.5vw,.65rem)}
  .s1-hud-timer{font-size:clamp(.6rem,3.5vw,1rem)}
  .s1-hud-pct{font-size:clamp(.5rem,3vw,.8rem)}
  .s2-palette{flex-direction:column;align-items:center}
  .s3-emoji-tray{justify-content:center}
  .s10-page-nav{justify-content:center}
  .s11-flip-card--wide{grid-column:1/2}
  .s12-recommendation{max-width:90vw;margin-inline:auto}
  .scene-prompt{font-size:clamp(.6rem,2.5vw,.8rem)}
  .s6-clickbar{min-height:28px}
  .hud-dots{gap:4px}
  .hud-dot{width:6px;height:6px}
  .mockup-body--s4{min-height:clamp(250px,40vh,400px)}
}

/* ═══ SMALL MOBILE (≤480px) ═══════════════════════════════════ */
@media(max-width:480px){
  .scene-inner{padding:calc(40px + .3rem) clamp(.5rem,3vw,1rem) calc(.8rem + 36px + .3rem)}
  .scene-h1{font-size:clamp(1.3rem,7vw,2.2rem)}
  .mockup{max-width:94vw}
  .s1m-grid{gap:3px}
  .s1m-nav{padding:5px 10px}
  .s1m-hero{padding:8px 10px}
  .s1m-footer{padding:4px 10px}
  .s1-cl--chat{bottom:clamp(30px,6vh,60px)}
  .s1-cl--social{bottom:clamp(50px,10vh,100px)}
  .exp-scene-nav{bottom:.6rem;padding:.3rem .6rem;gap:.5rem}
  .exp-btn--nav{padding:.35rem .6rem;font-size:.72rem}
}

/* ═══ TINY MOBILE / iPhone SE (≤375px) ════════════════════════ */
@media(max-width:375px){
  .scene-inner{padding:calc(38px + .2rem) .4rem calc(.6rem + 34px + .2rem)}
  .scene-h1{font-size:clamp(1.2rem,6.5vw,1.8rem)}
  .scene-sub{font-size:clamp(.7rem,3vw,.9rem)}
  .mockup{max-width:96vw}
  .s4m-sidebar{display:none}
  .s8-composition{grid-template-columns:1fr;max-width:94vw}
  .s8-block--hero{grid-column:1}
  .s8-block--tall{grid-column:1}
  .s8-block--overlay{grid-column:1;transform:none}
  .s8-quote{grid-column:1}
  .s11-glass-grid{grid-template-columns:1fr;max-width:94vw}
  .s11-flip-card--wide{grid-column:1}
  .s1-top .scene-h1{font-size:clamp(.95rem,5.5vw,1.6rem)}
  .s1-top .scene-sub{font-size:clamp(.42rem,2.5vw,.6rem)}
  .s1m-hero-text{font-size:clamp(.8rem,5vw,1.5rem)}
  .s1m-hero-circle{width:clamp(20px,7vw,36px);height:clamp(20px,7vw,36px)}
  .s1m-stat-val{font-size:clamp(.55rem,3.5vw,.9rem)}
  .s1m-card{height:clamp(20px,5vh,40px)}
  .s1-clutter-item{font-size:clamp(.35rem,2.2vw,.5rem);padding:3px 5px}
  .s1-cl--popup{font-size:clamp(.38rem,2.5vw,.55rem);padding:5px 8px}
  .s1-hud-label{font-size:clamp(.4rem,2.2vw,.55rem)}
  .s1-hud-timer{font-size:clamp(.5rem,3vw,.8rem)}
  .intro-headline{font-size:clamp(1.6rem,10vw,2.8rem)}
  .exp-scene-nav{bottom:.5rem;padding:.25rem .5rem;gap:.4rem}
  .exp-btn--nav{padding:.3rem .5rem;font-size:.68rem}
  .exp-hud{padding:.4rem .7rem}
  .hud-logo{font-size:.75rem}
  .s3-emoji-tray{justify-content:center}
  .s10-page-nav{justify-content:center}
  .s2-palette{flex-direction:column;align-items:flex-start}
}

/* ═══════════════════════════════════════════════════════════════
   HUD — DOTS NAVIGATION
   ═══════════════════════════════════════════════════════════════ */
.hud-center{display:flex;flex-direction:column;align-items:center;gap:.3rem}
.hud-dots{display:flex;gap:6px}
.hud-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.15);transition:all .4s var(--ease-out);cursor:pointer;border:none;position:relative}
.hud-dot:hover{background:rgba(255,255,255,.3);transform:scale(1.3)}
.hud-dot.active{background:var(--kpr-bright);box-shadow:0 0 8px rgba(0,229,255,.5);transform:scale(1.2)}
.hud-dot.explored{background:rgba(0,229,255,.4)}
.hud-dot.explored.active{background:var(--kpr-bright)}

/* ═══════════════════════════════════════════════════════════════
   SCENE PROMPTS — Interaction Hints
   ═══════════════════════════════════════════════════════════════ */
.scene-prompt{margin-top:clamp(.75rem,1.5vh,1.5rem);padding:clamp(.5rem,1vh,.9rem) clamp(.8rem,1.5vw,1.5rem);background:rgba(0,229,255,.06);border:1px solid rgba(0,229,255,.15);border-radius:var(--radius-sm);font-size:clamp(.72rem,1vw,.95rem);color:var(--kpr-bright);font-family:var(--font-mono);display:inline-flex;align-items:center;gap:.5rem;animation:promptPulse 3s ease-in-out infinite;transition:all .5s var(--ease-out)}
.scene-prompt.completed{background:rgba(74,222,128,.08);border-color:rgba(74,222,128,.2);color:#4ADE80;animation:none}
.scene-prompt.completed::before{content:'✓ ';font-weight:700}

/* ═══════════════════════════════════════════════════════════════
   TOAST REWARDS  
   ═══════════════════════════════════════════════════════════════ */
.scene-toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%) translateY(20px);z-index:200;background:rgba(10,10,15,.9);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(0,229,255,.2);border-radius:var(--radius);padding:.65rem 1.2rem;display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--text-1);opacity:0;transition:all .4s var(--ease-spring);pointer-events:none;box-shadow:0 10px 40px rgba(0,0,0,.4)}
.scene-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.scene-toast[hidden]{display:none}
.scene-toast-icon{font-size:1.1rem;flex-shrink:0}

/* ═══════════════════════════════════════════════════════════════
   S1 — CLUTTER GAME (Aufräumen)
   ═══════════════════════════════════════════════════════════════ */
#s1-clutter{position:absolute;inset:0;pointer-events:auto;z-index:10}
.s1-clutter-item{position:absolute;padding:clamp(8px,1.2vh,14px) clamp(10px,1.5vw,20px);border-radius:8px;font-size:clamp(.58rem,.8vw,.75rem);color:#1a1a1a;cursor:pointer;animation:clutterIn .5s var(--ease-spring) both;transition:transform .3s var(--ease-spring),opacity .3s;display:flex;align-items:center;gap:6px;font-weight:600;box-shadow:0 4px 15px rgba(0,0,0,.2)}
.s1-clutter-item:hover{transform:scale(1.08);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.s1-clutter-item.removing{transform:scale(0) rotate(20deg);opacity:0}
.s1-cl-x{font-size:clamp(.8rem,1vw,1.1rem);opacity:.5;margin-left:6px;transition:opacity .2s}
.s1-clutter-item:hover .s1-cl-x{opacity:1}
.s1-cl--cookie{bottom:8px;left:8px;right:8px;background:#FFF3CD;border:1px solid #FFE69C;border-radius:0 0 8px 8px;animation-delay:.2s}
.s1-cl--popup{top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#FF6B6B,#FF3D3D);color:#fff;padding:clamp(12px,2vh,22px) clamp(14px,2vw,26px);border-radius:12px;font-size:clamp(.65rem,.9vw,.85rem);box-shadow:0 8px 30px rgba(255,61,61,.3);animation-delay:.5s;z-index:2}
.s1-cl--chat{bottom:60px;right:10px;background:#4CAF50;color:#fff;border-radius:20px 20px 4px 20px;padding:clamp(6px,1vh,12px) clamp(10px,1.5vw,18px);animation-delay:.8s}
.s1-cl--banner{top:8px;left:50%;transform:translateX(-50%);background:linear-gradient(90deg,#7B1FA2,#9C27B0);color:#fff;border-radius:6px;padding:clamp(6px,1vh,12px) clamp(12px,2vw,22px);font-size:clamp(.55rem,.75vw,.68rem);letter-spacing:.05em;animation-delay:1.1s;white-space:nowrap}
.s1-clear-msg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:clamp(1.2rem,2vw,2rem);color:#111;opacity:0;animation:fadeInUp .8s var(--ease-out) forwards;pointer-events:none}
/* additional clutter already in SCENE 1 CSS block above (video, social, notif, survey) */

/* ═══════════════════════════════════════════════════════════════
   S2 — ACCENT PALETTE PICKER
   ═══════════════════════════════════════════════════════════════ */
.s2-palette{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.s2-palette-label{font-family:var(--font-mono);font-size:.72rem;color:var(--text-3);letter-spacing:.1em}
.s2-color{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border-radius:999px;font-size:.72rem;color:var(--text-2);border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.03);transition:all .3s var(--ease-out);cursor:pointer}
.s2-color:hover{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.06)}
.s2-color.active{border-color:var(--swatch);color:var(--swatch);background:rgba(255,255,255,.06)}
.s2-swatch{display:block;width:14px;height:14px;border-radius:50%;background:var(--swatch);transition:transform .3s var(--ease-spring);box-shadow:0 0 8px color-mix(in srgb,var(--swatch) 40%,transparent)}
.s2-color.active .s2-swatch{transform:scale(1.3)}

/* ═══════════════════════════════════════════════════════════════
   S3 — EMOJI DRAG & DROP + VIBE SWITCHER
   ═══════════════════════════════════════════════════════════════ */
.s3-emoji-tray{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}
.s3-emoji-label{font-family:var(--font-mono);font-size:.68rem;color:var(--text-3);letter-spacing:.1em}
.s3-emoji-drag{font-size:1.5rem;cursor:grab;transition:transform .2s;user-select:none}
.s3-emoji-drag:hover{transform:scale(1.3)}
.s3-emoji-drag:active{cursor:grabbing;transform:scale(1.1)}
.s3-emoji-drag.dragging{opacity:.3;transform:scale(.8)}
#s3-dropped{position:absolute;inset:0;pointer-events:none;z-index:5}
.s3-placed-emoji{position:absolute;font-size:1.6rem;animation:emojiDrop .5s var(--ease-spring) both;pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}
#s3-dropzone{position:relative}
#s3-dropzone.drag-over{box-shadow:inset 0 0 30px rgba(196,78,255,.2)}

/* ═══════════════════════════════════════════════════════════════
   S4 — DASHBOARD VIEWS & TOGGLES
   ═══════════════════════════════════════════════════════════════ */
.s4m-view{display:none}
.s4m-view.active{display:block;animation:fadeInUp .4s var(--ease-out)}
.s4m-settings{display:flex;flex-direction:column;gap:8px}
.s4m-setting{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:8px;font-size:.65rem;color:var(--text-2)}
.s4m-toggle{width:36px;height:20px;border-radius:10px;background:rgba(255,255,255,.1);position:relative;cursor:pointer;transition:background .3s}
.s4m-toggle::after{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .3s var(--ease-spring)}
.s4m-toggle.on{background:rgba(88,80,236,.6)}
.s4m-toggle.on::after{transform:translateX(16px)}
.s4m-sidebar-item{cursor:pointer;transition:all .3s var(--ease-out)}
.s4m-sidebar-item:hover{background:rgba(88,80,236,.08);color:#9D96FF}

/* ═══════════════════════════════════════════════════════════════
   S5 — TERMINAL INPUT
   ═══════════════════════════════════════════════════════════════ */
.s5m-input-wrap{display:flex;align-items:center;gap:8px;padding-top:8px;border-top:1px solid rgba(0,255,65,.1);margin-top:8px}
.s5m-input{background:transparent;border:none;color:#00FF41;font-family:var(--font-mono);font-size:.65rem;flex:1;outline:none;caret-color:#00FF41}
.s5m-input::placeholder{color:rgba(0,255,65,.25)}
.s5m-lines{max-height:180px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(0,255,65,.2) transparent}
.s5m-lines::-webkit-scrollbar{width:4px}
.s5m-lines::-webkit-scrollbar-thumb{background:rgba(0,255,65,.2);border-radius:2px}
.s5-term-success{color:#00FF41;text-shadow:0 0 10px rgba(0,255,65,.3)}
.s5-term-error{color:#FF6B6B}
.s5-term-info{color:#60A5FA}
.s5-term-warning{color:#FFE100}

/* ═══════════════════════════════════════════════════════════════
   S6 — OVERCLOCK BARS (Klick-Game)
   ═══════════════════════════════════════════════════════════════ */
.s6-clickbar{cursor:pointer;transition:all .2s;position:relative}
.s6-clickbar:hover{background:rgba(0,229,255,.06)}
.s6-clickbar:active{transform:scale(.97)}
.s6-bar-fill{position:absolute;left:0;top:0;bottom:0;border-radius:3px;transition:width .2s var(--ease-out);z-index:0}
#s6-bar-cpu{background:linear-gradient(90deg,rgba(0,229,255,.3),rgba(0,229,255,.7));width:0}
#s6-bar-mem{background:linear-gradient(90deg,rgba(255,61,222,.3),rgba(255,61,222,.7));width:0}
#s6-bar-gpu{background:linear-gradient(90deg,rgba(255,225,0,.3),rgba(255,225,0,.7));width:0}
.s6-bar-pct{font-family:var(--font-mono);font-size:.5rem;color:var(--text-3);position:relative;z-index:1;min-width:28px;text-align:right}
.s6-hud-bar em{position:relative;z-index:1}
.s6-hud-bar span:first-child{position:relative}
.s6-overclock-msg{text-align:center;padding:12px;font-family:var(--font-display);font-size:.9rem;color:var(--kpr-accent);letter-spacing:.2em;animation:glitch1 .3s infinite,hudBreathe 1s ease-in-out infinite;text-shadow:0 0 20px rgba(255,61,222,.5)}
.s6-overclock-msg[hidden]{display:none}
.s6-overclocked{animation:rainbowBg 3s linear infinite!important}
.s6-overclocked *{animation-play-state:running!important}

/* ═══════════════════════════════════════════════════════════════
   S7 — GARDEN PLANTING
   ═══════════════════════════════════════════════════════════════ */
.s7-garden{padding:12px}
.s7-soil{display:flex;justify-content:center;gap:12px;padding:16px;background:linear-gradient(to bottom,transparent,rgba(101,67,33,.15) 60%,rgba(101,67,33,.3));border-radius:0 0 10px 10px;min-height:100px;align-items:flex-end}
.s7-seed{font-size:1.5rem;background:none;border:none;cursor:pointer;transition:all .4s var(--ease-spring);transform-origin:bottom center;padding:4px;animation:seedBounce 2s ease-in-out infinite;animation-delay:calc(var(--i,0) * .2s)}
.s7-seed:hover{transform:scale(1.2)}
.s7-seed.planted{font-size:2rem;animation:plantGrow .8s var(--ease-spring) forwards;cursor:default;pointer-events:none}
.s7-seed.planted.stage-2{font-size:2.2rem}
.s7-seed.planted.stage-3{font-size:2.5rem}
.s7-garden-status{text-align:center;padding:8px;font-family:var(--font-mono);font-size:.65rem;color:#6B7B5C}
.s7-garden-complete{animation:gardenCelebrate 1s var(--ease-spring)}

/* ═══════════════════════════════════════════════════════════════
   S8 — BLOCK ROTATION
   ═══════════════════════════════════════════════════════════════ */
.s8-block{cursor:pointer;transition:transform .4s var(--ease-spring),box-shadow .3s}
.s8-block:active{transform:scale(.95)!important}
.s8-block.rotating{animation:blockSpin .4s var(--ease-spring)}

/* ═══════════════════════════════════════════════════════════════
   S9 — PROCESS STEPS (Sequential Unlock)
   ═══════════════════════════════════════════════════════════════ */
.s9-step.clickable{cursor:pointer}
.s9-step.clickable:hover .s9-step-num{transform:scale(1.15);box-shadow:0 0 12px rgba(96,165,250,.3)}
.s9-step.locked{opacity:.4;pointer-events:none}
.s9-step.completed .s9-step-num{background:rgba(74,222,128,.2);border-color:#4ADE80;color:#4ADE80}
.s9-step.active-step .s9-step-num{animation:pulse 1.5s ease-in-out infinite;box-shadow:0 0 15px rgba(96,165,250,.4)}
.s9-detail{margin-top:.75rem}
.s9-detail-card{background:rgba(96,165,250,.06);border:1px solid rgba(96,165,250,.15);border-radius:var(--radius-sm);padding:1rem;font-size:.82rem;color:var(--text-2);line-height:1.6;animation:fadeInUp .4s var(--ease-out)}

/* ═══════════════════════════════════════════════════════════════
   S10 — MAGAZINE PAGES
   ═══════════════════════════════════════════════════════════════ */
.s10-page-nav{display:flex;align-items:center;gap:1rem;margin-top:.75rem}
.s10-page-btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(138,125,107,.3);display:flex;align-items:center;justify-content:center;font-size:1rem;color:#8A7D6B;transition:all .3s;cursor:pointer;background:none}
.s10-page-btn:hover:not(:disabled){background:rgba(138,125,107,.1);border-color:#8A7D6B;transform:scale(1.1)}
.s10-page-btn:disabled{opacity:.3;cursor:not-allowed}
.s10-page-counter{font-family:var(--font-mono);font-size:.72rem;color:var(--text-3);letter-spacing:.1em}
.s10-page-content{display:none}
.s10-page-content.active{display:block;animation:pageFlip .5s var(--ease-out)}

/* ═══════════════════════════════════════════════════════════════
   S11 — FLIP CARDS (3D)
   ═══════════════════════════════════════════════════════════════ */
.s11-flip-card{perspective:1000px;cursor:pointer}
.s11-flip-card--wide{grid-column:1/4}
.s11-flip-inner{position:relative;width:100%;transition:transform .6s var(--ease-spring);transform-style:preserve-3d}
.s11-flip-card.flipped .s11-flip-inner{transform:rotateY(180deg)}
.s11-flip-front,.s11-flip-back{backface-visibility:hidden;-webkit-backface-visibility:hidden}
.s11-flip-back{position:absolute;inset:0;transform:rotateY(180deg);display:flex;flex-direction:column;gap:6px}
.s11-back-detail{font-family:var(--font-mono);font-size:.6rem;color:var(--text-2);line-height:1.8}

/* ═══════════════════════════════════════════════════════════════
   S12 — RECOMMENDATION CARD
   ═══════════════════════════════════════════════════════════════ */
.s12-recommendation{margin-top:clamp(.75rem,2vh,2rem);border:3px solid #111;max-width:clamp(340px,45vw,750px);width:100%;overflow:hidden;animation:fadeInUp .6s var(--ease-out)}
.s12-recommendation[hidden]{display:none}
.s12-rec-title{background:#FF3D3D;color:#fff;padding:8px 16px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase}
.s12-rec-style{padding:clamp(12px,2vh,28px) clamp(16px,2vw,32px);font-family:var(--font-display);font-size:clamp(1.2rem,2vw,2.5rem);font-weight:700;color:#111;border-bottom:2px solid #111}
.s12-rec-reason{padding:12px 16px;font-size:.8rem;color:#555;line-height:1.6}

/* ═══════════════════════════════════════════════════════════════
   EXTRA KEYFRAMES for Game Mechanics
   ═══════════════════════════════════════════════════════════════ */
@keyframes clutterIn{from{opacity:0;transform:scale(0) rotate(-10deg)}to{opacity:1;transform:scale(1) rotate(0)}}
@keyframes clutterIn{0%{opacity:0;transform:scale(0) rotate(-10deg) translateY(20px)}100%{opacity:1;transform:scale(1) rotate(0) translateY(0)}}
@keyframes emojiDrop{from{opacity:0;transform:scale(0) rotate(-20deg)}to{opacity:1;transform:scale(1) rotate(0)}}
@keyframes promptPulse{0%,100%{box-shadow:0 0 0 rgba(0,229,255,0)}50%{box-shadow:0 0 15px rgba(0,229,255,.1)}}
@keyframes seedBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes plantGrow{0%{transform:scale(0) translateY(20px);opacity:0}50%{transform:scale(1.3) translateY(-5px)}100%{transform:scale(1) translateY(0);opacity:1}}
@keyframes gardenCelebrate{0%{transform:scale(1)}50%{transform:scale(1.02)}100%{transform:scale(1)}}
@keyframes blockSpin{0%{transform:rotate(0) scale(.95)}50%{transform:rotate(45deg) scale(1.05)}100%{transform:rotate(90deg) scale(1)}}
@keyframes pageFlip{0%{opacity:0;transform:perspective(800px) rotateY(-20deg)}100%{opacity:1;transform:perspective(800px) rotateY(0)}}
@keyframes barGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes hudGlow{0%,100%{box-shadow:0 0 0 rgba(0,229,255,0)}50%{box-shadow:0 0 30px rgba(0,229,255,.15)}}

/* ═══ Accessibility — prefers-reduced-motion ═════════════════ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.2s!important}
  .boot-seq{display:none}
  .cursor-wrap{display:none}
}

/* ═══════════════════════════════════════════════════════════════
   DEEP INTERACTION CSS — Gate, S2 Pickers, S4 Notifs,
   S6 Flash, S7 Weather, S8 Chaos/Drag, S11 Timer, S12 DNA
   ════════════════════════════════════════════════════════════ */

/* ── Gate Hint ─────────────────────────────────────────────── */
.gate-hint{position:fixed;bottom:3rem;left:50%;transform:translateX(-50%);z-index:800;font:600 .85rem/1 var(--f-body);color:var(--c-text-muted,.6);background:rgba(10,10,20,.65);border:1px solid rgba(255,255,255,.08);padding:.6rem 1.4rem;border-radius:999px;opacity:0;pointer-events:none;transition:opacity .4s,transform .4s;backdrop-filter:blur(8px);letter-spacing:.03em}
.gate-hint.visible{opacity:1;pointer-events:auto}
.gate-hint.ready{color:#00e5ff;border-color:rgba(0,229,255,.25);animation:gateReady 1.5s ease infinite}
.gate-hint.pulse{animation:gatePulse .6s ease}
@keyframes gateReady{0%,100%{box-shadow:0 0 0 rgba(0,229,255,0)}50%{box-shadow:0 0 20px rgba(0,229,255,.2)}}
@keyframes gatePulse{0%{transform:translateX(-50%) scale(1)}50%{transform:translateX(-50%) scale(1.08)}100%{transform:translateX(-50%) scale(1)}}

/* ── S2: Font + Layout Pickers ────────────────────────────── */
.s2-fonts,.s2-layouts{display:flex;align-items:center;gap:.5rem;margin-top:.6rem;flex-wrap:wrap}
.s2-label{font:600 .7rem/1 var(--f-body);color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.08em;min-width:3rem}
.s2-font,.s2-layout{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.7);padding:.35rem .7rem;border-radius:6px;cursor:pointer;font-size:.75rem;transition:all .25s}
.s2-font:hover,.s2-layout:hover{background:rgba(255,255,255,.12);color:#fff}
.s2-font.active,.s2-layout.active{background:rgba(0,229,255,.15);border-color:rgba(0,229,255,.4);color:#00e5ff}

/* S2 Layout Variants */
.layout-split .mockup-body{display:grid!important;grid-template-columns:1fr 1fr;gap:.5rem}
.layout-cards .mockup-body{display:flex!important;flex-wrap:wrap;gap:.4rem}
.layout-cards .mockup-body > *{flex:1 1 45%;min-width:0}

/* ── S4: Live Notifications ───────────────────────────────── */
.s4m-notif-bell{padding:.5rem;margin-top:auto;cursor:pointer;font-size:1rem;position:relative;transition:transform .2s}
.s4m-notif-bell:hover{transform:scale(1.15)}
.s4m-notif-badge{position:absolute;top:2px;right:2px;background:#ff4444;color:#fff;font:700 .55rem/1 var(--f-body);padding:1px 4px;border-radius:99px;min-width:14px;text-align:center}
.s4m-notif-popup{position:absolute;top:1rem;right:1rem;background:rgba(0,229,255,.12);border:1px solid rgba(0,229,255,.25);color:#fff;padding:.5rem .8rem;border-radius:8px;font:.7rem/1.3 var(--f-body);opacity:0;transform:translateY(-10px) scale(.95);transition:all .35s;z-index:10;backdrop-filter:blur(6px);max-width:60%}
.s4m-notif-popup.visible{opacity:1;transform:translateY(0) scale(1)}

/* ── S6: Flash effect + Warning ───────────────────────────── */
.s6-bar-fill.s6-flash{filter:brightness(2)!important;transition:filter .1s}

/* ── S7: Weather Controls ─────────────────────────────────── */
.s7-weather-controls{display:flex;align-items:center;gap:.5rem;justify-content:center;margin-bottom:.6rem;padding:.4rem .8rem;background:rgba(255,255,255,.04);border-radius:8px;border:1px solid rgba(255,255,255,.06)}
.s7-weather-label{font:600 .65rem/1 var(--f-body);color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.08em}
.s7-weather{background:none;border:1px solid rgba(255,255,255,.1);padding:.3rem .5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .25s}
.s7-weather:hover{background:rgba(255,255,255,.08);transform:scale(1.1)}
.s7-weather.active{background:rgba(0,229,255,.12);border-color:rgba(0,229,255,.35);box-shadow:0 0 8px rgba(0,229,255,.15)}
.s7-weather-info{font:.65rem/1 var(--f-body);color:rgba(0,229,255,.7);letter-spacing:.03em}

/* Weather scene overlays */
.weather-rain .scene-bg::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(180deg,transparent,transparent 20px,rgba(100,180,255,.04) 20px,rgba(100,180,255,.04) 21px);animation:rainDrip 1s linear infinite;pointer-events:none;z-index:1}
.weather-wind .scene-bg::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(255,255,255,.015) 40px,rgba(255,255,255,.015) 42px);animation:windBlow 2s linear infinite;pointer-events:none;z-index:1}
.weather-magic .scene-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,215,0,.06),transparent 60%);animation:magicPulse 2s ease infinite;pointer-events:none;z-index:1}
@keyframes rainDrip{from{background-position:0 0}to{background-position:0 21px}}
@keyframes windBlow{from{background-position:0 0}to{background-position:42px 0}}
@keyframes magicPulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}

/* ── S8: Drag + Chaos ─────────────────────────────────────── */
.s8-block{cursor:grab;user-select:none;transition:transform .3s,background .3s,translate .3s}
.s8-block.dragging{cursor:grabbing;z-index:10;opacity:.85;filter:brightness(1.3)}
.s8-chaos-btn{position:absolute;bottom:.8rem;right:.8rem;z-index:5;background:rgba(255,68,68,.12)!important;border:1px solid rgba(255,68,68,.3)!important;color:#ff6666!important;padding:.35rem .8rem;border-radius:6px;cursor:pointer;font:.7rem/1 var(--f-body);transition:all .25s;letter-spacing:.03em}
.s8-chaos-btn:hover{background:rgba(255,68,68,.2)!important;transform:scale(1.05)}

/* ── S11: Timer ───────────────────────────────────────────── */
.s11-timer{position:absolute;top:1rem;right:1.5rem;font:700 .85rem/1 var(--f-mono);color:rgba(0,229,255,.7);background:rgba(0,229,255,.06);border:1px solid rgba(0,229,255,.15);padding:.3rem .7rem;border-radius:6px;z-index:5}

/* ── S12: Typewriter + DNA Bars ───────────────────────────── */
.s12-typing{border-right:2px solid #00e5ff;animation:s12Blink .7s step-end infinite}
.s12-typed{border-right:none}
@keyframes s12Blink{50%{border-color:transparent}}

.s12-dna-bars{margin-top:1.2rem;padding:.8rem;background:rgba(255,255,255,.03);border-radius:10px;border:1px solid rgba(255,255,255,.06)}
.s12-dna-title{font:700 .7rem/1 var(--f-body);text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.4);margin-bottom:.8rem}
.s12-dna-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}
.s12-dna-label{flex:0 0 5rem;font:.65rem/1 var(--f-body);color:rgba(255,255,255,.55);text-align:right}
.s12-dna-track{flex:1;height:6px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden}
.s12-dna-fill{height:100%;background:linear-gradient(90deg,#00e5ff,#ff00ff);border-radius:3px;transition:width 1s cubic-bezier(.4,0,.2,1);width:0}
.s12-dna-pct{flex:0 0 2.5rem;font:700 .65rem/1 var(--f-mono);color:rgba(0,229,255,.7);transition:color .5s}

.s12-rec-reveal{animation:s12RecReveal .8s ease both}
@keyframes s12RecReveal{from{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
