/* =================================================================
   AHMD.GPT — V2  ·  Cinematic AI UGC Agency
   Syne · indigo-black · film grain · Apple Liquid Glass
   ================================================================= */

:root{
  --bg:           #0A0A0C;   /* near-black, slight cool tone */
  --surface:      #141014;   /* dark surface, faint red undertone */
  --surface-2:    #0F0C10;
  --border:       #2A1A1D;   /* dark red-tinted border */
  --text:         #F2EDEE;
  --muted:        #8A7C7E;
  --muted-2:      #5a4a4d;
  --accent:       #FF2A3C;   /* RED is primary — brighter, more saturated */
  --accent-light: #FF5A68;
  --accent-dim:   rgba(255,42,60,.14);
  --accent-glow:  rgba(255,42,60,.35);
  --accent-red:       #FF2A3C;  /* kept for legacy refs — same bright red */
  --accent-red-glow:  rgba(255,42,60,.45);
  --accent-red-dim:   rgba(255,42,60,.14);
  --gold:         #D4A853;   /* demoted — ONLY "Most Popular" badge + star ratings */
  --green:        #00FF85;   /* LIVE indicators only */
  --glass-bg:     rgba(255,255,255,.05);
  --glass-border: rgba(255,255,255,.10);

  --display: 'Syne', system-ui, sans-serif;
  --sans:    'Inter', system-ui, sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, monospace;

  --ease: cubic-bezier(.22,.61,.36,1);
  --nav-h: 64px;
  --maxw: 1200px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
/* global horizontal-overflow safety net */
html,body{overflow-x:hidden!important;max-width:100vw;position:relative}
body{
  background:var(--bg);color:var(--text);
  font-family:var(--sans);font-size:15px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}
svg{display:block}
em{font-style:italic}
::selection{background:var(--accent);color:#0A0A0C}

/* scrollbar */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--border)}
::-webkit-scrollbar-thumb{background:var(--accent)}
html{scrollbar-width:thin;scrollbar-color:var(--accent) var(--border)}

/* live film grain — canvas random noise (JS); sits BEHIND content (z-index:0), shows only on the background */
#grain-canvas{position:fixed;inset:0;width:100vw;height:100vh;pointer-events:none;z-index:0;opacity:.05;mix-blend-mode:normal}
/* lift all section content above the grain so it never overlays text/cards/buttons */
.hero,.section,footer,.eye-banner,.marquee{position:relative;z-index:1}
/* cursor spotlight */
body::after{
  content:'';position:fixed;inset:0;z-index:9998;pointer-events:none;
  background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%),var(--accent-glow),transparent 60%);
}

/* black-fill arrow with white outline (two-layer: white stroke, then black fill on top) */
:root{
  --cursor-main:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'%3E%3Cpath d='M 5 2 L 5 22 L 9.5 17.5 L 13.5 25.5 L 16.5 24 L 12.5 16 L 19 16 Z' fill='white' stroke='white' stroke-width='3' stroke-linejoin='round' stroke-linecap='round'/%3E%3Cpath d='M 5 2 L 5 22 L 9.5 17.5 L 13.5 25.5 L 16.5 24 L 12.5 16 L 19 16 Z' fill='%23111111' stroke='none'/%3E%3C/svg%3E") 5 2, auto;
  --cursor-text:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='26' viewBox='0 0 16 26'%3E%3Cpath d='M3 2 L3 4 M3 22 L3 24 M3 4 Q3 4 8 4 Q13 4 13 4 M3 22 Q3 22 8 22 Q13 22 13 22 M8 4 L8 22' stroke='white' stroke-width='2.5' stroke-linecap='round' fill='none'/%3E%3Cpath d='M3 2 L3 4 M3 22 L3 24 M3 4 Q3 4 8 4 Q13 4 13 4 M3 22 Q3 22 8 22 Q13 22 13 22 M8 4 L8 22' stroke='%23111111' stroke-width='1.2' stroke-linecap='round' fill='none'/%3E%3C/svg%3E") 8 13, text;
}
*{cursor:var(--cursor-main)!important}
input[type="text"],input[type="email"],input[type="url"],textarea,[contenteditable]{cursor:var(--cursor-text)!important}
.work-track,.work-railwrap{cursor:grab!important}
.work-track:active,.work-railwrap:active{cursor:grabbing!important}

/* =================================================================
   LIQUID GLASS
   ================================================================= */
.glass{
  position:relative;
  background:var(--glass-bg);
  backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);
  border:1px solid var(--glass-border);border-top-color:rgba(255,255,255,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),inset 0 -1px 0 rgba(0,0,0,.2),
             0 8px 32px rgba(0,0,0,.4),0 2px 8px rgba(0,0,0,.2);
  border-radius:16px;
}
.glass::before{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(135deg,rgba(255,100,100,.05),rgba(100,255,200,.05) 25%,rgba(100,150,255,.05) 50%,rgba(255,200,100,.05) 75%,rgba(255,100,200,.05));
  opacity:0;transition:opacity .4s var(--ease);z-index:0;
}
.glass:hover::before{opacity:1}
.glass > *{position:relative;z-index:1}

/* =================================================================
   TYPOGRAPHY HELPERS
   ================================================================= */
.section{max-width:var(--maxw);margin:0 auto;padding:120px 32px}

/* ambient gold glow per section */
section{position:relative}
.section > *{position:relative;z-index:1}
section::after{content:'';position:absolute;width:600px;height:400px;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse,rgba(255,42,60,.06) 0%,transparent 70%);
  animation:sectionGlowDrift 12s ease-in-out infinite alternate}
section:nth-of-type(odd)::after{bottom:-120px;left:-120px}
section:nth-of-type(even)::after{top:-120px;right:-120px}
@keyframes sectionGlowDrift{from{transform:translate(0,0) scale(1);opacity:.6}to{transform:translate(40px,30px) scale(1.2);opacity:1}}
.section-head{margin-bottom:54px}
.section-head.center{text-align:center}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px}
.section-head.center .eyebrow{justify-content:center}
.section-title{font-family:var(--display);font-weight:700;letter-spacing:-.03em;line-height:1.02;
  font-size:clamp(2.5rem,6vw,4.5rem);margin-top:14px}
.section-title em{color:var(--accent-light);font-style:italic}
.section-lead{color:var(--muted);max-width:540px;margin:18px auto 0;font-size:1rem}
.section-head:not(.center) .section-lead{margin-left:0}

/* =================================================================
   BUTTONS
   ================================================================= */
.btn{display:inline-flex;align-items:center;gap:9px;font-size:14px;font-weight:500;
  padding:14px 28px;border-radius:100px;
  backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);
  transition:background .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease}
.btn .arr,.btn .arr-d{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn:hover .arr-d{transform:translateY(3px)}
/* secondary glass */
.btn-ghost{background:rgba(255,255,255,.08);color:var(--text);
  border:1px solid rgba(255,255,255,.14);border-top-color:rgba(255,255,255,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10),inset 0 -1px 0 rgba(0,0,0,.15),0 4px 24px rgba(0,0,0,.3)}
.btn-ghost:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.20);transform:translateY(-1px)}
/* primary — gold-tinted glass + glow */
.btn-gold{background:rgba(255,42,60,.16);color:var(--accent-light);
  border:1px solid rgba(255,42,60,.30);border-top-color:rgba(255,42,60,.50);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 0 0 1px rgba(255,42,60,.5),0 0 32px var(--accent-glow)}
.btn-gold:hover{background:rgba(255,42,60,.24);transform:translateY(-2px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 0 0 1px rgba(255,42,60,.6),0 0 40px rgba(255,42,60,.40)}
.btn.full{width:100%;justify-content:center}
.pill{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--accent);color:var(--accent-light);
  border-radius:100px;padding:9px 20px;font-size:13px;font-weight:500;transition:background .3s,color .3s;
  animation:navBtnPulse 3s ease infinite}
.pill:hover{background:var(--accent);color:#0A0A0C}
.pill:hover .arr{transform:translateX(3px)}
@keyframes navBtnPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,42,60,.3)}50%{box-shadow:0 0 0 6px rgba(255,42,60,0)}}

/* =================================================================
   NAV
   ================================================================= */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;padding:14px 28px;
  transition:background .35s,border-color .35s}
.nav.scrolled{margin:12px 18px 0;height:auto;padding:12px 22px;border-radius:16px;width:calc(100% - 36px)}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:24px;height:24px;color:var(--accent)}
.brand-mark svg{width:100%;height:100%}
.brand-text{font-family:var(--display);font-weight:700;font-size:1.18rem;letter-spacing:-.02em}
.nav-links{display:flex;gap:30px}
.nav-links a{font-size:14px;font-weight:500;color:var(--muted);transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-5px;height:1.5px;width:100%;background:var(--accent-light);
  transform:scaleX(0);transform-origin:left;transition:transform .2s ease}
.nav-links a:hover{color:var(--accent-light)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-right{display:flex;align-items:center;gap:16px}
.burger{display:none;width:30px;height:26px;flex-direction:column;justify-content:center;gap:7px;align-items:flex-end}
.burger span{display:block;height:1.6px;background:var(--text);transition:.3s var(--ease)}
.burger span:nth-child(1){width:26px}.burger span:nth-child(2){width:17px}

/* =================================================================
   FULLSCREEN MENU
   ================================================================= */
.overlay{position:fixed;inset:0;z-index:80;background:var(--bg);
  clip-path:inset(100% 0 0 0);transition:clip-path .55s var(--ease);
  display:flex;flex-direction:column;padding:26px 40px 40px;overflow:hidden}
.overlay.open{clip-path:inset(0 0 0 0)}
.overlay[aria-hidden="true"]{pointer-events:none}
.overlay.open{pointer-events:auto}
.overlay-eye{position:absolute;right:-40px;top:48%;transform:translateY(-50%);width:60vw;max-width:760px;color:var(--text);opacity:.05;pointer-events:none}
.overlay-eye svg{width:100%;height:auto}
.overlay-top{display:flex;align-items:center;justify-content:space-between}
.overlay-close{font-size:34px;line-height:1;color:var(--text);width:44px;height:44px;transition:transform .3s,color .3s}
.overlay-close:hover{transform:rotate(90deg);color:var(--accent)}
.overlay-links{flex:1;display:flex;flex-direction:column;justify-content:center;gap:4px}
.overlay-links a{font-family:var(--display);font-weight:800;letter-spacing:-.03em;line-height:1.05;
  font-size:clamp(2.8rem,8vw,6rem);color:var(--text);width:max-content;max-width:100%;position:relative;
  opacity:0;transform:translateY(30px);transition:transform .25s var(--ease),color .25s}
.overlay.open .overlay-links a{opacity:1;transform:translateY(0);transition:opacity .5s var(--ease) calc(.25s + var(--i)*.06s),transform .5s var(--ease) calc(.25s + var(--i)*.06s)}
.overlay-links a::after{content:'';position:absolute;left:0;bottom:.08em;height:2px;width:100%;background:var(--accent);
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.overlay-links a:hover{color:var(--accent);transform:translateX(12px)}
.overlay-links a:hover::after{transform:scaleX(1)}
.overlay-foot{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  border-top:1px solid var(--border);padding-top:22px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted)}
.overlay-socials{display:flex;gap:22px}
.overlay-socials a:hover,.overlay-mail:hover{color:var(--accent)}

/* =================================================================
   HERO
   ================================================================= */
.hero{position:relative;overflow:hidden;min-height:100vh;display:flex;align-items:flex-start;justify-content:center;text-align:center;
  padding:100px 24px 60px}
/* hero video background */
.hero-video-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-video-bg video{width:100%;height:100%;object-fit:cover;object-position:center;opacity:.25}
.hero-video-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 20%,#0D0B14 80%),linear-gradient(to bottom,#0D0B14 0%,transparent 30%,transparent 70%,#0D0B14 100%)}
.hero::before{content:'';position:absolute;top:18%;left:50%;width:1px;height:42%;z-index:0;
  background:linear-gradient(to bottom,transparent,rgba(255,42,60,.14),transparent);
  transform:translateX(-50%);animation:streakPulse 6s ease-in-out infinite}
@keyframes streakPulse{0%,100%{opacity:0}50%{opacity:1}}
.hero-inner{max-width:820px;width:100%;position:relative;z-index:2}
.kicker{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--muted);margin-bottom:18px}

/* floating particles */
.particle{position:absolute;z-index:1;background:var(--accent);border-radius:50%;pointer-events:none;animation:particleFloat linear infinite}
@keyframes particleFloat{0%{transform:translateY(0) translateX(0);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(-120px) translateX(30px);opacity:0}}

/* radial glow behind eye */
.eye-glow-bg{position:absolute;top:50%;left:50%;width:500px;height:300px;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse,rgba(255,42,60,.09) 0%,transparent 70%);
  transform:translate(-50%,-50%);animation:eyeGlowPulse 5s ease-in-out infinite}
@keyframes eyeGlowPulse{0%,100%{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}}
.eye-wrap{position:relative;display:flex;justify-content:center;margin-bottom:4px}
.eye{position:relative;z-index:1;width:clamp(260px,32vw,380px);height:auto;overflow:visible;transform-origin:center center;
  animation:heroEyeOpen 1.2s cubic-bezier(.16,1,.3,1) .3s both,eyeGlowAlternate 5s ease-in-out 1.5s infinite}
@keyframes heroEyeOpen{0%{transform:scaleY(.05)}60%{transform:scaleY(1.15)}100%{transform:scaleY(1)}}
/* dual-tone glow — gold breathes into a red flash and back */
@keyframes eyeGlowAlternate{
  0%,100%{filter:drop-shadow(0 0 18px rgba(255,42,60,.45))}
  50%{filter:drop-shadow(0 0 26px rgba(255,42,60,.3)) drop-shadow(0 0 16px rgba(255,42,60,.4))}}

.eye-line{stroke:var(--text);stroke-width:2}
.lashes line{stroke:var(--text);stroke-width:2;stroke-linecap:round}
#fibres{transform-box:fill-box;transform-origin:center;animation:irisRotate 20s linear infinite}
#fibres line{stroke:var(--accent);stroke-width:1;opacity:.55}
@keyframes irisRotate{to{transform:rotate(360deg)}}
.eye-iris{transition:transform .04s linear}
.eye-lid{fill:var(--bg);transform-box:fill-box;transform-origin:center;transform:scaleY(0);animation:blink 6.5s infinite}
@keyframes blink{0%,93%,100%{transform:scaleY(0)}96%{transform:scaleY(1.05)}98%{transform:scaleY(0)}}

.hero-title{font-family:var(--display);font-weight:800;letter-spacing:-.03em;line-height:1.03;
  font-size:clamp(42px,6vw,76px);margin:18px 0 0}
.hero-title .line{display:block}
.hero-title em{color:var(--accent);position:relative;display:inline-block;animation:wordGlitchFlicker 6s ease-in-out infinite}
@keyframes wordGlitchFlicker{
  0%,94%,100%{text-shadow:none;color:var(--accent)}
  95%{text-shadow:-2px 0 var(--accent),2px 0 var(--gold);color:var(--accent-light)}
  96%{text-shadow:2px 0 var(--accent),-2px 0 var(--gold);color:var(--accent)}
  97%{text-shadow:none;color:var(--accent)}}
.hero-sub{color:var(--muted);max-width:500px;margin:18px auto 0;font-size:1rem;line-height:1.65}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:26px}
.hero-cta.center{justify-content:center}
.hero-stats{margin-top:30px;display:inline-flex;align-items:stretch;justify-content:center;flex-wrap:wrap}
.hero-stats .stat{padding:2px 28px;text-align:center}
.hero-stats .stat + .stat{border-left:1px solid var(--border)}
.hero-stats .snum{font-family:var(--display);font-weight:700;font-size:1.45rem;line-height:1;color:var(--text);display:flex;align-items:center;justify-content:center;gap:6px}
.hero-stats .snum .star{color:var(--accent-light)}
.hero-stats .slabel{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-top:7px}

/* process flow */
.process-flow{margin:48px auto 0;display:flex;align-items:flex-start;justify-content:center;max-width:760px;width:100%}
.pf-step{display:flex;flex-direction:column;align-items:center;gap:8px;flex:0 0 auto;opacity:.2;transition:opacity .4s ease}
.pf-node{position:relative;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--border);background:var(--surface);color:var(--accent-light);
  transition:box-shadow .4s ease,border-color .4s ease}
.pf-node svg{width:22px;height:22px}
.pf-node.bounce{animation:nodeBounce .6s cubic-bezier(.34,1.56,.64,1)}
@keyframes nodeBounce{0%{transform:scale(1)}45%{transform:scale(1.15)}100%{transform:scale(1)}}
.pf-burst{position:absolute;inset:0;pointer-events:none}
.pf-burst i{position:absolute;top:50%;left:50%;width:4px;height:4px;border-radius:50%;background:var(--accent-light);opacity:0}
.pf-burst.go i{animation:burstParticle .6s ease-out forwards}
@keyframes burstParticle{from{transform:translate(0,0) scale(1);opacity:1}to{transform:translate(var(--tx),var(--ty)) scale(0);opacity:0}}
.pf-label{font-family:var(--display);font-weight:600;font-size:13px;color:var(--text)}
.pf-sub{font-family:var(--mono);font-size:10px;letter-spacing:.05em;color:var(--muted);margin-top:-4px}
.pf-link{flex:1 1 auto;position:relative;height:48px;display:flex;align-items:center;min-width:30px}
.pf-line{height:1px;width:100%;background:var(--border);transition:background .5s ease}
.pf-badge{position:absolute;top:0;left:50%;transform:translate(-50%,-115%);font-family:var(--mono);font-size:10px;color:var(--muted);
  background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:100px;padding:2px 8px;white-space:nowrap;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}

/* before / after box (hero) */
.before-after-box{display:grid;grid-template-columns:1fr 1fr;border-radius:20px;overflow:hidden;max-width:780px;margin:42px auto 0;
  border:1px solid rgba(255,255,255,.10);border-top-color:rgba(255,255,255,.18);background:rgba(255,255,255,.03);
  backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 8px 32px rgba(0,0,0,.5);text-align:left}
.ba-side{padding:26px 28px}
.ba-left{background:rgba(0,0,0,.2);border-right:1px solid rgba(255,255,255,.08)}
.ba-right{background:rgba(255,42,60,.04);transition:box-shadow 1s ease}
.ba-right.animate{box-shadow:inset 0 0 40px rgba(255,42,60,.08)}
.ba-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;display:inline-block;margin-bottom:16px}
.ba-label-bad{color:#FF4444}
.ba-label-good{color:#00FF85}
.ba-list{list-style:none;display:flex;flex-direction:column;gap:11px}
.before-item{font-size:15px;color:var(--text);text-decoration:line-through;text-decoration-color:transparent;opacity:1}
.before-after-box.animate .before-item{animation:glitchText .45s ease forwards,strikeThrough .4s ease forwards}
.before-after-box.animate .before-item:nth-child(1){animation-delay:.3s,.45s}
.before-after-box.animate .before-item:nth-child(2){animation-delay:.45s,.6s}
.before-after-box.animate .before-item:nth-child(3){animation-delay:.6s,.75s}
.before-after-box.animate .before-item:nth-child(4){animation-delay:.75s,.9s}
.before-after-box.animate .before-item:nth-child(5){animation-delay:.9s,1.05s}
@keyframes strikeThrough{to{text-decoration-color:#FF4444}}
@keyframes glitchText{0%{transform:translateX(0);opacity:1;filter:none}10%{transform:translateX(-3px);filter:hue-rotate(90deg)}20%{transform:translateX(3px);opacity:.8}30%{transform:translateX(-2px);filter:hue-rotate(0deg)}40%{transform:translateX(0);opacity:.5}100%{transform:translateX(0);opacity:.35;filter:none}}
.after-item{font-size:15px;color:var(--text);padding-left:22px;position:relative;opacity:0;transform:translateY(10px)}
.after-item::before{content:'→';position:absolute;left:0;color:var(--accent-light);transform:translateX(-8px);opacity:0}
.before-after-box.animate .after-item{animation:afterIn .5s ease forwards}
.before-after-box.animate .after-item::before{animation:afterArrow .5s ease forwards}
.before-after-box.animate .after-item:nth-child(1){animation-delay:1.2s}
.before-after-box.animate .after-item:nth-child(2){animation-delay:1.32s}
.before-after-box.animate .after-item:nth-child(3){animation-delay:1.44s}
.before-after-box.animate .after-item:nth-child(4){animation-delay:1.56s}
.before-after-box.animate .after-item:nth-child(5){animation-delay:1.68s}
.before-after-box.animate .after-item:nth-child(1)::before{animation-delay:1.2s}
.before-after-box.animate .after-item:nth-child(2)::before{animation-delay:1.32s}
.before-after-box.animate .after-item:nth-child(3)::before{animation-delay:1.44s}
.before-after-box.animate .after-item:nth-child(4)::before{animation-delay:1.56s}
.before-after-box.animate .after-item:nth-child(5)::before{animation-delay:1.68s}
@keyframes afterIn{to{opacity:1;transform:translateY(0)}}
@keyframes afterArrow{to{opacity:1;transform:translateX(0)}}
.ba-note{text-align:center;font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--muted-2);margin:14px auto 0}

/* scroll hint */
.scroll-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;
  animation:scrollHintFade 2s ease-in-out infinite}
.scroll-hint span{font-family:var(--mono);font-size:10px;letter-spacing:.15em;color:var(--muted);text-transform:uppercase}
.scroll-hint-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--accent-light),transparent);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top;opacity:1}50%{transform:scaleY(1);transform-origin:top;opacity:1}100%{transform:scaleY(1);transform-origin:bottom;opacity:0}}
@keyframes scrollHintFade{0%,100%{opacity:.3}50%{opacity:.6}}

/* hero sides: Higgsfield robot characters at desks (vertically centered) */
.hero-sides-wrapper{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:2}
.hero-sides-wrapper .hero-side{pointer-events:none}
/* will-change only on genuinely animated elements (perf) */
.eye{will-change:transform,filter}
.robot-character{will-change:transform}
.hero-crack-overlay{will-change:opacity}
#reboot-overlay{will-change:opacity}
.hero-side{position:absolute;top:0;bottom:0;width:220px;z-index:3;pointer-events:none}
.hero-side-left{left:8px}
.hero-side-right{right:8px}
.robot-station{position:absolute;top:50%;left:50%;margin-left:-95px;transform:translateY(-50%);cursor:pointer;user-select:none;pointer-events:auto;transition:transform .2s ease}
.robot-station:hover{transform:translateY(-50%) scale(1.05)}
.robot-station:active{transform:translateY(-50%) scale(.96)}
.robot-desk-svg{display:block;filter:drop-shadow(0 6px 20px rgba(0,0,0,.4))}
/* idle bob — looks like it's typing */
.robot-character{transform-origin:90px 100px;animation:robotTypingBob 1.8s ease-in-out infinite}
@keyframes robotTypingBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-1.5px)}}
.antenna-light{animation:antennaBlink 2s ease-in-out infinite}
@keyframes antennaBlink{0%,100%{opacity:1}50%{opacity:.3}}
.screen-line{animation:screenFlicker 3s steps(4) infinite}
.screen-line:nth-child(2){animation-delay:.3s}
.screen-line:nth-child(3){animation-delay:.6s}
.screen-line:nth-child(4){animation-delay:.9s}
@keyframes screenFlicker{0%,100%{opacity:1}50%{opacity:.4}}
/* screen glow "rendering" pulse */
.screen-glow{animation:screenPulse 2.5s ease-in-out infinite}
@keyframes screenPulse{0%,100%{opacity:.25}50%{opacity:.5}}
/* speech bubble */
.robot-speech-bubble{position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(8px) scale(.9);margin-bottom:8px;
  background:rgba(255,255,255,.06);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.10);border-radius:14px;
  padding:10px 14px;font-family:var(--sans);font-size:12px;color:var(--text);max-width:160px;width:max-content;text-align:center;
  opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;z-index:4}
.robot-speech-bubble::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:rgba(255,255,255,.08)}
.robot-speech-bubble.visible{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}
.robot-speech-bubble.angry{background:rgba(255,42,60,.15);border-color:var(--accent);color:var(--accent-light);font-weight:700}
.robot-speech-bubble.angry::after{border-top-color:var(--accent)}
/* shake / crack / flash */
@keyframes robotShake{0%,100%{transform:translateX(0) rotate(0)}20%{transform:translateX(calc(var(--shake-x) * -1)) rotate(-2deg)}40%{transform:translateX(var(--shake-x)) rotate(2deg)}60%{transform:translateX(calc(var(--shake-x) * -.6)) rotate(-1deg)}80%{transform:translateX(calc(var(--shake-x) * .6)) rotate(1deg)}}
@keyframes heroShakeKeyframes{0%,100%{transform:translate(0,0)}10%{transform:translate(-6px,2px)}20%{transform:translate(6px,-2px)}30%{transform:translate(-5px,1px)}40%{transform:translate(5px,-1px)}50%{transform:translate(-3px,2px)}60%{transform:translate(3px,-2px)}70%{transform:translate(-2px,1px)}80%{transform:translate(2px,-1px)}90%{transform:translate(-1px,0)}}
.hero.hero-shake{animation:heroShakeKeyframes .5s ease}
.hero-flash{position:absolute;inset:0;background:var(--accent);opacity:.25;z-index:50;pointer-events:none;animation:flashFade .2s ease forwards}
@keyframes flashFade{from{opacity:.35}to{opacity:0}}
.hero-crack-overlay{position:absolute;inset:0;width:100%;height:100%;z-index:40;pointer-events:none}
/* realistic glass shatter: dual-layer (dark shadow + bright edge) + rings + punched hole */
.crack-shadow,.crack-bright,.crack-micro,.crack-hole{fill:none;opacity:0;stroke-linecap:round;stroke-linejoin:round}
.crack-shadow{stroke:rgba(0,0,0,.65);stroke-width:2.5;stroke-dasharray:800;stroke-dashoffset:800;transform:translate(1.5px,1.5px)}
.crack-shadow.crack-ring{stroke-width:1.8;stroke-dasharray:600;stroke-dashoffset:600}
.crack-shadow.crack-ring-outer{stroke-width:1.2;stroke-dasharray:800;stroke-dashoffset:800}
.crack-bright{stroke:rgba(255,255,255,.92);stroke-width:1.5;stroke-dasharray:800;stroke-dashoffset:800;filter:drop-shadow(0 0 2px rgba(255,255,255,.4))}
.crack-bright.crack-ring{stroke-width:1;stroke-dasharray:600;stroke-dashoffset:600}
.crack-bright.crack-ring-outer{stroke-width:.8;stroke-dasharray:800;stroke-dashoffset:800}
.crack-micro{stroke:rgba(255,255,255,.8);stroke-width:.7;stroke-dasharray:50;stroke-dashoffset:50}
.crack-hole{fill:rgba(0,0,0,.88);stroke:rgba(255,255,255,.95);stroke-width:1.8;stroke-linejoin:round;transform:scale(0);transform-origin:700px 350px;
  filter:drop-shadow(0 0 8px rgba(255,42,60,.7))}
/* hole punches through first & fastest */
.hero-crack-overlay.cracked .crack-hole{animation:holePunch .16s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes holePunch{0%{opacity:0;transform:scale(0) rotate(0deg)}70%{opacity:1;transform:scale(1.2) rotate(4deg)}100%{opacity:1;transform:scale(1) rotate(0deg)}}
/* shadow layer draws first, bright just after (light catching the edge) */
.hero-crack-overlay.cracked .crack-shadow{opacity:1;animation:crackDraw .32s ease-out forwards;animation-delay:.06s}
.hero-crack-overlay.cracked .crack-shadow.crack-ring{animation:crackDraw .28s ease-out forwards;animation-delay:.28s}
.hero-crack-overlay.cracked .crack-shadow.crack-ring-outer{animation:crackDraw .32s ease-out forwards;animation-delay:.42s}
.hero-crack-overlay.cracked .crack-bright{opacity:1;animation:crackDraw .26s ease-out forwards;animation-delay:.10s}
.hero-crack-overlay.cracked .crack-bright.crack-ring{animation:crackDraw .22s ease-out forwards;animation-delay:.30s}
.hero-crack-overlay.cracked .crack-bright.crack-ring-outer{animation:crackDraw .26s ease-out forwards;animation-delay:.44s}
.hero-crack-overlay.cracked .crack-micro{opacity:1;animation:crackDraw .12s ease-out forwards;animation-delay:.50s}
/* per-radial stagger for organic shatter */
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(1){animation-delay:.04s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(2){animation-delay:.06s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(3){animation-delay:.08s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(4){animation-delay:.07s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(5){animation-delay:.09s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(6){animation-delay:.10s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(7){animation-delay:.12s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(8){animation-delay:.11s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(9){animation-delay:.09s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(10){animation-delay:.08s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(11){animation-delay:.10s}
.hero-crack-overlay.cracked .crack-shadow:nth-of-type(12){animation-delay:.11s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(1){animation-delay:.08s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(2){animation-delay:.10s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(3){animation-delay:.12s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(4){animation-delay:.11s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(5){animation-delay:.13s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(6){animation-delay:.14s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(7){animation-delay:.16s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(8){animation-delay:.15s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(9){animation-delay:.13s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(10){animation-delay:.12s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(11){animation-delay:.14s}
.hero-crack-overlay.cracked .crack-bright:nth-of-type(12){animation-delay:.15s}
@keyframes crackDraw{to{stroke-dashoffset:0}}
.hero-crack-overlay.healing .crack-shadow,.hero-crack-overlay.healing .crack-bright,.hero-crack-overlay.healing .crack-micro{animation:crackFade .8s ease forwards}
.hero-crack-overlay.healing .crack-hole{animation:holeSeal .6s ease forwards}
@keyframes crackFade{from{opacity:1}to{opacity:0}}
@keyframes holeSeal{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0)}}
/* flying fist punch */
.punch-fist{position:absolute;font-size:28px;z-index:55;pointer-events:none;transform-origin:center;filter:drop-shadow(0 0 8px rgba(255,42,60,.8))}
.punch-fist-trail{position:absolute;font-size:24px;z-index:54;pointer-events:none;opacity:.4}
/* debris shards */
.debris-container{position:absolute;inset:0;pointer-events:none;z-index:45;overflow:visible}
.debris-shard{position:absolute;background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(255,42,60,.6));box-shadow:0 0 6px rgba(255,42,60,.5);pointer-events:none}
/* full-screen reboot loading overlay */
.hero-reboot-overlay{position:absolute;inset:0;z-index:60;background:#0A0A0C;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .8s ease}
.hero-reboot-overlay.active{opacity:1;pointer-events:auto}
.reboot-content{display:flex;flex-direction:column;align-items:center;gap:16px}
.reboot-eye{animation:rebootEyePulse 1.5s ease-in-out infinite}
@keyframes rebootEyePulse{0%,100%{opacity:.5;filter:drop-shadow(0 0 4px var(--accent))}50%{opacity:1;filter:drop-shadow(0 0 16px var(--accent))}}
.reboot-title{font-family:var(--mono);font-size:13px;letter-spacing:.2em;color:var(--text)}
.reboot-title::after{content:'';animation:dotsCycle 1.2s steps(1) infinite}
@keyframes dotsCycle{0%{content:''}25%{content:'.'}50%{content:'..'}75%{content:'...'}}
.reboot-progress-track{width:220px;height:3px;background:rgba(255,255,255,.1);border-radius:100px;overflow:hidden}
.reboot-progress-fill{height:100%;width:0%;background:var(--accent);box-shadow:0 0 8px var(--accent);border-radius:100px}
.reboot-percent{font-family:var(--mono);font-size:11px;color:var(--muted)}
/* robots slump asleep while the hero is broken */
.robot-character.robot-slumped{animation:none!important;transform:rotate(8deg) translateY(6px);transform-origin:90px 108px;transition:transform .6s ease}
.robot-station.sleeping .robot-visor{opacity:.25;transform:scaleY(.3);transform-box:fill-box;transform-origin:center}
.robot-station.sleeping .antenna-light,.robot-character.robot-slumped .chest-light{opacity:.2;animation:antennaSleepPulse 3.5s ease-in-out infinite}
@keyframes antennaSleepPulse{0%,100%{opacity:.1}50%{opacity:.3}}
.robot-station.sleeping .screen-line{animation:none;opacity:.1}
.robot-station.sleeping .screen-glow{opacity:.05}
/* visor pulses gently while awake/working */
.robot-visor{transform-box:fill-box;transform-origin:center;animation:visorPulse 2.4s ease-in-out infinite}
@keyframes visorPulse{0%,100%{opacity:.7}50%{opacity:1;filter:drop-shadow(0 0 6px var(--accent))}}
.chest-light{transform-box:fill-box;transform-origin:center}
/* floating zzz drifting up from a sleeping robot */
.sleep-z{position:absolute;top:30%;font-family:var(--display);font-weight:700;font-size:14px;color:var(--accent);pointer-events:none;z-index:10}
/* live status tag (replaces HIGGSFIELD label) */
.robot-status-tag{display:flex;align-items:center;gap:5px;justify-content:center;font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--muted);margin-top:8px}
.status-dot{width:5px;height:5px;border-radius:50%;background:#00FF85;box-shadow:0 0 6px #00FF85;animation:statusBlink 2s ease-in-out infinite}
@keyframes statusBlink{0%,100%{opacity:1}50%{opacity:.3}}
.robot-status-tag.asleep .status-dot{background:var(--muted);box-shadow:none;animation:none}
.robot-status-tag.offline .status-dot{background:var(--accent);box-shadow:0 0 6px var(--accent)}
/* tablet (600–1100px): keep robots on the sides, just smaller */
@media(max-width:1100px) and (min-width:600px){
  .hero-side{width:150px}
  .robot-desk-svg{width:130px;height:150px}
  .robot-station{margin-left:-65px}
}
/* mobile (<600px): robots drop out of the sides into an in-flow row below the hero content */
@media(max-width:599px){
  .hero{flex-direction:column;align-items:center}
  .hero-sides-wrapper{position:static;order:2;display:flex;flex-direction:row;justify-content:center;align-items:flex-end;gap:36px;width:100%;height:auto;padding:14px 0 4px;pointer-events:auto}
  .hero-side{position:static;width:auto;height:auto;overflow:visible;left:auto;right:auto}
  .robot-station{position:static;top:auto;left:auto;margin-left:0;transform:scale(.65);transform-origin:bottom center}
  .robot-station:hover,.robot-station:active{transform:scale(.65)}
  .robot-desk-svg{width:110px;height:130px}
  .robot-speech-bubble{font-size:11px;padding:8px 10px;max-width:130px}
  .robot-status-tag{font-size:8px}
}

/* hero entrance */
.hero-el{opacity:0;transform:translateY(28px);animation:heroUp .7s var(--ease) forwards}
@keyframes heroUp{to{opacity:1;transform:none}}
.eye-wrap.hero-el{transform:scale(.92);animation:heroEye .8s var(--ease) forwards}
@keyframes heroEye{to{opacity:1;transform:scale(1)}}

/* =================================================================
   MARQUEE
   ================================================================= */
.marquee{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 0;white-space:nowrap}
.marquee-track{display:inline-flex;gap:0;animation:marquee 32s linear infinite;will-change:transform}
.marquee-track span{font-family:var(--mono);font-size:11px;letter-spacing:.15em;color:var(--muted);padding:0 22px}
.marquee-track span::after{content:'·';margin-left:44px;color:var(--muted-2)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* =================================================================
   WORK / PIPELINE
   ================================================================= */
.work .section-head{display:flex;flex-direction:column;gap:10px}
.live-dot{width:7px;height:7px;border-radius:50%;color:var(--green);background:currentColor;box-shadow:0 0 0 0 rgba(0,255,133,.6);animation:livePulse 1.8s infinite,livePulseDual 3s linear infinite}
@keyframes livePulse{70%{box-shadow:0 0 0 7px rgba(0,255,133,0)}100%{box-shadow:0 0 0 0 rgba(0,255,133,0)}}
/* LIVE indicators cycle green → gold → red */
@keyframes livePulseDual{0%,100%{color:#00FF85}33%{color:var(--accent-light)}66%{color:var(--accent-red)}}
.eyebrow .live-dot{display:inline-block}
.rail-hint{font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:var(--muted-2);text-transform:uppercase}

.work-railwrap{overflow:hidden;width:100%;padding:8px 0 16px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.work-track{display:flex;gap:18px;width:max-content;will-change:transform}

.vcard{flex:0 0 auto;width:220px;aspect-ratio:9/16;border-radius:12px;overflow:hidden;position:relative;
  background:var(--surface);border:1px solid var(--border)}

/* generating layer */
.gen-layer{position:absolute;inset:0;z-index:2;opacity:0;transition:opacity .4s}
.vcard.generating .gen-layer{opacity:1}
.gen-noise{position:absolute;inset:0;background-color:#0c0a14;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  background-size:140px 140px;opacity:.55;animation:noiseShift .4s steps(4) infinite}
@keyframes noiseShift{to{background-position:140px 70px}}
.gen-scan{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(0,0,0,.28) 2px 3px);opacity:.4;pointer-events:none}
.gen-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--mono);font-size:13px;letter-spacing:.06em;color:var(--text);display:flex;align-items:center;white-space:nowrap}
.gen-caret{width:7px;height:14px;background:var(--green);margin-left:4px;animation:caret 1s steps(2) infinite}
@keyframes caret{50%{opacity:0}}
.gen-live{position:absolute;top:12px;right:12px;font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--green);display:flex;align-items:center;gap:5px;animation:livePulseDual 3s linear infinite}
.gen-live .ld{width:6px;height:6px;border-radius:50%;background:currentColor;animation:livePulse 1.6s infinite}
.gen-bar{position:absolute;left:0;bottom:0;height:3px;background:var(--green);width:0}

/* revealed layer */
.reveal-layer{position:absolute;inset:0;z-index:3;clip-path:inset(0 0 100% 0)}
.vcard.revealed .reveal-layer{animation:glitchReveal .5s ease-out forwards}
@keyframes glitchReveal{
  0%{clip-path:inset(0 0 100% 0);transform:translateX(0)}
  10%{clip-path:inset(0 0 80% 0);transform:translateX(-4px)}
  20%{clip-path:inset(0 0 80% 0);transform:translateX(4px)}
  30%{clip-path:inset(0 0 60% 0);transform:translateX(-2px)}
  40%{clip-path:inset(0 0 60% 0);transform:translateX(2px)}
  60%{clip-path:inset(0 0 30% 0);transform:translateX(-1px)}
  80%{clip-path:inset(0 0 10% 0);transform:translateX(0)}
  100%{clip-path:inset(0 0 0 0);transform:translateX(0)}
}
/* residual noise that eases out on hover */
.card-noise-overlay{position:absolute;inset:0;z-index:4;pointer-events:none;opacity:0;
  background-color:transparent;background-size:140px 140px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  transition:opacity .8s cubic-bezier(.25,.46,.45,.94)}
.vcard.revealed .card-noise-overlay{opacity:.15}
.vcard.revealed:hover .card-noise-overlay{opacity:0}
.reveal-poster{position:absolute;inset:0;background:var(--surface)}
.vvideo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#0c0a14;z-index:0}
.vshade{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.3),transparent 28% 55%,rgba(0,0,0,.72))}
.vmeta{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:space-between;padding:12px}
.vtop{display:flex;justify-content:space-between;align-items:flex-start}
.vplat{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;color:var(--text);padding:3px 7px;border:1px solid var(--border);background:rgba(13,11,20,.6)}
.vai{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;color:var(--muted);display:flex;align-items:center;gap:5px;transition:opacity .3s}
.vcard:hover .vai{opacity:0}
.vai .gd{width:5px;height:5px;border-radius:50%;background:var(--accent)}
/* unmute button */
.vmute{position:absolute;top:10px;right:10px;z-index:5;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;cursor:pointer;
  color:#fff;background:rgba(8,6,16,.55);border:1px solid var(--glass-border);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;transform:scale(.85);transition:opacity .3s,transform .3s,background .2s,color .2s}
.vcard:hover .vmute{opacity:1;transform:scale(1)}
.vmute:hover{background:rgba(255,42,60,.9);color:#0A0A0C;border-color:var(--accent)}
.vmute svg{width:15px;height:15px}
.vmute .ic-on{display:none}
.vmute.on{opacity:1;transform:scale(1);background:var(--accent);color:#0A0A0C;border-color:var(--accent)}
.vmute.on .ic-mute{display:none}
.vmute.on .ic-on{display:block}
.vplay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;border:1px solid var(--glass-border);background:rgba(13,11,20,.4);display:grid;place-items:center}
.vplay svg{width:14px;height:14px;margin-left:2px;fill:var(--text)}
.vbot{display:flex;flex-direction:column;gap:5px}
.vhandle{font-family:var(--mono);font-size:11px;display:flex;align-items:center;gap:7px}
.vhandle .ha{width:18px;height:18px;border-radius:50%;background:#2a2740}
.vstat{font-family:var(--mono);font-size:10px;color:var(--muted);display:flex;gap:12px}

/* =================================================================
   NICHES — 3D FAN
   ================================================================= */
.niches{text-align:center}
.fan-stage{perspective:1400px;perspective-origin:50% 40%;margin-top:50px;height:400px;position:relative}
.fan{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transform-style:preserve-3d;transition:transform .2s var(--ease)}
.fcard{position:absolute;width:190px;height:290px;border-radius:14px;overflow:hidden;transform-style:preserve-3d;backface-visibility:hidden;
  background:var(--surface);border:1px solid var(--glass-border);box-shadow:0 30px 60px -30px rgba(0,0,0,.9)}
.fcard .fimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.fcard::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(13,11,20,.15) 0%,transparent 35% 55%,rgba(13,11,20,.9))}
.fcard .fnum{position:absolute;top:12px;left:12px;z-index:2;font-family:var(--mono);font-size:10px;color:#fff;opacity:.7}
.fcard .flabel{position:absolute;left:0;right:0;bottom:14px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#fff}

/* =================================================================
   WHY US
   ================================================================= */
/* symmetric 3-column grid — every card equal size, no dead space */
.why-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:10px;width:100%}
.why-card{position:relative;overflow:hidden;min-width:0;width:100%;padding:28px;border-radius:20px;
  background:#0F0B0D;border:1.5px solid rgba(255,42,60,.15);
  opacity:0;transform:translateY(26px);
  transition:opacity .6s var(--ease),transform .35s cubic-bezier(.34,1.56,.64,1),border-color .3s,box-shadow .3s}
.why-card.shown{opacity:1;transform:translateY(0)}
.why-card.shown:hover{transform:translateY(-6px)}
.why-card:hover{border-color:var(--accent);box-shadow:0 16px 40px rgba(255,42,60,.18),0 0 0 1px var(--accent)}
/* diagonal red accent line — grows in on hover, on every card */
.why-card::after{content:'';position:absolute;top:0;left:0;z-index:2;width:0;height:100%;
  background:linear-gradient(to bottom,var(--accent),transparent);transition:width .3s ease}
.why-card:hover::after{width:3px}
.why-card>*{position:relative;z-index:1}
/* bold faded background number */
.why-card-number{position:absolute;top:10px;right:16px;z-index:0;font-family:var(--display);font-size:80px;font-weight:900;
  color:rgba(255,42,60,.05);-webkit-text-stroke:1px rgba(255,42,60,.08);line-height:1;pointer-events:none}
/* icon — bigger, bolder, red-glowing */
.why-ico{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;margin-bottom:16px;font-size:24px;
  background:rgba(255,42,60,.12);border:1.5px solid rgba(255,42,60,.3);color:var(--accent-light);box-shadow:0 0 20px rgba(255,42,60,.1);
  transition:transform .3s ease,box-shadow .3s,border-color .3s,background .3s;animation:whyIcoPulse 3.6s ease-in-out infinite}
@keyframes whyIcoPulse{0%,100%{box-shadow:0 0 12px rgba(255,42,60,.06)}50%{box-shadow:0 0 18px rgba(255,42,60,.16)}}
.why-card:hover .why-ico{transform:rotate(-8deg) scale(1.15);border-color:var(--accent);background:rgba(255,42,60,.25);box-shadow:0 0 30px rgba(255,42,60,.4)}
.why-ico svg{width:24px;height:24px}
.why-card h3{font-family:var(--display);font-weight:800;font-size:22px;margin-bottom:10px;letter-spacing:-.02em;transition:color .3s}
.why-card:hover h3{color:var(--accent-light)}
.why-card p{color:var(--muted);font-size:.9rem;line-height:1.6}

/* =================================================================
   REVIEWS — auto-rotating deck
   ================================================================= */
.reviews{overflow:visible;text-align:center}
.dot-gold{width:7px;height:7px;border-radius:50%;background:var(--accent-light);display:inline-block;box-shadow:0 0 8px rgba(255,42,60,.6)}
.review-carousel{position:relative;width:min(520px,92vw);height:280px;margin:56px auto 24px}
.review-stack{position:relative;width:100%;height:100%}
.review-card{position:absolute;inset:0;padding:30px;display:flex;flex-direction:column;gap:14px;text-align:left;
  border:1px solid rgba(255,255,255,.08);will-change:transform,opacity;
  transition:transform .5s ease,opacity .5s ease,box-shadow .4s}
.review-card:nth-child(5n+1){background:linear-gradient(135deg,#1a1520,#231d2e)}
.review-card:nth-child(5n+2){background:linear-gradient(135deg,#0f1a14,#162012)}
.review-card:nth-child(5n+3){background:linear-gradient(135deg,#1a1208,#241a0a)}
.review-card:nth-child(5n+4){background:linear-gradient(135deg,#0f1520,#121c2a)}
.review-card:nth-child(5n+5){background:linear-gradient(135deg,#161226,#0f1a22)}
.review-prev,.review-next{position:absolute;top:50%;transform:translateY(-50%);z-index:20;cursor:pointer;
  width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-size:18px;color:var(--text);
  background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  opacity:0;transition:opacity .3s,background .3s,border-color .3s,color .3s}
.review-prev{left:-14px}.review-next{right:-14px}
.review-carousel:hover .review-prev,.review-carousel:hover .review-next{opacity:1}
.review-prev:hover,.review-next:hover{border-color:var(--accent);color:var(--accent-light)}
.review-dots{display:flex;gap:9px;justify-content:center;margin-bottom:8px}
.review-dot{width:8px;height:8px;border-radius:50%;background:var(--muted-2);cursor:pointer;transition:background .3s,transform .3s}
.review-dot.active{background:var(--accent-light);transform:scale(1.3)}
.rv-top{display:flex;align-items:center;gap:10px}
.rv-av{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#0A0A0C;display:grid;place-items:center;font-weight:700;font-family:var(--display);font-size:1rem}
.rv-handle{font-family:var(--mono);font-size:13px;color:var(--text)}
.rv-plat{margin-left:auto;font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--muted);border:1px solid var(--border);padding:3px 9px;border-radius:100px}
.rv-quote{font-size:1rem;line-height:1.55;color:var(--text);flex-grow:1}
.rv-foot{display:flex;justify-content:space-between;align-items:center}
.rv-stars{color:var(--gold);letter-spacing:1px;font-size:13px}
.rv-date{font-family:var(--mono);font-size:10px;color:var(--muted)}

/* video testimonials */
.vt-head{text-align:center;margin:84px auto 34px;max-width:600px}
.vt-head .eyebrow{justify-content:center;margin-bottom:14px}
.vt-title{font-family:var(--display);font-weight:700;font-size:2rem;letter-spacing:-.02em}
.vt-title em{color:var(--accent-light);font-style:italic}
.vt-sub{color:var(--muted);margin-top:8px;font-size:.95rem}
.vt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.vt-card{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px;margin:0 auto}
.vt-thumb{position:relative;aspect-ratio:9/16;max-height:560px;border-radius:14px;overflow:hidden;background:#141220;border:1px solid var(--border);cursor:pointer;transition:border-color .3s}
.vt-thumb:hover{border-color:#37334d}
.vt-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#0c0a14;z-index:0;filter:contrast(1.05) saturate(.95)}
/* subtle vignette so the real frame matches the dark theme (no emoji placeholder) */
.vt-thumb::before{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,.4) 100%)}
.vt-thumb::after{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.6));transition:opacity .3s}
.vt-card.playing .vt-thumb{cursor:default}
.vt-card.playing .vt-thumb::after,.vt-card.playing .vt-thumb::before,.vt-card.playing .vt-play,.vt-card.playing .vt-name,.vt-card.playing .vt-watch{opacity:0;pointer-events:none}
.vt-card.playing .vt-video{object-fit:contain;z-index:3}
.vt-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:54px;height:54px;border-radius:50%;display:grid;place-items:center;
  background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:transform .3s,box-shadow .3s}
.vt-thumb:hover .vt-play{transform:translate(-50%,-50%) scale(1.1);box-shadow:0 0 24px rgba(255,42,60,.4)}
.vt-play svg{width:18px;height:18px;margin-left:2px;fill:var(--text)}
.vt-name{position:absolute;left:14px;bottom:12px;z-index:2;font-family:var(--mono);font-size:10.5px;color:var(--text)}
.vt-watch{position:absolute;right:14px;bottom:12px;z-index:2;font-family:var(--mono);font-size:10.5px;color:var(--accent-light)}
.vt-watch:hover{text-decoration:underline}
.vt-quote{font-size:.95rem;color:var(--text);font-weight:500;text-align:left}

/* =================================================================
   PRICING
   ================================================================= */
/* 3-package selector — single add/remove toggle each */
.pricing-widget{display:grid;grid-template-columns:1.25fr 1fr;gap:24px;align-items:start}
.pricing-left{padding:8px 28px}
.popular-tag{position:absolute;top:-12px;left:0;background:var(--gold);color:#0A0A0C;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.08em;padding:4px 10px;border-radius:100px;z-index:2}
.service-row{position:relative;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.06);transition:background .25s ease,padding .25s ease,margin .25s ease}
.service-row:last-of-type{border-bottom:none}
.service-row.featured{margin-top:8px}
.service-row.active{background:var(--accent-dim);border-radius:12px;border-bottom-color:transparent;padding-left:14px;padding-right:14px;margin-left:-14px;margin-right:-14px;box-shadow:inset 0 0 0 1px var(--accent)}
.service-info{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.service-name{font-family:var(--display);font-weight:700;font-size:18px;color:var(--text)}
.service-desc{font-size:.82rem;color:var(--muted);line-height:1.5}
.service-price{font-family:var(--display);font-weight:800;font-size:22px;color:var(--accent-light);white-space:nowrap}
.service-price small{font-size:12px;color:var(--muted);font-weight:400}
.add-toggle-btn{width:36px;height:36px;flex-shrink:0;border-radius:50%;border:1.5px solid rgba(255,42,60,.3);background:rgba(255,42,60,.06);color:var(--text);font-size:18px;font-weight:700;line-height:1;display:grid;place-items:center;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1)}
.add-toggle-btn:hover{border-color:var(--accent);background:rgba(255,42,60,.15);transform:scale(1.08)}
.add-toggle-btn.added{background:var(--accent);border-color:var(--accent);color:#0A0A0C}
.pricing-left .pricing-disclaimer{font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--muted);text-align:center;margin:16px 0 4px;opacity:1;padding:0}
.pricing-footnote{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--muted);text-align:center;padding-top:0;margin-top:0}

/* live total panel */
.pricing-right{padding:30px 28px;position:sticky;top:100px;border-radius:20px}
.summary-label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.summary-total{font-family:var(--display);font-weight:800;font-size:3.4rem;line-height:1;letter-spacing:-.03em;margin:10px 0 2px;color:var(--text)}
.summary-sub{font-size:.82rem;color:var(--muted)}
.summary-breakdown{display:flex;flex-direction:column;margin:22px 0;min-height:1px}
.summary-breakdown:empty{margin:14px 0}
.breakdown-row{display:flex;justify-content:space-between;gap:12px;padding:9px 0;font-size:13px;color:var(--text);border-bottom:1px solid rgba(255,255,255,.05)}
.breakdown-row span:first-child{color:var(--muted)}
.breakdown-row span:last-child{font-family:var(--mono);white-space:nowrap}
#pricing-cta{width:100%;justify-content:center}

/* comparison table */
.compare-wrap{margin-top:34px;border-radius:20px;overflow:hidden;overflow-x:auto}
.compare-table{width:100%;border-collapse:collapse;min-width:560px}
.compare-table th,.compare-table td{padding:15px 18px;text-align:center;border-bottom:1px solid var(--border);font-size:.9rem}
.compare-table thead th{position:sticky;top:0;z-index:2;background:rgba(20,18,30,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:500}
.compare-table th.ct-feature,.compare-table td:first-child{text-align:left;color:var(--text);font-weight:500}
.compare-table th.ct-feat{color:var(--accent-light)}
.compare-table td.ct-feat,.compare-table th.ct-feat{background:rgba(255,42,60,.07)}
.compare-table tbody tr:last-child td{border-bottom:none}
.compare-table tbody tr:hover td{background:rgba(255,255,255,.02)}
.compare-table tbody tr:hover td.ct-feat{background:rgba(255,42,60,.1)}
.ck-yes{color:var(--green);font-style:normal;font-weight:700}
.ck-no{color:#5a5468;font-style:normal;font-weight:700}

.pricing-disclaimer{text-align:center;font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--muted);opacity:.6;margin-top:32px;padding:0 24px}

/* =================================================================
   BOOK / CALENDAR
   ================================================================= */
/* pricing → booking handoff banner */
.booking-selection-banner{display:none;align-items:center;gap:10px;max-width:600px;margin:0 auto 24px;padding:14px 20px;border-radius:100px;
  background:var(--accent-dim);border:1px solid var(--accent);color:var(--text);font-family:var(--sans);font-size:14px;
  opacity:0;transform:translateY(-10px);transition:opacity .4s ease,transform .4s ease}
.booking-selection-banner.visible{display:flex;opacity:1;transform:translateY(0)}
.banner-icon{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#0A0A0C;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.banner-clear{margin-left:auto;background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;padding:4px;line-height:1}
.banner-clear:hover{color:var(--text)}

.booking-widget{position:relative;max-width:900px;margin:0 auto;border-radius:24px;overflow:hidden;
  background:rgba(255,255,255,.04);backdrop-filter:blur(40px) saturate(200%);-webkit-backdrop-filter:blur(40px) saturate(200%);
  border:1px solid rgba(255,255,255,.10);border-top-color:rgba(255,255,255,.20);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),inset 0 -1px 0 rgba(0,0,0,.15),0 32px 80px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04);
  opacity:0;transform:translateY(40px) scale(.97);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.booking-widget.visible{opacity:1;transform:translateY(0) scale(1)}
.booking-widget::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;z-index:5;
  background:linear-gradient(90deg,transparent,rgba(255,42,60,.4) 20%,rgba(255,255,255,.6) 50%,rgba(255,42,60,.4) 80%,transparent)}
/* progress */
.booking-progress{display:flex;align-items:center;gap:10px;padding:18px 28px;border-bottom:1px solid rgba(255,255,255,.06)}
.progress-step{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2);transition:color .3s}
.progress-step b{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:11px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-weight:600;transition:.3s}
.progress-step.active{color:var(--text)}
.progress-step.active b{border-color:var(--accent);color:var(--accent-light);background:rgba(255,42,60,.12)}
.progress-step.completed b{background:var(--accent);color:#080808;border-color:var(--accent)}
.progress-line{flex:1;height:1px;background:var(--border)}
/* steps */
.booking-step{display:none;min-height:340px}
.booking-step.active{display:grid;grid-template-columns:240px 1fr;animation:stepIn .45s cubic-bezier(.16,1,.3,1)}
#step-0.booking-step.active,#step-3.booking-step.active,#step-4.booking-step.active{display:block}
/* step 0: timezone */
.timezone-select-panel{max-width:460px;margin:0 auto;padding:48px 32px;text-align:center;display:flex;flex-direction:column;align-items:center}
.tz-globe{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;color:var(--accent-light);
  background:var(--surface);border:1px solid var(--border);margin-bottom:18px}
.tz-globe svg{width:26px;height:26px;animation:irisRotate 24s linear infinite}
.timezone-select-panel h3{font-family:var(--display);font-weight:600;font-size:1.45rem;margin-bottom:8px}
.tz-subtitle{font-size:.9rem;color:var(--muted);margin-bottom:26px}
.country-dropdown{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:12px;
  padding:14px 16px;color:var(--text);font-family:var(--sans);font-size:14px;outline:none;cursor:pointer;margin-bottom:22px;
  transition:border-color .2s,background .2s;appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23E63946' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;background-size:16px}
.country-dropdown:focus{border-color:rgba(255,42,60,.4);background-color:rgba(255,255,255,.06)}
.country-dropdown option{background:#15131f;color:var(--text)}
.country-dropdown optgroup{background:#0f0d16;color:var(--accent-light);font-style:normal;font-weight:700;font-size:11px;letter-spacing:.06em}
#tz-continue:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
@keyframes stepIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:none}}
.booking-info{padding:30px 26px;border-right:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.03)}
.booking-logo{display:flex;align-items:center;gap:8px;font-family:var(--display);font-weight:700;font-size:1rem;letter-spacing:-.02em}
.booking-logo svg{width:22px;height:22px;color:var(--accent-light)}
.booking-info h3{font-family:var(--display);font-weight:600;font-size:1.4rem;color:var(--accent-light);margin:14px 0 20px}
.booking-meta{list-style:none;display:flex;flex-direction:column;gap:14px}
.booking-meta li{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--muted)}
.booking-meta svg{width:18px;height:18px;flex:0 0 auto}
.booking-seldate{font-size:.95rem;color:var(--text);font-weight:500;line-height:1.5}
.booking-back{margin-top:18px;background:none;border:none;color:var(--muted);font-family:var(--mono);font-size:11px;cursor:pointer;transition:color .2s;padding:0}
.step-back-btn{background:none;border:none;color:var(--muted);font-family:var(--mono);font-size:11px;letter-spacing:.08em;padding:0;margin-top:18px;display:block;transition:color .2s ease}
.step-back-btn:hover{color:var(--text)}
.change-date-link{background:none;border:none;color:var(--accent);font-family:var(--sans);font-size:12px;padding:4px 0;margin-top:8px;display:block;opacity:.8;transition:opacity .2s ease}
.change-date-link:hover{opacity:1}
.booking-back:hover{color:var(--accent-light)}
.booking-panel{padding:26px 28px}
/* calendar */
.booking-cal .cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.booking-cal .cal-header span{font-family:var(--display);font-weight:600;font-size:1.2rem}
.cal-nav-btn{width:32px;height:32px;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:17px;cursor:pointer;transition:border-color .2s,background .2s}
.cal-nav-btn:hover:not(:disabled){border-color:var(--accent)}
.cal-nav-btn:disabled{opacity:.3;cursor:not-allowed}
.booking-cal .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-dow-label{font-family:var(--mono);font-size:9.5px;color:var(--muted-2);text-align:center;padding-bottom:4px}
.cal-day{aspect-ratio:1;display:grid;place-items:center;position:relative;font-size:.9rem;border-radius:10px;border:1px solid transparent;background:none;font-family:var(--sans);color:var(--muted-2)}
.cal-day.unavailable{opacity:.45}
.cal-day.available{background:var(--glass-bg);border-color:var(--glass-border);color:var(--text);cursor:pointer;transition:background .2s,border-color .2s,transform .2s}
.cal-day.available:hover{background:rgba(255,42,60,.1);border-color:rgba(255,42,60,.3);transform:translateY(-1px)}
.cal-day.today{outline:1px solid rgba(255,42,60,.4);outline-offset:-1px}
.cal-day .pip{position:absolute;bottom:5px;width:4px;height:4px;border-radius:50%;background:var(--accent)}
/* time slots */
.time-label{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted);margin-bottom:16px}
.time-slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.time-slot{padding:12px 8px;border:1px solid rgba(255,255,255,.08);border-radius:100px;text-align:center;font-family:var(--mono);font-size:12.5px;color:var(--text);cursor:pointer;
  background:rgba(255,255,255,.04);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .2s,border-color .2s,transform .2s,box-shadow .2s,color .2s}
.time-slot:hover{background:rgba(255,42,60,.1);border-color:rgba(255,42,60,.3);transform:translateY(-1px);box-shadow:0 4px 16px rgba(255,42,60,.1)}
.time-slot.selected{background:var(--accent);color:#0A0A0C;border-color:var(--accent);font-weight:700;box-shadow:0 0 20px rgba(255,42,60,.3)}
/* details form */
.booking-form{padding:30px 32px;display:flex;flex-direction:column;gap:14px}
.booking-form h3{font-family:var(--display);font-weight:600;font-size:1.4rem;margin-bottom:4px}
.bf-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.booking-form input,.booking-form textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;
  padding:13px 16px;color:var(--text);font-family:var(--sans);font-size:14px;outline:none;transition:border-color .2s,background .2s}
.booking-form input::placeholder,.booking-form textarea::placeholder{color:var(--muted)}
.booking-form input:focus,.booking-form textarea:focus{border-color:rgba(255,42,60,.4);background:rgba(255,255,255,.06)}
.booking-form textarea{resize:vertical;min-height:80px}
.booking-form textarea.prefilled{border-color:var(--accent);background:var(--accent-dim)}
.bf-actions{display:flex;align-items:center;justify-content:space-between;margin-top:6px}
.bf-actions .booking-back{margin-top:0}
.btn-confirm{background:var(--accent);color:#0A0A0C;font-family:var(--display);font-weight:700;font-size:14px;border:none;border-radius:100px;
  padding:13px 28px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background .2s,transform .2s,box-shadow .2s;
  box-shadow:0 0 0 1px var(--accent),0 0 32px var(--accent-glow)}
.btn-confirm:hover{background:var(--accent-light);transform:translateY(-2px);box-shadow:0 0 0 1px var(--accent-light),0 0 40px var(--accent-glow)}
.btn-confirm:disabled{opacity:.7;cursor:default}
/* confirmation */
.confirmation-screen{text-align:center;padding:44px 32px;display:flex;flex-direction:column;align-items:center;gap:14px}
.confirm-avatar{position:relative;width:72px;height:72px;border-radius:50%;background:var(--surface);border:2px solid var(--accent);display:grid;place-items:center;color:var(--accent-light)}
.confirm-avatar svg{width:34px;height:34px}
.confirm-check{position:absolute;bottom:-4px;right:-4px;width:24px;height:24px;background:var(--green);border-radius:50%;display:grid;place-items:center;font-size:13px;color:#080808;font-weight:900}
.confirmation-screen h2{font-family:var(--display);font-weight:700;font-size:1.7rem;margin:0}
.confirm-sub{color:var(--muted);font-size:.95rem}
.confirm-email-notice{font-family:var(--sans);font-size:13px;color:var(--muted);text-align:center;max-width:380px;line-height:1.6;margin:4px auto 0}
.confirm-email-link{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(255,42,60,.3);transition:border-color .2s ease}
.confirm-email-link:hover{border-color:var(--accent)}
.confirm-sub strong{color:var(--accent-light)}
.confirm-details{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:18px 24px;width:100%;max-width:460px;text-align:left}
.confirm-row{display:flex;gap:24px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.confirm-row:last-child{border-bottom:none}
.confirm-label{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;min-width:54px;padding-top:2px}
.confirm-value{font-size:14px;color:var(--text)}
.btn-meet{margin-top:8px;background:var(--accent);color:#080808;font-family:var(--display);font-weight:700;font-size:15px;padding:14px 32px;border-radius:100px;
  display:inline-flex;align-items:center;gap:8px;transition:background .2s,transform .2s,box-shadow .2s}
.btn-meet:hover{background:var(--accent-light);transform:translateY(-2px);box-shadow:0 0 24px rgba(255,42,60,.4)}

/* =================================================================
   FAQ
   ================================================================= */
.faq-chat{max-width:680px;margin:0 auto;border-radius:20px;padding:22px;display:flex;flex-direction:column;gap:12px}
.faq-chat-head{display:flex;align-items:center;gap:9px;padding:0 4px 16px;border-bottom:1px solid var(--border);margin-bottom:6px}
.fc-eye{width:24px;height:24px;color:var(--accent-light)}
.fc-eye svg{width:100%;height:100%}
.fc-name{font-family:var(--mono);font-size:13px;color:var(--text);letter-spacing:.02em}
.fc-status{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}
.fc-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(0,255,133,.5);animation:livePulse 2s infinite}
.faq-chat-body{display:flex;flex-direction:column;gap:10px}
.faq-q-bubble{align-self:flex-end;background:rgba(255,255,255,.08);border:1px solid var(--glass-border);
  border-radius:18px 18px 4px 18px;padding:11px 16px;max-width:78%;font-size:14px;color:var(--text);cursor:pointer;
  transition:background .2s,transform .2s}
.faq-q-bubble:hover{background:rgba(255,255,255,.13);transform:translateX(-2px)}
.faq-q-bubble.active{border-color:rgba(255,42,60,.4)}
.faq-a-wrap{align-self:flex-start;max-width:84%;max-height:0;overflow:hidden;transition:max-height .45s var(--ease),opacity .3s;opacity:0}
.faq-a-wrap.open{opacity:1}
.faq-a-bubble{display:flex;gap:10px;padding-top:2px}
.faq-a-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;background:var(--surface);border:1px solid var(--accent);color:var(--accent-light)}
.faq-a-avatar svg{width:17px;height:17px}
.faq-a-text{background:rgba(255,42,60,.08);border:1px solid rgba(255,42,60,.15);border-radius:18px 18px 18px 4px;
  padding:12px 16px;font-size:14px;color:var(--text);line-height:1.6}
.typing-indicator{display:flex;gap:5px;align-items:center;background:rgba(255,42,60,.08);border:1px solid rgba(255,42,60,.15);
  border-radius:18px 18px 18px 4px;padding:14px 16px;width:max-content}
.typing-indicator span{width:6px;height:6px;background:var(--muted);border-radius:50%;display:inline-block;animation:typingBounce 1s ease infinite}
.typing-indicator span:nth-child(2){animation-delay:.15s}
.typing-indicator span:nth-child(3){animation-delay:.3s}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}}

/* =================================================================
   FOOTER CTA — eye grid
   ================================================================= */
.eye-banner{position:relative;padding:120px 24px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden}
/* scanline sweep across the footer */
.eye-banner::before{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent 48%,rgba(255,42,60,.08) 50%,transparent 52%);background-size:100% 300%;
  animation:scanSweep 4s ease-in-out infinite}
@keyframes scanSweep{0%{background-position:0 -100%}100%{background-position:0 200%}}
/* ambient red glow drifting behind the headline */
.footer-redglow{position:absolute;top:6%;right:-100px;width:500px;height:500px;z-index:0;pointer-events:none;
  background:radial-gradient(circle,rgba(255,42,60,.06) 0%,transparent 70%);animation:redGlowDrift 8s ease-in-out infinite alternate}
@keyframes redGlowDrift{from{transform:translate(0,0);opacity:.5}to{transform:translate(-30px,20px);opacity:1}}
/* centred ambient glow that slowly breathes */
.footer-breathe{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at 50% 30%,rgba(255,42,60,.05) 0%,transparent 60%);animation:footerBreathe 6s ease-in-out infinite}
@keyframes footerBreathe{0%,100%{opacity:.5}50%{opacity:1}}
.eye-grid{position:absolute;inset:0;z-index:0;display:grid;align-content:center;justify-items:center;
  grid-template-columns:repeat(auto-fill,minmax(108px,1fr))}
.footer-eye{display:grid;place-items:center;padding:16px 0}
.footer-eye svg{width:46px;height:auto;color:#3a3550;opacity:.18;
  filter:drop-shadow(0 0 4px rgba(255,42,60,.3));transition:opacity .3s,filter .3s}
.footer-eye:hover svg{opacity:.55;filter:drop-shadow(0 0 12px rgba(255,42,60,.7))}
.footer-eye-pupil{transition:transform .12s ease-out}
.eye-banner::after{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(circle at 50% 50%,rgba(13,11,20,.4),rgba(13,11,20,.86) 72%)}
.eye-banner-inner{position:relative;z-index:2;text-align:center;max-width:680px;margin:0 auto;pointer-events:none}
.eye-banner-inner a{pointer-events:auto}
.banner-title{font-family:var(--display);font-weight:800;letter-spacing:-.03em;font-size:clamp(40px,5vw,72px);line-height:1.03;position:relative}
.banner-title em{color:var(--accent-light)}
/* one-shot glitch on scroll-into-view */
.banner-title.glitch-active::before,.banner-title.glitch-active::after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;overflow:hidden;pointer-events:none}
.banner-title.glitch-active::before{color:var(--accent-red);clip-path:inset(0 0 60% 0);animation:glitchSlice1 .6s steps(2) 1}
.banner-title.glitch-active::after{color:var(--gold);clip-path:inset(60% 0 0 0);animation:glitchSlice2 .6s steps(2) 1}
@keyframes glitchSlice1{0%{transform:translate(0)}20%{transform:translate(-6px,2px)}40%{transform:translate(6px,-2px)}60%{transform:translate(-3px,1px)}80%{transform:translate(3px,-1px)}100%{transform:translate(0)}}
@keyframes glitchSlice2{0%{transform:translate(0)}20%{transform:translate(6px,-2px)}40%{transform:translate(-6px,2px)}60%{transform:translate(3px,-1px)}80%{transform:translate(-3px,1px)}100%{transform:translate(0)}}
.banner-sub{color:var(--muted);margin:18px auto 30px;max-width:440px}

/* contact pills */
.contact-row{margin-top:34px;display:flex;flex-direction:column;align-items:center;gap:14px}
.contact-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.contact-pills{display:flex;gap:12px}
.cpill{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:var(--muted);
  background:var(--glass-bg);border:1px solid var(--glass-border);
  backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);
  transition:transform .25s,color .25s,box-shadow .25s,border-color .25s}
.cpill svg{width:19px;height:19px;transition:transform .25s}
.cpill:hover{color:var(--c);border-color:var(--c);box-shadow:0 0 16px rgba(255,255,255,.12)}
.cpill:hover svg{transform:scale(1.12)}

/* email capture */
.email-capture-row{display:flex;align-items:center;border-radius:100px;pointer-events:auto;
  border:1px solid rgba(255,255,255,.12);border-top-color:rgba(255,255,255,.20);background:rgba(255,255,255,.05);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:6px 6px 6px 24px;max-width:480px;margin:32px auto 14px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);transition:box-shadow .3s ease,border-color .3s ease}
.email-capture-row:focus-within{border-color:var(--accent);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 0 0 1px var(--accent),0 0 30px var(--accent-glow)}
.email-capture-row input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--text);font-family:var(--sans);font-size:15px}
.email-capture-row input::placeholder{color:var(--muted)}
.email-capture-row button{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:#080808;border:none;border-radius:100px;
  padding:12px 22px;font-family:var(--display);font-weight:700;font-size:14px;cursor:pointer;transition:background .2s,transform .2s;white-space:nowrap}
.email-capture-row button:hover{background:var(--accent-light);transform:scale(1.02)}
.email-capture-row button.done{background:var(--green);color:#062b16}
.email-micro{font-family:var(--mono);font-size:11px;color:var(--muted);text-align:center}
.hp-field{position:absolute!important;left:-9999px;top:auto;width:1px;height:1px;opacity:0;overflow:hidden;pointer-events:none}

/* before / after split */
.vs-split{display:grid;grid-template-columns:1fr auto 1fr;max-width:760px;margin:40px auto 0;text-align:left;
  border:1px solid var(--border);border-radius:16px;overflow:hidden}
.vs-side{padding:28px 30px}
.vs-before{background:#0a0a0a;filter:grayscale(.7);opacity:.78;transition:filter .8s,opacity .8s}
.vs-split.in .vs-before{filter:grayscale(1);opacity:.62}
.vs-after{position:relative;background:var(--bg);transition:box-shadow .8s}
.vs-after::after{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(120% 80% at 70% 30%,rgba(255,42,60,.1),transparent 60%);opacity:.6;transition:opacity .8s}
.vs-split.in .vs-after::after{opacity:1}
.vs-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;display:inline-block;margin-bottom:16px}
.vs-label-bad{color:#e06363}
.vs-label-good{color:var(--green)}
.vs-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.vs-list li{font-size:15px;line-height:1.3}
.vs-before .vs-list li{color:var(--muted);text-decoration:line-through;text-decoration-color:rgba(224,99,99,.55)}
.vs-after .vs-list li{color:var(--text);padding-left:22px;position:relative;z-index:1}
.vs-after .vs-list li::before{content:'→';position:absolute;left:0;color:var(--accent-light)}
.vs-metric{margin-top:18px}
.vs-metric-bad{font-family:var(--mono);font-size:.78rem;color:var(--muted-2)}
.vs-metric-good{font-family:var(--display);font-weight:700;font-size:1.12rem;color:var(--accent-light);position:relative;z-index:1}
.vs-divider{position:relative;width:1px;background:var(--border);display:flex;align-items:center;justify-content:center}
.vs-divider span{position:absolute;background:var(--bg);font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--muted);padding:5px 0}

/* =================================================================
   FOOTER
   ================================================================= */
.footer{max-width:var(--maxw);margin:0 auto;padding:54px 32px 40px}
.footer-top{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-bottom:28px;border-bottom:1px solid var(--border)}
.footer-links{display:flex;gap:24px;flex-wrap:wrap}
.footer-links a{font-size:13px;color:var(--muted);transition:color .25s}
.footer-links a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:22px;font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;color:var(--muted-2)}
.footer-legal{display:flex;gap:18px}
.footer-legal a{transition:color .2s}
.footer-legal a:hover{color:var(--accent-light)}

/* =================================================================
   REVEAL
   ================================================================= */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media(max-width:900px){
  .pricing-widget{grid-template-columns:1fr}
  .pricing-right{position:static}
  .why-grid{grid-template-columns:1fr}
  .why-card:nth-child(1){grid-row:auto}
  .vt-grid{grid-template-columns:1fr}
  .booking-step.active{grid-template-columns:1fr}
  .booking-info{border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}
  .booking-meta{flex-direction:row;flex-wrap:wrap;gap:14px 22px}
}
@media(max-width:768px){
  .section{padding:84px 22px}
  .nav-links,.pill{display:none}
  .burger{display:flex}
  .nav.scrolled{margin:8px 12px 0;width:calc(100% - 24px)}
  .fan-stage{height:350px;perspective:none;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none}
  .fan-stage::-webkit-scrollbar{display:none}
  .fan{position:static;transform:none!important;display:flex;gap:14px;padding:0 22%;width:max-content;height:100%;align-items:center}
  .fcard{position:relative;transform:none!important;scroll-snap-align:center;flex:0 0 auto;box-shadow:none}
  .bf-grid{grid-template-columns:1fr}
  .time-slots-grid{grid-template-columns:repeat(2,1fr)}
  .booking-progress{gap:4px;padding:14px 14px}
  .progress-step b{width:18px;height:18px;font-size:9px}
  .progress-step span{display:none}
  .footer-top{flex-direction:column;align-items:flex-start}
  .hero-stats .stat{padding:2px 18px}
}
@media(max-width:540px){
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%;justify-content:center}
  .why-grid{grid-template-columns:1fr}
  .pf-sub{display:none}
  .pf-node{width:42px;height:42px}
  .pf-node svg{width:19px;height:19px}
  .vs-split{grid-template-columns:1fr}
  .vs-divider{width:auto;height:1px}
}

/* =================================================================
   REDUCED MOTION
   ================================================================= */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal,.hero-el,.pf-step,.pf-badge,.booking-widget,.why-card{opacity:1!important;transform:none!important}
  .pf-line{width:100%!important}
  .after-item{opacity:1!important;transform:none!important}
  .after-item::before{opacity:1!important;transform:none!important}
  .before-item{opacity:.55!important;text-decoration-color:#FF4444!important}
  .overlay-links a{opacity:1;transform:none}
}
