:root{
  --bg:#090412;
  --bg-2:#14052a;
  --fg:#f7f3ff;
  --silver:#eff4ff;
  --silver-soft:rgba(239,244,255,.86);
  --muted:rgba(247,243,255,.82);
  --line:rgba(247,243,255,.16);
  --line-strong:rgba(247,243,255,.24);
  --card:rgba(14,8,25,.68);
  --card-2:rgba(255,255,255,.035);
  --card-soft:rgba(255,255,255,.05);
  --cyan:#4df5ff;
  --magenta:#ff4be7;
  --violet:#8460ff;
  --gold:#ffc44d;
  --lime:#b9ff73;
  --focus:#7bf8ff;
  --shadow:0 18px 60px rgba(0,0,0,.32);
  --radius:24px;
  --radius-sm:18px;
  --pad:clamp(18px,2vw,28px);
  --t-fast:180ms;
  --t-med:420ms;
  --e:cubic-bezier(.2,.8,.2,1);
  --hair:1px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Space Grotesk',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--fg);
  background:
    radial-gradient(circle at 12% 18%, rgba(255,75,231,.34), transparent 28%),
    radial-gradient(circle at 78% 24%, rgba(77,245,255,.22), transparent 26%),
    radial-gradient(circle at 68% 66%, rgba(255,196,77,.18), transparent 24%),
    linear-gradient(180deg, #12041d 0%, #0c0619 34%, #090412 100%);
  min-height:100vh;
  overflow-x:hidden;
}
body::before,
body::after{
  content:'';
  position:fixed;
  inset:auto;
  pointer-events:none;
  z-index:-3;
  filter:blur(12px);
}
body::before{
  width:42vw;
  height:42vw;
  left:-8vw;
  top:18vh;
  background:radial-gradient(circle, rgba(255,75,231,.24), transparent 62%);
  animation:floatGlowA 18s ease-in-out infinite;
}
body::after{
  width:38vw;
  height:38vw;
  right:-10vw;
  top:16vh;
  background:radial-gradient(circle, rgba(77,245,255,.18), transparent 60%);
  animation:floatGlowB 22s ease-in-out infinite;
}
@keyframes floatGlowA{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(6vw,4vh,0)}}
@keyframes floatGlowB{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(-5vw,5vh,0)}}

a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer}
img{max-width:100%;display:block}
.skip-link{
  position:absolute;left:12px;top:-100px;padding:10px 14px;background:#fff;color:#000;border-radius:12px;z-index:2000;
}
.skip-link:focus{top:12px}
.container{width:min(1280px, calc(100% - 2*var(--pad))); margin-inline:auto}
.grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:18px}
.span-12{grid-column:1/-1}
.section{padding:36px 0 18px}
.section-hero{padding:118px 0 24px}
.section-head{display:grid;gap:10px;margin-bottom:14px}
.label,
.mini-kicker,
.brand-mini,
.mono{
  font-family:'Orbitron', 'Space Grotesk', sans-serif;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.75rem;
}
.label{color:rgba(247,243,255,.8)}
.h2{font-size:clamp(2rem,3vw,3.15rem);line-height:1.02;margin:0;letter-spacing:-.04em}
.h3{font-size:clamp(1.12rem,2vw,1.5rem);line-height:1.1;margin:0 0 8px;letter-spacing:-.03em}
.muted{color:var(--muted)}
.small{font-size:.92rem}
.card,
.card-soft,
.mini-card,
.plan,
.calc,
.contact-main,
.venue-panel,
.booking-panel{
  position:relative;
  border:var(--hair) solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}
.card::before,
.plan::before,
.booking-panel::before,
.contact-main::before,
.venue-panel::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg, rgba(77,245,255,.38), rgba(255,75,231,.32), rgba(255,196,77,.26));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  opacity:.44;
  pointer-events:none;
}
.card-soft,
.mini-card,
.contact-card{
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.022));
  border:1px solid var(--line);
  padding:18px;
}
.soft-chip,
.pay-chip,
.tag{
  display:inline-flex;align-items:center;gap:6px;
  border:1px solid rgba(247,243,255,.16);
  background:rgba(255,255,255,.04);
  border-radius:999px;
  padding:8px 12px;
  color:rgba(247,243,255,.84);
  font-size:.9rem;
}
.soft-chip-hot{background:rgba(255,75,231,.11);border-color:rgba(255,75,231,.34)}
.section-divider{height:1px;background:linear-gradient(90deg, transparent, rgba(247,243,255,.2), transparent);margin-top:10px}

.scroll-progress{position:fixed;top:0;left:0;width:100%;height:3px;z-index:1400;background:transparent;transform:translateZ(0)}
.scroll-progress-bar{width:100%;height:100%;transform-origin:left center;transform:scaleX(0);background:linear-gradient(90deg,var(--magenta),var(--cyan),var(--gold));box-shadow:0 0 18px rgba(77,245,255,.36)}
.site-header{position:sticky;top:0;z-index:1100;background:linear-gradient(180deg, rgba(12,6,24,.9), rgba(10,5,18,.72));backdrop-filter:blur(18px);border-bottom:1px solid rgba(247,243,255,.08)}
.site-header::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg, transparent, rgba(77,245,255,.42), rgba(255,75,231,.44), transparent);opacity:.72}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:84px;position:relative}
.header-bar{display:flex;align-items:center;gap:14px;flex-shrink:0}
.header-panel{display:flex;align-items:center;justify-content:space-between;gap:18px;flex:1}
.header-panel-inner{display:flex;align-items:center;justify-content:flex-start;gap:18px;flex:1}
.brand{display:inline-flex;align-items:center;gap:10px;padding:14px 18px;border-radius:20px;border:1px solid rgba(247,243,255,.16);background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));box-shadow:inset 0 0 0 1px rgba(255,255,255,.03), 0 0 0 1px rgba(77,245,255,.04);transition:transform var(--t-fast) var(--e), border-color var(--t-fast) var(--e), box-shadow var(--t-fast) var(--e), background var(--t-fast) var(--e)}
.brand:hover{transform:translateY(-1px);border-color:rgba(77,245,255,.36);box-shadow:0 0 26px rgba(77,245,255,.1), 0 0 42px rgba(255,75,231,.08);background:linear-gradient(180deg, rgba(77,245,255,.07), rgba(255,255,255,.025))}
.brand-mark,.brand-name{font-family:'Orbitron',sans-serif;font-weight:700;letter-spacing:.08em;font-size:1rem}
.brand-mark{color:#fff;text-shadow:0 0 14px rgba(77,245,255,.14)}
.brand-name{color:rgba(247,243,255,.94)}
.brand-slash{color:rgba(247,243,255,.4);font-size:1rem}
.brand-sub{margin-left:6px;font-size:.78rem;color:rgba(247,243,255,.72)}
.primary-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-start;flex:1}
.nav-link{padding:14px 16px;border-radius:18px;color:var(--silver-soft);position:relative;transition:color var(--t-fast) var(--e), background var(--t-fast) var(--e), transform var(--t-fast) var(--e), box-shadow var(--t-fast) var(--e), border-color var(--t-fast) var(--e);border:1px solid transparent;text-shadow:0 0 14px rgba(209,224,255,.12)}
.nav-link::after{content:'';position:absolute;left:14px;right:14px;bottom:8px;height:1px;background:linear-gradient(90deg, rgba(255,75,231,0), rgba(77,245,255,.88), rgba(255,196,77,.7), rgba(255,75,231,0));transform:scaleX(.35);opacity:0;transition:transform var(--t-fast) var(--e), opacity var(--t-fast) var(--e)}
.nav-link:hover,.nav-link[aria-current='page']{color:var(--fg);background:rgba(77,245,255,.08);transform:translateY(-1px);border-color:rgba(77,245,255,.22);box-shadow:0 0 0 1px rgba(77,245,255,.24) inset, 0 0 18px rgba(77,245,255,.1), 0 0 24px rgba(255,75,231,.08)}
.nav-link:hover::after,.nav-link[aria-current='page']::after{transform:scaleX(1);opacity:1}
.nav-toggle{display:none;align-items:center;justify-content:center;flex-direction:column;gap:5px;width:48px;height:48px;border-radius:16px;border:1px solid rgba(247,243,255,.14);background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));box-shadow:0 0 0 1px rgba(77,245,255,.04) inset;transition:transform var(--t-fast) var(--e), border-color var(--t-fast) var(--e), box-shadow var(--t-fast) var(--e)}
.nav-toggle span{display:block;width:20px;height:2px;border-radius:999px;background:linear-gradient(90deg, rgba(255,255,255,.92), rgba(77,245,255,.92));transition:transform var(--t-fast) var(--e), opacity var(--t-fast) var(--e), background var(--t-fast) var(--e)}
.nav-toggle:hover{transform:translateY(-1px);border-color:rgba(77,245,255,.28);box-shadow:0 0 20px rgba(77,245,255,.12)}
.nav-link-book{margin-left:auto;border-color:rgba(77,245,255,.28);background:linear-gradient(135deg, rgba(255,75,231,.18), rgba(77,245,255,.12) 56%, rgba(255,196,77,.16));box-shadow:0 0 0 1px rgba(77,245,255,.14) inset, 0 0 28px rgba(77,245,255,.16), 0 0 42px rgba(255,75,231,.12);color:var(--silver);text-shadow:0 0 16px rgba(239,244,255,.3), 0 0 24px rgba(77,245,255,.16)}
.nav-link-book::before{content:'';position:absolute;inset:-18% -6%;background:radial-gradient(circle at 50% 50%, rgba(77,245,255,.24), transparent 56%);opacity:.65;z-index:-1;pointer-events:none}
.nav-link-book:hover,.nav-link-book[aria-current='page']{background:linear-gradient(135deg, rgba(255,75,231,.22), rgba(77,245,255,.18) 54%, rgba(255,196,77,.2));box-shadow:0 0 0 1px rgba(77,245,255,.2) inset, 0 0 32px rgba(77,245,255,.24), 0 0 54px rgba(255,75,231,.16)}
.site-header.is-menu-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.site-header.is-menu-open .nav-toggle span:nth-child(2){opacity:0}
.site-header.is-menu-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:18px;padding:14px 22px;border:1px solid transparent;transition:transform var(--t-fast) var(--e), box-shadow var(--t-fast) var(--e), border-color var(--t-fast) var(--e), background var(--t-fast) var(--e), color var(--t-fast) var(--e);position:relative;overflow:hidden;isolation:isolate}
.btn::before{content:'';position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(135deg, rgba(255,75,231,.2), rgba(77,245,255,.18), rgba(255,196,77,.16));opacity:0;transition:opacity var(--t-fast) var(--e);z-index:-2}
.btn::after{content:'';position:absolute;inset:auto -30% 0 auto;width:120px;height:120%;transform:skewX(-24deg) translateX(130%);background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.22), rgba(255,255,255,0));opacity:.5;transition:transform .7s var(--e);z-index:-1}
.btn:hover{transform:translateY(-2px)}
.btn:hover::before{opacity:1}
.btn:hover::after{transform:skewX(-24deg) translateX(-20%)}
.btn:focus-visible,
.nav-link:focus-visible,
.project:focus-visible,
.step:focus-visible,
.pill-btn:focus-visible,
.seg-btn:focus-visible,
.accordion-btn:focus-visible,
.footer-link-btn:focus-visible,
.field input:focus-visible,
.field select:focus-visible,
.field textarea:focus-visible{outline:2px solid var(--focus);outline-offset:3px}
.btn-solid{background:linear-gradient(90deg, #ff60eb 0%, #46f1ff 52%, #ffd25c 100%);color:rgba(255,255,255,.98);text-shadow:0 1px 10px rgba(9,4,18,.3);box-shadow:0 12px 34px rgba(77,245,255,.2), 0 0 32px rgba(255,75,231,.16)}
.btn-outline{border-color:rgba(247,243,255,.16);background:rgba(255,255,255,.03);color:var(--fg);box-shadow:0 0 0 1px rgba(255,255,255,.02) inset}
.btn-outline:hover{border-color:rgba(77,245,255,.4);box-shadow:0 0 24px rgba(77,245,255,.12), 0 0 0 1px rgba(77,245,255,.12) inset}
.btn-ghost:hover{color:#fff;text-shadow:0 0 16px rgba(77,245,255,.18)}
.btn-ghost{background:transparent;border-color:transparent;color:rgba(247,243,255,.86)}
.btn-small{padding:11px 16px;border-radius:14px}
.btn-compact{padding:12px 18px}

.loader{position:fixed;inset:0;background:radial-gradient(circle at 50% 40%, rgba(255,75,231,.16), transparent 28%), rgba(9,4,18,.96);display:flex;align-items:center;justify-content:center;z-index:1500;transition:opacity var(--t-med) var(--e), visibility var(--t-med) var(--e)}
.loader-inner{width:min(420px,calc(100% - 40px));padding:30px;border:1px solid rgba(247,243,255,.14);border-radius:28px;background:rgba(14,8,25,.84);box-shadow:var(--shadow)}
.loader-track{height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;margin:18px 0}
.loader-fill{height:100%;transform-origin:left center;transform:scaleX(.02);background:linear-gradient(90deg,var(--magenta),var(--cyan),var(--gold));box-shadow:0 0 12px rgba(77,245,255,.4)}
.loader-readout{display:flex;justify-content:space-between;gap:12px}
body.is-ready .loader{opacity:0;visibility:hidden;pointer-events:none}

.particle-layer{position:fixed;inset:0;pointer-events:none;z-index:-2;overflow:hidden}
.particle{position:absolute;width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.7);box-shadow:0 0 12px rgba(77,245,255,.6);opacity:.42;animation:particleFloat linear infinite}
@keyframes particleFloat{0%{transform:translate3d(0,0,0) scale(.8);opacity:0}10%{opacity:.5}50%{opacity:.22}100%{transform:translate3d(-30px,-120vh,0) scale(1.15);opacity:0}}
.wave-layer{position:fixed;inset:0;pointer-events:none;z-index:-1;overflow:hidden}
.wave{position:absolute;left:-10vw;right:-10vw;height:180px;border-top:1px solid rgba(77,245,255,.16);border-radius:50%;filter:blur(.2px)}
.wave-a{bottom:18vh;animation:waveDrift 18s linear infinite}
.wave-b{bottom:36vh;opacity:.55;transform:scaleX(1.08);animation:waveDrift 24s linear infinite reverse}
.wave-c{bottom:58vh;opacity:.34;transform:scaleX(1.2);animation:waveDrift 30s linear infinite}
@keyframes waveDrift{0%{transform:translateX(0) scaleX(1.05)}50%{transform:translateX(-3vw) scaleX(1.12)}100%{transform:translateX(0) scaleX(1.05)}}

.hero-grid{align-items:start}
.hero-copy{grid-column:1 / span 7;display:grid;gap:18px}
.hero-aside{grid-column:8 / -1}
.kicker{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:999px;border:1px solid rgba(247,243,255,.18);background:rgba(255,255,255,.03)}
.pill-hot{box-shadow:0 0 0 1px rgba(255,75,231,.12) inset, 0 0 26px rgba(255,75,231,.08)}
.pill-ico{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:50%;background:rgba(255,196,77,.18);font-size:.8rem}
.hairline{height:1px;width:min(52vw,420px);background:linear-gradient(90deg, rgba(247,243,255,.12), rgba(247,243,255,.24), transparent)}
.hero-title{font-size:clamp(3.2rem,7vw,6rem);line-height:.95;letter-spacing:-.065em;margin:0;max-width:9ch;text-wrap:balance;text-shadow:0 0 26px rgba(255,75,231,.12), 0 0 42px rgba(77,245,255,.08)}
.hero-sub{font-size:clamp(1.05rem,1.8vw,1.42rem);margin:0;color:rgba(247,243,255,.9)}
.hero-cta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hero-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.meta-card{padding:18px 20px;border-radius:22px;border:1px solid rgba(247,243,255,.16);background:rgba(255,255,255,.03)}
.meta-glow{box-shadow:0 0 24px rgba(255,75,231,.08), inset 0 0 0 1px rgba(77,245,255,.08)}
.meta-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.meta-bottom{font-size:1rem}
.hero-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.strip-item{display:flex;align-items:flex-start;gap:14px;padding:18px}
.strip-ico{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));color:rgba(255,255,255,.95);box-shadow:0 0 0 1px rgba(255,255,255,.04) inset, 0 0 24px rgba(77,245,255,.08)}
.strip-ico svg{width:22px;height:22px;filter:drop-shadow(0 0 10px rgba(77,245,255,.24))}
.strip-title{font-size:1.12rem;font-weight:600;letter-spacing:-.03em;margin-bottom:4px}
.strip-sub{font-size:.98rem}
.hero-visual{padding:18px;overflow:hidden}
.visual-top{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px}
.live-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(77,245,255,.1);border:1px solid rgba(77,245,255,.24);font-size:.9rem;color:rgba(247,243,255,.92)}
.hero-poster-wrap{position:relative;border-radius:20px;overflow:hidden;border:1px solid rgba(247,243,255,.12);background:rgba(255,255,255,.03)}
.hero-poster{width:100%;aspect-ratio:1.08/1;object-fit:cover;transition:transform 1.2s var(--e), filter 1.2s var(--e)}
.hero-visual:hover .hero-poster{transform:scale(1.04);filter:saturate(1.08)}
.mini-schedule{display:grid;gap:10px;margin-top:16px}
.mini-row{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid rgba(247,243,255,.1)}
.mini-row span{color:rgba(247,243,255,.72)}
.hero-actions-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}

.guide-grid{grid-column:1/-1;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.accordion-btn{width:100%;display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:18px;background:none;border:none;color:inherit;text-align:left}
.card-title{font-size:1.14rem;font-weight:600;letter-spacing:-.03em}
.card-meta{font-size:.95rem}
.chev{width:12px;height:12px;border-right:2px solid rgba(247,243,255,.64);border-bottom:2px solid rgba(247,243,255,.64);transform:rotate(45deg);transition:transform var(--t-fast) var(--e)}
.accordion-btn[aria-expanded='true'] .chev{transform:rotate(225deg) translate(-2px,-1px)}
.accordion-panel{padding:0 18px 18px}
.bullets{margin:0;padding-left:18px;display:grid;gap:10px}
.bullets-tight{gap:8px}
.guide-highlights,.experience-grid,.perks-grid{grid-column:1/-1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:14px}
.mini-card{padding:18px 18px 16px}
.mini-card strong{display:block;font-size:1.12rem;line-height:1.15;letter-spacing:-.03em;margin:8px 0}
.mini-card p{margin:0}

.stage-top{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:6px}
.lab-toolbar,.filters{display:flex;gap:10px;flex-wrap:wrap}
.pill-btn{padding:11px 16px;border-radius:999px;border:1px solid rgba(247,243,255,.16);background:rgba(255,255,255,.025);color:rgba(247,243,255,.74);transition:transform var(--t-fast) var(--e), border-color var(--t-fast) var(--e), background var(--t-fast) var(--e), color var(--t-fast) var(--e)}
.pill-btn:hover,.pill-btn.is-active{transform:translateY(-1px);color:var(--fg);border-color:rgba(77,245,255,.34);background:rgba(77,245,255,.09)}
.stages-grid{grid-column:1/-1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.stage-card{padding:22px}
.stage-badge{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(77,245,255,.12);border:1px solid rgba(77,245,255,.28);margin-bottom:12px;font-size:.92rem}
.stage-badge-alt{background:rgba(255,75,231,.12);border-color:rgba(255,75,231,.3)}
.stage-badge-gold{background:rgba(255,196,77,.12);border-color:rgba(255,196,77,.3)}
.venue-panel{grid-column:1/-1;display:grid;grid-template-columns:1.05fr .95fr;gap:18px;padding:22px;align-items:center}
.venue-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.venue-map-wrap{padding:10px;border-radius:22px;background:rgba(255,255,255,.03);border:1px solid rgba(247,243,255,.12)}
.venue-map-wrap img{width:100%;aspect-ratio:1.18/1;object-fit:cover;border-radius:18px}

.stepper{display:grid;grid-template-columns:300px 1fr;gap:18px;padding:18px}
.stepper-left{display:flex;flex-direction:column;gap:10px}
.step{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:18px;border:1px solid rgba(247,243,255,.14);background:rgba(255,255,255,.02);color:rgba(247,243,255,.72);transition:transform var(--t-fast) var(--e), border-color var(--t-fast) var(--e), background var(--t-fast) var(--e), color var(--t-fast) var(--e)}
.step:hover,.step.is-active{transform:translateY(-1px);color:var(--fg);border-color:rgba(255,75,231,.32);background:rgba(255,75,231,.09)}
.stepper-right{padding:20px;border-radius:22px;border:1px solid rgba(247,243,255,.12);background:rgba(255,255,255,.03)}
.mini-cta{margin-top:14px}
.link{color:var(--cyan)}
.gallery-grid{grid-column:1/-1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:14px}
.gallery-shot{width:100%;aspect-ratio:1.18/1;object-fit:cover;border-radius:24px;border:1px solid rgba(247,243,255,.14);box-shadow:var(--shadow);transition:transform .7s var(--e), box-shadow .7s var(--e)}
.gallery-shot:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 24px 60px rgba(0,0,0,.38)}

.project-list{grid-column:1/-1;list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.project-item{display:block}
.project{width:100%;display:grid;grid-template-columns:112px 1fr;align-items:center;gap:16px;padding:14px;border-radius:24px;border:1px solid rgba(247,243,255,.14);background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));text-align:left;box-shadow:var(--shadow);transition:transform var(--t-fast) var(--e), border-color var(--t-fast) var(--e), box-shadow var(--t-fast) var(--e), background var(--t-fast) var(--e)}
.project:hover{transform:translateY(-4px) scale(1.01);border-color:rgba(77,245,255,.32);box-shadow:0 20px 42px rgba(0,0,0,.34), 0 0 0 1px rgba(77,245,255,.12) inset, 0 0 32px rgba(255,75,231,.08);background:linear-gradient(180deg, rgba(77,245,255,.08), rgba(255,255,255,.02))}
.project-thumb{width:112px;height:112px;border-radius:18px;object-fit:cover;border:1px solid rgba(247,243,255,.14)}
.project-copy{display:grid;gap:6px}
.project-title{font-size:1.22rem;font-weight:600;letter-spacing:-.03em}
.project-desc{font-size:.98rem}
.project-meta-row{display:flex;gap:8px;flex-wrap:wrap}
.tag{padding:7px 10px;font-size:.82rem;background:rgba(255,255,255,.03)}

.pricing-top{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.segmented{display:inline-flex;gap:4px;padding:4px;border-radius:999px;border:1px solid rgba(247,243,255,.14);background:rgba(255,255,255,.03)}
.seg-btn{padding:10px 16px;border-radius:999px;border:none;background:transparent;color:rgba(247,243,255,.74);transition:background var(--t-fast) var(--e), color var(--t-fast) var(--e), transform var(--t-fast) var(--e)}
.seg-btn:hover,.seg-btn.is-active{color:var(--fg);background:rgba(255,75,231,.12);transform:translateY(-1px)}
.pricing-status{display:flex;gap:10px;flex-wrap:wrap}
.pricing-grid{grid-column:1/-1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.plan{padding:22px;display:flex;flex-direction:column;gap:16px;overflow:hidden}
.plan-featured{transform:translateY(-6px);box-shadow:0 0 0 1px rgba(255,75,231,.14) inset, 0 24px 60px rgba(0,0,0,.34), 0 0 32px rgba(255,75,231,.12)}
.plan-ribbon{position:absolute;top:14px;right:14px;padding:8px 12px;border-radius:999px;background:rgba(255,196,77,.14);border:1px solid rgba(255,196,77,.28);font-size:.82rem}
.plan-head{display:grid;gap:6px}
.plan-name{font-size:1.2rem;font-weight:600;letter-spacing:-.03em}
.plan-price{font-size:clamp(2rem,4vw,3rem);line-height:.94;letter-spacing:-.05em}
.plan-sub{font-size:.98rem}
.booking-panel{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px;margin-top:14px;flex-wrap:wrap}
.booking-copy{max-width:760px}
.payment-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.booking-actions{display:flex;gap:12px;flex-wrap:wrap}
.calc{grid-column:1/-1;padding:22px;margin-top:14px}
.calc-head{display:grid;grid-template-columns:1fr 300px;gap:16px;align-items:start;margin-bottom:16px}
.calc-output{padding:16px;border-radius:22px;border:1px solid rgba(247,243,255,.14);background:rgba(255,255,255,.03);box-shadow:0 0 0 1px rgba(77,245,255,.08) inset}
.calc-form{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-weight:500}
.field input,.field select,.field textarea{border:1px solid rgba(247,243,255,.14);background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));color:var(--fg);border-radius:18px;padding:13px 14px;box-shadow:0 0 0 1px rgba(255,255,255,.02) inset}
.field select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:48px;background-image:linear-gradient(45deg, transparent 50%, rgba(247,243,255,.82) 50%), linear-gradient(135deg, rgba(247,243,255,.82) 50%, transparent 50%), radial-gradient(circle at 50% 50%, rgba(255,255,255,.02), rgba(255,255,255,0));background-position:calc(100% - 21px) calc(50% - 1px), calc(100% - 15px) calc(50% - 1px), center;background-size:6px 6px, 6px 6px, 100% 100%;background-repeat:no-repeat;color-scheme:dark}
.field select option,.field select optgroup{background:#14052a;color:#f7f3ff}
.field select option:checked{background:#28104a;color:#fff}
.field input::placeholder,.field textarea::placeholder{color:rgba(247,243,255,.54)}
.form-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:4px}
.error{color:#ff93d7;font-size:.92rem}
.form-status{min-height:20px;color:#ff93d7}

.contact-grid{grid-column:1/-1;display:grid;grid-template-columns:380px 1fr;gap:16px;align-items:start}
.contact-side{display:grid;gap:14px}
.contact-main{padding:22px}
.contact-points{list-style:none;padding:0;margin:16px 0 0;display:grid;gap:12px}
.contact-points li{display:flex;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid rgba(247,243,255,.1)}
.faq-list{display:grid;gap:10px;margin-top:10px}
.faq-list details{padding:14px;border-radius:18px;border:1px solid rgba(247,243,255,.12);background:rgba(255,255,255,.03)}
.faq-list summary{cursor:pointer;font-weight:600}
.faq-list p{margin:10px 0 0}
.contact-success{padding:22px;background:rgba(77,245,255,.08)}
.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}

.site-footer{padding:32px 0 46px}
.footer-top{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap;padding-top:8px}
.footer-copy{max-width:700px}
.footer-links{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.footer-link-btn{background:none;border:none;color:rgba(247,243,255,.74);padding:0}
.footer-links a,.footer-link-btn{transition:color var(--t-fast) var(--e)}
.footer-links a:hover,.footer-link-btn:hover{color:var(--fg)}
.footer-bottom{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:20px;padding-top:16px;border-top:1px solid rgba(247,243,255,.1)}
.brand-footer{padding:0;border:none;background:none;box-shadow:none}

.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(5,2,12,.82);z-index:1300}
.modal[hidden]{display:none}
.modal-card{width:min(1040px, calc(100% - 2*var(--pad)));max-height:min(90vh,920px);overflow:auto;border-radius:32px;border:1px solid rgba(247,243,255,.18);background:rgba(10,5,18,.94);box-shadow:0 26px 80px rgba(0,0,0,.46);padding:22px;transform:translateY(14px) scale(.98);opacity:0;transition:transform var(--t-med) var(--e), opacity var(--t-med) var(--e)}
.modal.is-open .modal-card{transform:translateY(0) scale(1);opacity:1}
.modal-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding-bottom:16px;border-bottom:1px solid rgba(247,243,255,.1)}
.modal-title{margin:6px 0 0}
.modal-body{display:grid;grid-template-columns:360px 1fr;gap:18px;padding-top:18px}
.modal-media{padding:10px;border-radius:24px;border:1px solid rgba(247,243,255,.14);background:linear-gradient(180deg, rgba(77,245,255,.08), rgba(255,75,231,.08));min-height:280px}
.modal-media img{width:100%;height:100%;min-height:280px;object-fit:cover;border-radius:18px;border:1px solid rgba(247,243,255,.14)}
.modal-desc{font-size:1.08rem;line-height:1.6;color:rgba(247,243,255,.88);margin:0 0 16px}
.modal-tags{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.modal-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.modal-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}

body.overlay-open{overflow:hidden}
.reveal{opacity:0;transform:translateY(16px);transition:transform var(--t-med) var(--e), opacity var(--t-med) var(--e)}
.reveal.is-visible{opacity:1;transform:translateY(0)}

@media (max-width:1100px){
  .hero-copy{grid-column:1 / -1}
  .hero-aside{grid-column:1 / -1}
  .hero-title{max-width:unset}
  .hairline{display:none}
  .contact-grid,.venue-panel,.modal-body{grid-template-columns:1fr}
}
@media (max-width:900px){
  .header-inner{display:block;padding:12px 0}
  .header-bar{justify-content:space-between;width:100%}
  .nav-toggle{display:inline-flex}
  .header-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--t-med) var(--e), margin-top var(--t-med) var(--e), opacity var(--t-fast) var(--e);margin-top:0;opacity:0}
  .header-panel-inner{min-height:0;overflow:hidden;display:grid;gap:12px;padding:0}
  .site-header.is-menu-open .header-panel{grid-template-rows:1fr;margin-top:12px;opacity:1}
  .primary-nav{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;align-items:stretch}
  .nav-link{width:100%;padding:12px 10px;background:rgba(255,255,255,.03);min-height:56px;display:flex;align-items:center;justify-content:center;text-align:center}
  .nav-link-book{margin-left:0}
  .hero-meta,.hero-strip,.guide-grid,.stages-grid,.guide-highlights,.experience-grid,.gallery-grid,.pricing-grid,.project-list,.perks-grid,.two-col{grid-template-columns:1fr}
  .stepper,.calc-head,.calc-form{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .project{grid-template-columns:92px 1fr}
  .project-thumb{width:92px;height:92px}
}
@media (max-width:640px){
  .site-header{position:sticky;top:0}
  .section-hero{padding-top:42px}
  .container{width:min(100% - 24px, 1280px)}
  .brand{padding:12px 14px;gap:8px;min-width:0}
  .brand-mark,.brand-name{font-size:.92rem}
  .brand-sub{display:inline-flex;white-space:nowrap;font-size:.7rem}
  .primary-nav{grid-template-columns:repeat(4,minmax(0,1fr))}
  .nav-link{padding:11px 8px;font-size:.95rem;min-height:54px}
  .hero-title{font-size:clamp(2.6rem,14vw,4rem)}
  .btn{width:100%}
  .hero-cta,.hero-actions-row,.booking-actions,.footer-links,.modal-actions{display:grid;grid-template-columns:1fr}
  .strip-item,.mini-row,.contact-points li{display:block}
  .modal-card{padding:16px}
  .modal-columns{grid-template-columns:1fr}
}
@media (max-width:480px){
  .primary-nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
  .brand-sub{font-size:.66rem}
  .hero-copy{gap:16px}
  .nav-link{font-size:.86rem;padding:10px 6px;min-height:50px}
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important;transition:none !important}
  .reveal{opacity:1;transform:none}
  body.is-ready .loader{display:none}
}

.card-soft,.contact-card,.step,.gallery-shot,.plan,.meta-card,.accordion-btn,.booking-panel,.calc-output,.project,.hero-visual,.strip-item{transition:transform var(--t-fast) var(--e), box-shadow var(--t-fast) var(--e), border-color var(--t-fast) var(--e), background var(--t-fast) var(--e)}
.card-soft:hover,.contact-card:hover,.step:hover,.strip-item:hover,.hero-visual:hover,.booking-panel:hover,.calc-output:hover{transform:translateY(-3px);box-shadow:0 20px 50px rgba(0,0,0,.32), 0 0 0 1px rgba(77,245,255,.1) inset, 0 0 28px rgba(255,75,231,.08)}
.card-soft,.contact-card,.project,.plan,.hero-visual,.booking-panel,.calc-output,.strip-item{position:relative;overflow:hidden}
.card-soft::after,.contact-card::after,.project::after,.plan::after,.hero-visual::after,.booking-panel::after,.calc-output::after,.strip-item::after{content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg, rgba(255,75,231,.34), rgba(77,245,255,.28), rgba(255,196,77,.22));-webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity var(--t-fast) var(--e);pointer-events:none}
.card-soft:hover::after,.contact-card:hover::after,.project:hover::after,.plan:hover::after,.hero-visual:hover::after,.booking-panel:hover::after,.calc-output:hover::after,.strip-item:hover::after{opacity:.92}
.hero-sub,.project-desc,.plan-sub,.contact-points,.small,.mini-row span,.modal-desc{color:rgba(247,243,255,.88)}
.pay-chip{background:rgba(77,245,255,.08);border-color:rgba(77,245,255,.2);color:rgba(247,243,255,.92)}
.section{padding:42px 0 20px}
.section-hero{padding:122px 0 28px}

body::selection{background:rgba(77,245,255,.22);color:#fff}
.h2,.h3,.hero-title,.project-title,.plan-name,.card-title,.step-name,.plan-price,strong,.contact-side h3,.modal-title,.stage-card .h3,.section-head h2{color:var(--silver);text-shadow:0 0 18px rgba(218,230,255,.12), 0 0 30px rgba(77,245,255,.05)}
.project-title,.project-desc,.project .tag,.project button,.project,.stage-card,.accordion-btn,.step,.pill-btn,.plan,.contact-card,.footer-links a,.footer-link-btn,.mini-row strong,.mini-card strong{color:var(--silver-soft)}
.project-title{font-size:1.26rem;font-weight:700}
.project-desc{line-height:1.45}
.stage-card{padding:22px;cursor:pointer;transition:transform var(--t-fast) var(--e), box-shadow var(--t-fast) var(--e), border-color var(--t-fast) var(--e), background var(--t-fast) var(--e)}
.stage-card:hover{transform:translateY(-5px);border-color:rgba(77,245,255,.32);box-shadow:0 18px 48px rgba(0,0,0,.34),0 0 0 1px rgba(77,245,255,.12) inset,0 0 34px rgba(77,245,255,.12),0 0 42px rgba(255,75,231,.09)}
.stage-card::after{content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg, rgba(77,245,255,.42), rgba(255,75,231,.34), rgba(255,196,77,.26));-webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity var(--t-fast) var(--e);pointer-events:none}
.stage-card:hover::after,.stage-card:focus-visible::after{opacity:1}
.stage-trigger-line{margin-top:14px;font-family:'Orbitron','Space Grotesk',sans-serif;font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(220,233,255,.82);text-shadow:0 0 18px rgba(77,245,255,.14)}
.loader{background:radial-gradient(circle at 50% 40%, rgba(255,75,231,.22), transparent 28%), radial-gradient(circle at 64% 48%, rgba(77,245,255,.18), transparent 20%), rgba(9,4,18,.965)}
.loader::before,.loader::after{content:'';position:absolute;inset:auto;pointer-events:none;filter:blur(12px);opacity:.9}
.loader::before{left:-10vw;bottom:14vh;width:44vw;height:20vh;border-radius:50%;background:radial-gradient(circle at 30% 50%, rgba(255,75,231,.35), transparent 60%);animation:loaderWaveA 4.2s ease-in-out infinite}
.loader::after{right:-8vw;top:16vh;width:38vw;height:18vh;border-radius:50%;background:radial-gradient(circle at 60% 50%, rgba(77,245,255,.28), transparent 60%);animation:loaderWaveB 4.8s ease-in-out infinite}
@keyframes loaderWaveA{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(4vw,-1vh,0) scale(1.12)}}
@keyframes loaderWaveB{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(-4vw,2vh,0) scale(1.08)}}
.particle{background:linear-gradient(135deg, rgba(255,255,255,.95), rgba(77,245,255,.72));box-shadow:0 0 18px rgba(77,245,255,.7), 0 0 26px rgba(255,75,231,.24)}
.wave-layer::before,.wave-layer::after{content:'';position:absolute;inset:0;pointer-events:none}
.wave-layer::before{background:radial-gradient(circle at 14% 26%, rgba(255,75,231,.16), transparent 24%), radial-gradient(circle at 86% 18%, rgba(77,245,255,.12), transparent 22%), radial-gradient(circle at 72% 62%, rgba(255,196,77,.08), transparent 28%);mix-blend-mode:screen;opacity:.95}
.wave-layer::after{background:linear-gradient(110deg, transparent 0%, rgba(255,75,231,.06) 18%, rgba(77,245,255,.08) 36%, transparent 54%, rgba(255,196,77,.06) 70%, transparent 100%);filter:blur(18px);opacity:.85;animation:auroraSweep 14s linear infinite}
.wave{height:220px;border-top:1px solid rgba(77,245,255,.24);box-shadow:0 0 24px rgba(77,245,255,.06);mix-blend-mode:screen}
.wave-a{bottom:15vh;opacity:.9}
.wave-b{bottom:34vh;opacity:.66}
.wave-c{bottom:54vh;opacity:.48}
.aurora-ribbon{position:absolute;left:-14vw;width:54vw;height:20vh;border-radius:999px;filter:blur(18px);opacity:.32;mix-blend-mode:screen;transform-origin:center;animation:auroraFloat 18s ease-in-out infinite}
.aurora-ribbon.r1{top:16vh;background:linear-gradient(90deg, rgba(255,75,231,.36), rgba(77,245,255,.12), rgba(255,75,231,0));animation-delay:-2s}
.aurora-ribbon.r2{top:42vh;background:linear-gradient(90deg, rgba(77,245,255,.28), rgba(255,196,77,.1), rgba(77,245,255,0));animation-delay:-8s}
.aurora-ribbon.r3{top:68vh;background:linear-gradient(90deg, rgba(255,196,77,.18), rgba(255,75,231,.12), rgba(255,196,77,0));animation-delay:-12s}
@keyframes auroraFloat{0%,100%{transform:translate3d(0,0,0) rotate(-8deg) scaleX(1)}50%{transform:translate3d(26vw,-3vh,0) rotate(-2deg) scaleX(1.16)}}
@keyframes auroraSweep{0%{transform:translateX(-10%)}100%{transform:translateX(10%)}}


/* v4 immersive motion, loader, audio, and mobile header refinements */
#page{position:relative;z-index:2;opacity:0;transform:translateY(18px) scale(1.01);filter:blur(10px);transition:opacity 1.05s var(--e), transform 1.05s var(--e), filter 1.05s var(--e)}
body.is-ready #page{opacity:1;transform:none;filter:none}

.particle-layer,
.wave-layer{z-index:0}
.particle-layer{opacity:1}
.wave-layer{opacity:1}
.wave-layer::before{opacity:1}
.wave-layer::after{opacity:.95;filter:blur(22px)}
.particle{opacity:.52}
.wave{height:250px;border-top:1px solid rgba(146,251,255,.34);box-shadow:0 0 28px rgba(77,245,255,.12), 0 0 48px rgba(255,75,231,.06)}
.wave-a{bottom:12vh;opacity:.96}
.wave-b{bottom:28vh;opacity:.78}
.wave-c{bottom:46vh;opacity:.6}
.wave-d{bottom:66vh;opacity:.42;transform:scaleX(1.22);animation:waveDrift 34s linear infinite}
.aurora-ribbon{opacity:.46;filter:blur(24px)}
.aurora-ribbon.r1{top:14vh;height:22vh}
.aurora-ribbon.r2{top:38vh;height:22vh}
.aurora-ribbon.r3{top:64vh;height:20vh}
@keyframes waveDrift{0%{transform:translateX(0) scaleX(1.05)}50%{transform:translateX(-5vw) scaleX(1.16)}100%{transform:translateX(0) scaleX(1.05)}}
@keyframes auroraSweep{0%{transform:translateX(-18%) scaleX(1)}50%{transform:translateX(4%) scaleX(1.08)}100%{transform:translateX(18%) scaleX(1)}}

.loader{background:
  radial-gradient(circle at 20% 24%, rgba(255,75,231,.3), transparent 22%),
  radial-gradient(circle at 78% 20%, rgba(77,245,255,.22), transparent 20%),
  radial-gradient(circle at 50% 70%, rgba(255,196,77,.12), transparent 26%),
  linear-gradient(180deg, rgba(10,4,20,.985), rgba(6,3,14,.985));
  overflow:hidden;
}
.loader::before,.loader::after{display:none}
.loader-sky{position:absolute;inset:0;pointer-events:none}
.loader-ribbon{position:absolute;left:-18vw;width:64vw;height:16vh;border-radius:999px;filter:blur(24px);opacity:.42;mix-blend-mode:screen;transform-origin:center}
.loader-ribbon.ribbon-a{top:18vh;background:linear-gradient(90deg, rgba(255,75,231,.45), rgba(77,245,255,.18), rgba(255,75,231,0));animation:loaderRibbonA 7s ease-in-out infinite}
.loader-ribbon.ribbon-b{top:40vh;background:linear-gradient(90deg, rgba(77,245,255,.36), rgba(255,196,77,.12), rgba(77,245,255,0));animation:loaderRibbonB 8.5s ease-in-out infinite}
.loader-ribbon.ribbon-c{top:66vh;background:linear-gradient(90deg, rgba(255,196,77,.22), rgba(255,75,231,.16), rgba(255,196,77,0));animation:loaderRibbonC 9.5s ease-in-out infinite}
.loader-spark{position:absolute;width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg, rgba(255,255,255,.98), rgba(77,245,255,.8));box-shadow:0 0 20px rgba(77,245,255,.7), 0 0 30px rgba(255,75,231,.3);opacity:.8}
.loader-spark.spark-a{left:18%;top:28%;animation:loaderSpark 4.8s ease-in-out infinite}
.loader-spark.spark-b{right:21%;top:36%;animation:loaderSpark 6.2s ease-in-out infinite -.9s}
.loader-spark.spark-c{left:62%;bottom:24%;animation:loaderSpark 5.6s ease-in-out infinite -1.5s}
.loader-inner{
  width:min(580px,calc(100% - 36px));
  padding:30px 28px 26px;
  border-radius:34px;
  background:linear-gradient(180deg, rgba(19,10,35,.86), rgba(13,8,24,.78));
  box-shadow:0 28px 90px rgba(0,0,0,.5), 0 0 0 1px rgba(77,245,255,.08) inset, 0 0 60px rgba(255,75,231,.14);
  position:relative;
  overflow:hidden;
}
.loader-inner::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(77,245,255,.08), rgba(255,75,231,.08), rgba(255,196,77,.06));
  pointer-events:none;
}
.loader-art{
  position:relative;
  width:min(250px,58vw);
  aspect-ratio:1;
  margin:0 auto 18px;
}
.loader-ring,
.loader-orb{
  position:absolute;inset:0;
  border-radius:50%;
}
.loader-ring{border:1px solid rgba(247,243,255,.16)}
.loader-ring.ring-a{inset:8%;border-color:rgba(77,245,255,.32);box-shadow:0 0 28px rgba(77,245,255,.18);animation:loaderSpinA 11s linear infinite}
.loader-ring.ring-b{inset:20%;border-color:rgba(255,75,231,.32);box-shadow:0 0 22px rgba(255,75,231,.18);animation:loaderSpinB 8s linear infinite reverse}
.loader-ring.ring-c{inset:34%;border-color:rgba(255,196,77,.28);box-shadow:0 0 18px rgba(255,196,77,.14);animation:loaderSpinC 5.5s linear infinite}
.loader-orb{
  inset:40%;
  background:radial-gradient(circle at 35% 35%, rgba(255,255,255,.92), rgba(77,245,255,.72) 28%, rgba(255,75,231,.48) 62%, rgba(255,75,231,0) 76%);
  filter:blur(.2px);
  box-shadow:0 0 28px rgba(77,245,255,.3), 0 0 48px rgba(255,75,231,.28);
  animation:loaderOrb 3.8s ease-in-out infinite;
}
.loader-bars{
  position:absolute;left:50%;bottom:10%;
  transform:translateX(-50%);
  display:grid;grid-template-columns:repeat(7,1fr);gap:7px;
  width:70%;
}
.loader-bars span{
  display:block;border-radius:999px 999px 0 0;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(77,245,255,.78) 36%, rgba(255,75,231,.42) 100%);
  box-shadow:0 0 18px rgba(77,245,255,.2);
  transform-origin:center bottom;
  animation:loaderBars 1.2s ease-in-out infinite;
}
.loader-bars span:nth-child(1){height:18px;animation-delay:-.5s}
.loader-bars span:nth-child(2){height:28px;animation-delay:-.2s}
.loader-bars span:nth-child(3){height:42px;animation-delay:-.8s}
.loader-bars span:nth-child(4){height:54px;animation-delay:-.35s}
.loader-bars span:nth-child(5){height:40px;animation-delay:-.62s}
.loader-bars span:nth-child(6){height:28px;animation-delay:-.15s}
.loader-bars span:nth-child(7){height:18px;animation-delay:-.45s}
.loader-mark{position:relative;z-index:1;display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.loader-tagline{
  position:relative;z-index:1;
  margin:12px auto 0;
  max-width:34ch;
  text-align:center;
  color:rgba(239,244,255,.8);
  font-size:1rem;
  line-height:1.45;
  text-shadow:0 0 24px rgba(77,245,255,.08);
}
.loader-track{position:relative;z-index:1;height:10px;background:rgba(255,255,255,.08);box-shadow:0 0 0 1px rgba(255,255,255,.04) inset;margin:20px 0 14px}
.loader-fill{box-shadow:0 0 16px rgba(77,245,255,.5), 0 0 32px rgba(255,75,231,.22)}
.loader-readout{position:relative;z-index:1;align-items:center}
body.is-ready .loader{opacity:0;visibility:hidden;pointer-events:none;transition-duration:.7s}
@keyframes loaderRibbonA{0%,100%{transform:translate3d(0,0,0) rotate(-8deg) scaleX(1)}50%{transform:translate3d(32vw,-2vh,0) rotate(-2deg) scaleX(1.18)}}
@keyframes loaderRibbonB{0%,100%{transform:translate3d(0,0,0) rotate(-4deg) scaleX(1)}50%{transform:translate3d(28vw,1vh,0) rotate(2deg) scaleX(1.12)}}
@keyframes loaderRibbonC{0%,100%{transform:translate3d(0,0,0) rotate(-6deg) scaleX(1)}50%{transform:translate3d(30vw,-1vh,0) rotate(1deg) scaleX(1.1)}}
@keyframes loaderSpark{0%,100%{transform:translate3d(0,0,0) scale(.9);opacity:.5}50%{transform:translate3d(0,-18px,0) scale(1.28);opacity:1}}
@keyframes loaderSpinA{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes loaderSpinB{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes loaderSpinC{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes loaderOrb{0%,100%{transform:scale(.98)}50%{transform:scale(1.14)}}
@keyframes loaderBars{0%,100%{transform:scaleY(.72);opacity:.7}50%{transform:scaleY(1.18);opacity:1}}

.sound-toggle{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:1200;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid rgba(77,245,255,.24);
  background:linear-gradient(135deg, rgba(18,10,30,.9), rgba(11,7,20,.86));
  color:var(--silver);
  box-shadow:0 0 0 1px rgba(77,245,255,.08) inset, 0 0 24px rgba(77,245,255,.14), 0 0 32px rgba(255,75,231,.08);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}
.sound-toggle:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(77,245,255,.12) inset, 0 0 28px rgba(77,245,255,.18), 0 0 42px rgba(255,75,231,.12)}
.sound-toggle.is-on{
  border-color:rgba(77,245,255,.4);
  background:linear-gradient(135deg, rgba(255,75,231,.18), rgba(77,245,255,.14) 58%, rgba(255,196,77,.14));
}
.sound-toggle-ico{
  width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, rgba(255,255,255,.95), rgba(77,245,255,.78) 36%, rgba(255,75,231,.46) 70%, rgba(255,75,231,0) 78%);
  box-shadow:0 0 18px rgba(77,245,255,.34), 0 0 28px rgba(255,75,231,.18);
  flex-shrink:0;
}
.sound-toggle.is-on .sound-toggle-ico{animation:soundPulse 1.8s ease-in-out infinite}
.sound-toggle-label{font-weight:600}
.sound-status{padding:4px 10px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(247,243,255,.1);font-size:.82rem}
@keyframes soundPulse{0%,100%{transform:scale(.92)}50%{transform:scale(1.12)}}

@media (max-width:900px){
  .header-panel-inner{justify-items:end}
  .primary-nav{
    width:min(100%, 560px);
    margin-left:auto;
    justify-self:end;
  }
  .nav-link-contact{order:7}
  .nav-link-book{
    order:6;
    grid-column:2 / span 2;
    min-width:0;
  }
}
@media (max-width:640px){
  .header-inner{padding:8px 0 12px}
  .header-panel{margin-top:0}
  .site-header.is-menu-open .header-panel{margin-top:10px}
  .header-panel-inner{
    justify-items:end;
  }
  .primary-nav{
    width:min(100%, 430px);
    margin-left:auto;
    justify-self:end;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:10px;
  }
  .nav-link{
    min-height:56px;
    justify-content:center;
    text-align:center;
    border-radius:20px;
  }
  .nav-link-book{
    grid-column:2 / span 2;
    padding-inline:14px;
    font-size:1rem;
    background:linear-gradient(135deg, rgba(255,75,231,.28), rgba(77,245,255,.18) 55%, rgba(255,196,77,.18));
    box-shadow:0 0 0 1px rgba(77,245,255,.16) inset, 0 0 28px rgba(77,245,255,.18), 0 0 42px rgba(255,75,231,.14);
  }
  .nav-link-contact{grid-column:4}
  .section-hero{
    padding-top:18px;
  }
  .hero-copy{
    gap:14px;
  }
  .kicker{
    gap:12px;
  }
  .sound-toggle{
    right:12px;
    bottom:12px;
    padding:11px 14px;
  }
}
@media (max-width:480px){
  .header-inner{padding:8px 0 10px}
  .brand{padding:10px 13px}
  .primary-nav{
    width:100%;
    grid-template-columns:repeat(4, minmax(0, 1fr));
  }
  .nav-link{
    font-size:.84rem;
    min-height:54px;
    padding:10px 6px;
  }
  .nav-link-book{
    grid-column:2 / span 2;
    font-size:.92rem;
  }
  .section-hero{
    padding-top:12px;
  }
  .hero-title{
    font-size:clamp(2.55rem, 14vw, 4rem);
  }
  .hero-sub{
    margin-top:-4px;
  }
  .sound-toggle-label{display:none}
}
@media (prefers-reduced-motion: reduce){
  #page{opacity:1;transform:none;filter:none}
}


/* v5 desktop header, tighter hero, stronger loader, stronger waves */
@media (min-width: 901px){
  .header-inner{gap:30px;min-height:76px;align-items:center}
  .header-bar{flex:0 0 auto}
  .header-panel{flex:1;justify-content:flex-end}
  .header-panel-inner{justify-content:flex-end;width:100%}
  .primary-nav{justify-content:flex-end;flex-wrap:nowrap;width:100%;gap:10px}
  .nav-link{flex:0 0 auto}
  .nav-link-book{margin-left:18px}
  .section-hero{padding-top:72px}
  .hero-grid{gap:24px;align-items:start}
  .hero-copy{padding-top:8px}
}

.loader-stage-pills{position:relative;z-index:1;display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin:16px 0 2px}
.loader-stage-pills span{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;border:1px solid rgba(247,243,255,.16);background:linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.025));box-shadow:0 0 0 1px rgba(255,255,255,.02) inset, 0 0 18px rgba(77,245,255,.08);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-family:'Orbitron','Space Grotesk',sans-serif;color:rgba(239,244,255,.88)}
.loader-stage-pills span:nth-child(1){border-color:rgba(77,245,255,.2)}
.loader-stage-pills span:nth-child(2){border-color:rgba(255,75,231,.2)}
.loader-stage-pills span:nth-child(3){border-color:rgba(255,196,77,.2)}
.loader-sky::before,.loader-sky::after{content:'';position:absolute;left:-10vw;right:-10vw;height:180px;border-top:1px solid rgba(146,251,255,.28);border-radius:50%;box-shadow:0 0 22px rgba(77,245,255,.12);opacity:.95}
.loader-sky::before{bottom:18vh;animation:loaderSkyWave 5.8s linear infinite}
.loader-sky::after{bottom:34vh;opacity:.62;transform:scaleX(1.16);animation:loaderSkyWave 7.4s linear infinite reverse}
@keyframes loaderSkyWave{0%{transform:translateX(0) scaleX(1.02)}50%{transform:translateX(-4vw) scaleX(1.12)}100%{transform:translateX(0) scaleX(1.02)}}
.loader-inner{box-shadow:0 32px 120px rgba(0,0,0,.58), 0 0 0 1px rgba(77,245,255,.1) inset, 0 0 90px rgba(255,75,231,.18), 0 0 120px rgba(77,245,255,.08)}
.loader-inner::after{content:'';position:absolute;inset:auto -12% -28% -12%;height:36%;background:radial-gradient(circle at 50% 0%, rgba(255,75,231,.2), rgba(77,245,255,.12) 38%, rgba(255,196,77,.08) 60%, transparent 74%);filter:blur(26px);pointer-events:none;opacity:.95}
.loader-tagline{font-size:1.02rem}
.wave-layer{opacity:1.15}
.wave-layer::before{opacity:1}
.wave-layer::after{opacity:1;filter:blur(26px)}
.wave{border-top:1px solid rgba(174,252,255,.38);box-shadow:0 0 34px rgba(77,245,255,.18), 0 0 50px rgba(255,75,231,.1)}
.wave-a{bottom:11vh}
.wave-b{bottom:28vh}
.wave-c{bottom:45vh}
.wave-d{bottom:62vh;opacity:.56}
.aurora-ribbon{opacity:.58;filter:blur(30px)}
.hero-copy .kicker,.hero-copy .hero-title,.hero-copy .hero-sub,.hero-copy .hero-cta,.hero-copy .hero-meta,.hero-copy .hero-strip,.hero-aside .hero-visual{will-change:transform,opacity}
body.is-ready .hero-copy .kicker{animation:heroRise .9s var(--e) both .08s}
body.is-ready .hero-copy .hero-title{animation:heroRise 1.1s var(--e) both .18s}
body.is-ready .hero-copy .hero-sub{animation:heroRise .95s var(--e) both .28s}
body.is-ready .hero-copy .hero-cta{animation:heroRise .95s var(--e) both .38s}
body.is-ready .hero-copy .hero-meta{animation:heroRise 1s var(--e) both .46s}
body.is-ready .hero-copy .hero-strip{animation:heroRise 1.05s var(--e) both .56s}
body.is-ready .hero-aside .hero-visual{animation:heroRiseWide 1.15s var(--e) both .26s}
@keyframes heroRise{0%{opacity:0;transform:translateY(30px) scale(.985);filter:blur(8px)}100%{opacity:1;transform:none;filter:none}}
@keyframes heroRiseWide{0%{opacity:0;transform:translate3d(24px,28px,0) scale(.985);filter:blur(10px)}100%{opacity:1;transform:none;filter:none}}


/* v6 modal reliability and richer interaction polish */
.stage-card{cursor:pointer;position:relative;z-index:2}
.stage-card:focus-visible,.project:focus-visible{outline:2px solid rgba(77,245,255,.6);outline-offset:3px}
.stage-card:hover{box-shadow:0 0 0 1px rgba(77,245,255,.14) inset, 0 18px 44px rgba(0,0,0,.34), 0 0 28px rgba(77,245,255,.12), 0 0 40px rgba(255,75,231,.08)}
.modal{backdrop-filter:blur(12px)}
.sound-toggle-label::after{content:' music';font-weight:500;color:rgba(247,243,255,.7)}
@media (max-width: 900px){
  .sound-toggle-label::after{content:''}
}

@media (max-width: 900px) {
  .site-header {
    overflow: visible;
  }

  .header-panel {
    width: 100%;
    overflow: hidden;
  }

  .site-header.is-menu-open .header-panel {
    display: block !important;
    grid-template-rows: none !important;
    height: auto !important;
    max-height: calc(100svh - 86px) !important;
    margin-top: 10px !important;
    padding-top: 12px !important;
    opacity: 1 !important;
    overflow: visible !important;
  }

  .header-panel-inner {
    width: 100%;
    justify-items: stretch !important;
    display: block !important;
    overflow: visible !important;
  }

  .primary-nav {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    justify-self: stretch !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    max-height: min(62svh, 480px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 2px;
  }

  .nav-link,
  .nav-link-book,
  .nav-link-contact {
    grid-column: auto !important;
    order: initial !important;
    min-width: 0 !important;
    min-height: 52px !important;
    padding: 10px 8px !important;
    font-size: clamp(0.84rem, 3.5vw, 0.98rem) !important;
    line-height: 1.1;
  }

  .nav-link-book {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 420px) {
  .primary-nav {
    grid-template-columns: 1fr !important;
  }

  .nav-link,
  .nav-link-book,
  .nav-link-contact {
    min-height: 48px !important;
  }
}
