:root{
  --bg:#fbfaff;
  --bg-2:#f1ecf9;
  --surface:#ffffff;
  --surface-2:#f5f0fb;
  --ink:#1a1428;
  --ink-dim:#5f5872;
  --brand:#9b4bd0;
  --brand-2:#7c3ebf;
  --brand-soft:#e0c6f4;
  --accent:#9b4bd0;
  --accent-2:#7c3ebf;
  --accent-3:#c77dee;
  --card:rgba(255,255,255,.78);
  --card-br:rgba(26,20,40,.08);
  --glow:0 20px 60px -20px rgba(155,75,208,.35);
  --radius:22px;
  --ease:cubic-bezier(.2,.8,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:"Inter","Segoe UI",system-ui,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}
body{overflow-x:hidden;min-height:100vh;line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ambient gradient background */
.bg-stage{position:fixed;inset:0;z-index:-2;background:radial-gradient(1200px 600px at 10% -10%,rgba(199,125,238,.22),transparent 60%),
  radial-gradient(900px 500px at 90% 10%,rgba(167,139,250,.18),transparent 60%),
  radial-gradient(1000px 700px at 50% 120%,rgba(224,198,244,.28),transparent 60%),
  linear-gradient(180deg,#fbfaff 0%,#f3edfa 100%);}
.bg-grid{position:fixed;inset:0;z-index:-1;background-image:
  linear-gradient(rgba(26,20,40,.04) 1px,transparent 1px),
  linear-gradient(90deg,rgba(26,20,40,.04) 1px,transparent 1px);
  background-size:60px 60px;mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);}
.blob{position:fixed;filter:blur(90px);opacity:.35;z-index:-1;border-radius:50%;pointer-events:none;animation:float 14s var(--ease) infinite alternate}
.blob.b1{width:520px;height:520px;background:#c77dee;top:-120px;left:-120px}
.blob.b2{width:460px;height:460px;background:#a78bfa;top:30%;right:-120px;animation-delay:-4s}
.blob.b3{width:420px;height:420px;background:#f4c8ff;bottom:-120px;left:30%;animation-delay:-8s}
@keyframes float{to{transform:translate(40px,60px) scale(1.1)}}

/* nav — floating pill */
.nav{position:sticky;top:14px;z-index:50;max-width:1260px;margin:14px auto 0;padding:0 20px;pointer-events:none}
.nav-inner{pointer-events:auto;background:rgba(255,255,255,.78);-webkit-backdrop-filter:saturate(180%) blur(22px);backdrop-filter:saturate(180%) blur(22px);border:1px solid rgba(26,20,40,.08);border-radius:999px;padding:8px 10px 8px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:0 18px 40px -22px rgba(26,20,40,.2),0 2px 0 rgba(255,255,255,.5) inset}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.5px;padding:4px 4px 4px 0;border-radius:999px;transition:opacity .3s}
.brand:hover{opacity:.85}
.brand-logo{height:34px;width:auto;display:block;filter:drop-shadow(0 6px 14px rgba(155,75,208,.25))}
.brand-sep{width:1px;height:22px;background:linear-gradient(180deg,transparent,rgba(26,20,40,.2),transparent);margin:0 6px}
.brand-tag{font-size:11px;color:var(--ink-dim);letter-spacing:2.5px;text-transform:uppercase;font-weight:700}
.nav-links{display:flex;gap:2px;align-items:center}
.nav-links a:not(.btn){position:relative;padding:9px 14px;border-radius:999px;color:var(--ink-dim);font-size:14px;font-weight:600;transition:color .25s var(--ease),background .25s var(--ease)}
.nav-links a:not(.btn):hover{color:var(--brand-2);background:rgba(155,75,208,.09)}
.nav-links a.active{color:var(--brand-2);background:rgba(155,75,208,.12)}
.nav-links a.active::after{content:"";position:absolute;left:50%;bottom:3px;transform:translateX(-50%);width:16px;height:2px;border-radius:2px;background:var(--brand)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:999px;font-weight:600;font-size:14px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s}
.nav-links .btn{padding:10px 18px;font-size:13.5px}
.btn-primary{background:linear-gradient(135deg,#9b4bd0,#7c3ebf);color:#fff;box-shadow:0 10px 28px -10px rgba(124,62,191,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 40px -12px rgba(124,62,191,.7)}
.btn-ghost{background:rgba(255,255,255,.7);border:1px solid rgba(26,20,40,.12);color:var(--ink);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:#fff;transform:translateY(-2px);border-color:rgba(155,75,208,.3)}
.menu-btn{display:none}

/* hero */
.hero{max-width:1280px;margin:0 auto;padding:80px 28px 60px;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border-radius:999px;background:rgba(199,125,238,.14);border:1px solid rgba(155,75,208,.25);font-size:12px;color:var(--accent-2);font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:28px}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-size:clamp(44px,7vw,96px);line-height:1.02;font-weight:800;letter-spacing:-.02em;margin-bottom:24px}
.hero h1 .grad{background:linear-gradient(135deg,#9b4bd0 0%,#7c3ebf 55%,#5e2a99 100%);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}
.hero p.lead{font-size:clamp(16px,1.4vw,20px);color:var(--ink-dim);max-width:720px;margin-bottom:40px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:60px}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:24px;padding:28px;border-radius:var(--radius);background:var(--card);border:1px solid var(--card-br);backdrop-filter:blur(16px);box-shadow:0 20px 50px -30px rgba(26,20,40,.25)}
.stat .num{font-size:36px;font-weight:800;background:linear-gradient(135deg,#9b4bd0,#7c3ebf);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lbl{font-size:13px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:1.5px;margin-top:4px}

/* section */
.section{max-width:1280px;margin:0 auto;padding:90px 28px}
.section-head{text-align:center;margin-bottom:60px}
.section-head .eyebrow{margin-bottom:20px}
.section-head h2{font-size:clamp(32px,4vw,52px);font-weight:800;letter-spacing:-.02em;line-height:1.1;margin-bottom:16px}
.section-head h2 .grad{background:linear-gradient(135deg,#9b4bd0,#7c3ebf,#5e2a99);-webkit-background-clip:text;background-clip:text;color:transparent}
.section-head p{color:var(--ink-dim);max-width:680px;margin:0 auto;font-size:17px}

/* marquee industries */
.marquee{overflow:hidden;padding:18px 0;mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent);margin-top:40px}
.marquee-track{display:flex;gap:44px;animation:scroll 40s linear infinite;width:max-content}
@keyframes scroll{to{transform:translateX(-50%)}}
.m-item{display:flex;align-items:center;gap:10px;padding:10px 22px;border-radius:999px;background:#fff;border:1px solid rgba(26,20,40,.08);white-space:nowrap;color:var(--ink);font-weight:500;font-size:14px;box-shadow:0 6px 18px -10px rgba(26,20,40,.15)}

/* catalogs grid */
.cats{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px}
.cat{position:relative;border-radius:var(--radius);padding:30px;overflow:hidden;background:#fff;border:1px solid var(--card-br);backdrop-filter:blur(16px);transition:transform .5s var(--ease),border-color .3s,box-shadow .5s var(--ease);display:flex;flex-direction:column;min-height:520px;box-shadow:0 14px 40px -24px rgba(26,20,40,.25)}
.cat::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 200px at var(--mx,50%) var(--my,0%),rgba(199,125,238,.22),transparent 60%);opacity:0;transition:opacity .5s;pointer-events:none}
.cat:hover{transform:translateY(-8px);border-color:rgba(155,75,208,.35);box-shadow:0 30px 70px -30px rgba(155,75,208,.35)}
.cat:hover::before{opacity:1}
.cat-cover{border-radius:16px;overflow:hidden;margin-bottom:24px;aspect-ratio:16/10;background:var(--surface-2);position:relative;border:1px solid rgba(26,20,40,.06)}
.cat-cover img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.cat:hover .cat-cover img{transform:scale(1.06)}
.cat-cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(26,20,40,.35));pointer-events:none}
.cat-badge{position:absolute;top:14px;left:14px;padding:6px 12px;border-radius:999px;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:700;color:var(--brand-2);border:1px solid rgba(155,75,208,.2)}
.cat-pages{position:absolute;bottom:14px;right:14px;padding:6px 12px;border-radius:999px;background:rgba(255,255,255,.9);font-size:12px;color:var(--ink);backdrop-filter:blur(10px);border:1px solid rgba(26,20,40,.1);font-weight:600}
.cat h3{font-size:26px;font-weight:800;letter-spacing:-.01em;margin-bottom:10px}
.cat p{color:var(--ink-dim);font-size:15px;flex:1}
.cat-actions{display:flex;gap:10px;margin-top:22px;flex-wrap:wrap}
.cat .btn{padding:11px 18px;font-size:13px}

/* products */
.products{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.prod{border-radius:18px;padding:26px;background:#fff;border:1px solid var(--card-br);transition:transform .4s var(--ease),border-color .3s,box-shadow .4s;position:relative;overflow:hidden;box-shadow:0 10px 30px -22px rgba(26,20,40,.2)}
.prod:hover{transform:translateY(-5px);border-color:rgba(155,75,208,.35);box-shadow:0 24px 48px -26px rgba(155,75,208,.3)}
.prod-icon{width:50px;height:50px;border-radius:14px;background:linear-gradient(135deg,rgba(199,125,238,.22),rgba(167,139,250,.22));display:grid;place-items:center;font-size:24px;margin-bottom:18px;border:1px solid rgba(155,75,208,.18)}
.prod h4{font-size:18px;font-weight:700;margin-bottom:8px}
.prod .tag{font-size:11px;letter-spacing:2px;color:var(--accent-2);font-weight:700;text-transform:uppercase;margin-bottom:10px;display:block}
.prod ul{list-style:none;margin-top:14px}
.prod li{font-size:13.5px;color:var(--ink-dim);padding:6px 0;padding-left:22px;position:relative}
.prod li::before{content:"";position:absolute;left:0;top:14px;width:12px;height:1.5px;background:linear-gradient(90deg,var(--brand),transparent)}

/* CTA footer */
.cta{margin:40px auto 0;max-width:1280px;padding:60px 28px}
.cta-card{border-radius:28px;padding:60px 40px;text-align:center;background:linear-gradient(135deg,rgba(199,125,238,.18),rgba(167,139,250,.15),rgba(244,198,244,.2));border:1px solid rgba(155,75,208,.18);position:relative;overflow:hidden;box-shadow:0 30px 60px -30px rgba(155,75,208,.3)}
.cta-card::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 200px at 50% 0%,rgba(199,125,238,.35),transparent 70%);pointer-events:none}
.cta-card h2{font-size:clamp(28px,3.5vw,44px);font-weight:800;margin-bottom:16px;position:relative}
.cta-card p{color:var(--ink-dim);max-width:520px;margin:0 auto 28px;position:relative}
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative}

footer{padding:50px 28px 30px;max-width:1280px;margin:0 auto;border-top:1px solid rgba(26,20,40,.08);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;color:var(--ink-dim);font-size:13px}
footer a:hover{color:var(--ink)}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.show{opacity:1;transform:none}

/* ============== Catalog viewer page ============== */
.viewer-wrap{min-height:100vh;display:flex;flex-direction:column}
.viewer-head{max-width:1680px;width:100%;margin:0 auto;padding:20px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.viewer-title{display:flex;align-items:center;gap:14px}
.viewer-title h1{font-size:20px;font-weight:700}
.viewer-title span{font-size:12px;color:var(--ink-dim);display:block;letter-spacing:2px;text-transform:uppercase}
.viewer-actions{display:flex;gap:10px;flex-wrap:wrap}

.flipbook{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;perspective:3000px;min-height:70vh}
.book{position:relative;display:flex;gap:0;max-width:min(1500px,95vw);width:100%;aspect-ratio:16/9;max-height:80vh;filter:drop-shadow(0 30px 50px rgba(26,20,40,.25))}
.book-page{position:absolute;inset:0;width:100%;height:100%;border-radius:14px;overflow:hidden;background:#fff;border:1px solid rgba(26,20,40,.08);display:grid;place-items:center;opacity:0;transform:scale(.95) translateY(10px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.book-page.active{opacity:1;transform:none;z-index:2}
.book-page.prev,.book-page.next{opacity:.15;transform:scale(.88);z-index:1;pointer-events:none}
.book-page img{width:100%;height:100%;object-fit:contain;background:#fff}

.nav-arrow{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.92);border:1px solid rgba(26,20,40,.1);backdrop-filter:blur(14px);display:grid;place-items:center;z-index:5;color:var(--ink);transition:background .3s,transform .3s;box-shadow:0 8px 24px -10px rgba(26,20,40,.25)}
.nav-arrow:hover{background:var(--brand);color:#fff;transform:translateY(-50%) scale(1.1)}
.nav-arrow.prev{left:14px}
.nav-arrow.next{right:14px}
.nav-arrow svg{width:22px;height:22px}
.nav-arrow:disabled{opacity:.3;cursor:not-allowed}

.thumbs{max-width:1680px;width:100%;margin:0 auto 28px;padding:0 28px;display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:rgba(26,20,40,.2) transparent}
.thumbs::-webkit-scrollbar{height:6px}
.thumbs::-webkit-scrollbar-thumb{background:rgba(26,20,40,.2);border-radius:4px}
.thumb{flex:0 0 120px;aspect-ratio:16/10;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;opacity:.6;transition:opacity .3s,border-color .3s,transform .3s;scroll-snap-align:center;background:#fff;box-shadow:0 4px 12px -6px rgba(26,20,40,.2)}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb:hover{opacity:.95;transform:translateY(-2px)}
.thumb.active{opacity:1;border-color:var(--brand);box-shadow:0 6px 20px -5px rgba(155,75,208,.45)}

.counter{padding:8px 16px;border-radius:999px;background:#fff;border:1px solid rgba(26,20,40,.1);font-size:13px;color:var(--ink-dim);font-variant-numeric:tabular-nums;box-shadow:0 4px 12px -8px rgba(26,20,40,.2)}
.counter b{color:var(--ink);font-weight:700}

/* ============== Detail page (humanoid/go2/family) ============== */
.hero-split{max-width:1280px;margin:0 auto;padding:70px 28px 40px;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero-split .eyebrow{margin-bottom:22px}
.hero-split h1{font-size:clamp(38px,5.5vw,72px);line-height:1.04;font-weight:800;letter-spacing:-.02em;margin-bottom:20px}
.hero-split p.lead{font-size:17px;color:var(--ink-dim);margin-bottom:28px;max-width:560px}
.hero-visual{position:relative;border-radius:24px;overflow:hidden;border:1px solid rgba(26,20,40,.08);background:var(--surface-2);aspect-ratio:16/10;box-shadow:0 40px 80px -30px rgba(26,20,40,.3),0 0 0 1px rgba(155,75,208,.12)}
.hero-visual img{width:100%;height:100%;object-fit:cover}
.hero-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(140deg,transparent 55%,rgba(199,125,238,.1),rgba(167,139,250,.14));pointer-events:none}
.hero-badge{position:absolute;top:20px;left:20px;padding:8px 16px;border-radius:999px;font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:700;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border:1px solid rgba(155,75,208,.2);color:var(--brand-2)}

.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}
.feature{padding:28px;border-radius:18px;background:#fff;border:1px solid var(--card-br);transition:transform .4s var(--ease),border-color .3s,box-shadow .4s;position:relative;overflow:hidden;box-shadow:0 10px 30px -22px rgba(26,20,40,.2)}
.feature:hover{transform:translateY(-4px);border-color:rgba(155,75,208,.35);box-shadow:0 22px 44px -24px rgba(155,75,208,.3)}
.feature .fi{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,rgba(199,125,238,.25),rgba(167,139,250,.22));display:grid;place-items:center;font-size:22px;margin-bottom:16px;border:1px solid rgba(155,75,208,.18)}
.feature h4{font-size:16px;font-weight:700;margin-bottom:8px}
.feature p{font-size:13.5px;color:var(--ink-dim);line-height:1.55}

.model-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}
.model{border-radius:20px;overflow:hidden;background:#fff;border:1px solid var(--card-br);transition:transform .4s var(--ease),border-color .3s,box-shadow .4s;display:flex;flex-direction:column;box-shadow:0 14px 40px -26px rgba(26,20,40,.25)}
.model:hover{transform:translateY(-5px);border-color:rgba(155,75,208,.35);box-shadow:0 28px 56px -26px rgba(155,75,208,.3)}
.model-img{aspect-ratio:16/10;background:var(--surface-2);overflow:hidden;border-bottom:1px solid rgba(26,20,40,.06)}
.model-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.model:hover .model-img img{transform:scale(1.05)}
.model-body{padding:24px}
.model-body .tag{font-size:11px;letter-spacing:2px;color:var(--accent-2);font-weight:700;text-transform:uppercase;display:block;margin-bottom:8px}
.model-body h3{font-size:22px;font-weight:800;margin-bottom:10px;letter-spacing:-.01em}
.model-body p{font-size:14px;color:var(--ink-dim);margin-bottom:14px}
.model-body ul{list-style:none}
.model-body li{font-size:13.5px;color:var(--ink-dim);padding:5px 0 5px 20px;position:relative}
.model-body li::before{content:"";position:absolute;left:0;top:14px;width:10px;height:1.5px;background:linear-gradient(90deg,var(--brand),transparent)}

.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.gi{border-radius:14px;overflow:hidden;background:var(--surface-2);border:1px solid rgba(26,20,40,.08);aspect-ratio:16/10;cursor:zoom-in;transition:transform .4s var(--ease),border-color .3s,box-shadow .4s;position:relative;box-shadow:0 8px 24px -18px rgba(26,20,40,.3)}
.gi img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gi:hover{transform:translateY(-4px);border-color:rgba(155,75,208,.4);box-shadow:0 18px 36px -20px rgba(155,75,208,.35)}
.gi:hover img{transform:scale(1.06)}
.gi .pno{position:absolute;bottom:10px;right:10px;padding:4px 10px;border-radius:999px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);font-size:11px;font-weight:700;color:var(--brand-2);letter-spacing:1px;border:1px solid rgba(155,75,208,.18)}

/* event meta strip */
.event-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:32px}
.em-card{padding:18px 22px;border-radius:16px;background:#fff;border:1px solid var(--card-br);box-shadow:0 10px 24px -18px rgba(26,20,40,.25)}
.em-card .k{font-size:11px;letter-spacing:2px;color:var(--accent-2);font-weight:700;text-transform:uppercase;margin-bottom:6px;display:block}
.em-card .v{font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.01em}

/* event date chip */
.date-chip{display:inline-flex;align-items:center;gap:14px;padding:10px 18px 10px 10px;border-radius:999px;background:#fff;border:1px solid rgba(155,75,208,.2);box-shadow:0 10px 24px -14px rgba(155,75,208,.3);margin-bottom:22px}
.date-chip .d{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,#9b4bd0,#7c3ebf);color:#fff;display:grid;place-items:center;font-weight:800;font-size:16px;line-height:1;text-align:center}
.date-chip .d small{display:block;font-size:9px;letter-spacing:2px;font-weight:700;opacity:.9;margin-top:2px}
.date-chip .lbl{font-size:13px;color:var(--ink-dim);font-weight:500}
.date-chip .lbl b{color:var(--ink);font-weight:700}

/* events — hero video */
.hero-video{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:16/10;border:1px solid rgba(26,20,40,.08);box-shadow:0 40px 80px -30px rgba(26,20,40,.3),0 0 0 1px rgba(155,75,208,.12);background:var(--surface-2)}
.hero-video video{width:100%;height:100%;object-fit:cover;display:block}
.hero-video::after{content:"";position:absolute;inset:0;background:linear-gradient(140deg,transparent 55%,rgba(199,125,238,.1),rgba(167,139,250,.14));pointer-events:none}

/* event feature card */
.ev-card{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:stretch;padding:28px;border-radius:24px;background:#fff;border:1px solid var(--card-br);box-shadow:0 22px 48px -28px rgba(26,20,40,.22);margin-bottom:24px}
.ev-card.reverse{grid-template-columns:.9fr 1.1fr}
.ev-card.reverse .ev-media{order:2}
.ev-card.reverse .ev-body{order:1}
@media (max-width:860px){.ev-card,.ev-card.reverse{grid-template-columns:1fr}.ev-card.reverse .ev-media{order:0}.ev-card.reverse .ev-body{order:0}}
.ev-media{position:relative;display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;gap:8px;min-height:340px}
.ev-media .m0{grid-row:span 2}
.ev-media .tile{border-radius:14px;overflow:hidden;background:var(--surface-2);border:1px solid rgba(26,20,40,.06);position:relative}
.ev-media .tile img,.ev-media .tile video{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--ease)}
.ev-media .tile:hover img,.ev-media .tile:hover video{transform:scale(1.05)}
.ev-media .tile .play{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none}
.ev-media .tile .play span{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--brand-2);display:grid;place-items:center;box-shadow:0 10px 24px -8px rgba(155,75,208,.5);font-size:18px}
.ev-body{display:flex;flex-direction:column;gap:14px;padding:10px 8px}
.ev-body .ev-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.ev-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:rgba(155,75,208,.1);border:1px solid rgba(155,75,208,.2);color:var(--brand-2);font-size:11.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase}
.ev-body h3{font-size:28px;line-height:1.1;letter-spacing:-.01em;font-weight:800}
.ev-body p{color:var(--ink-dim);font-size:15px}
.ev-body ul{list-style:none;margin:4px 0}
.ev-body li{font-size:14px;color:var(--ink);padding:6px 0 6px 24px;position:relative}
.ev-body li::before{content:"";position:absolute;left:0;top:13px;width:14px;height:2px;background:linear-gradient(90deg,var(--brand),transparent);border-radius:2px}
.ev-body .row{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}

/* video grid for events (auto-play silent) */
.ev-videos{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.ev-videos .v{aspect-ratio:9/16;border-radius:18px;overflow:hidden;background:#000;border:1px solid rgba(26,20,40,.08);transition:transform .4s var(--ease),box-shadow .4s;position:relative}
.ev-videos .v video{width:100%;height:100%;object-fit:cover;display:block}
.ev-videos .v:hover{transform:translateY(-4px);box-shadow:0 24px 40px -20px rgba(155,75,208,.35)}
.ev-videos .v .tag{position:absolute;top:12px;left:12px;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.92);color:var(--brand-2);font-size:10.5px;font-weight:800;letter-spacing:2px;text-transform:uppercase;backdrop-filter:blur(8px)}

/* packages */
.pkgs{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.pkg{border-radius:20px;padding:26px;background:#fff;border:1px solid var(--card-br);box-shadow:0 14px 36px -24px rgba(26,20,40,.2);transition:transform .4s var(--ease),box-shadow .4s,border-color .3s;position:relative;overflow:hidden}
.pkg:hover{transform:translateY(-5px);box-shadow:0 28px 52px -26px rgba(155,75,208,.3);border-color:rgba(155,75,208,.35)}
.pkg.featured{background:linear-gradient(180deg,rgba(199,125,238,.16),rgba(167,139,250,.12));border-color:rgba(155,75,208,.3)}
.pkg.featured::before{content:"Most popular";position:absolute;top:16px;right:16px;padding:4px 10px;border-radius:999px;background:linear-gradient(135deg,#9b4bd0,#7c3ebf);color:#fff;font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase}
.pkg .pk-title{font-size:12px;letter-spacing:2.5px;color:var(--brand-2);font-weight:800;text-transform:uppercase;margin-bottom:10px}
.pkg .pk-name{font-size:22px;font-weight:800;letter-spacing:-.01em;margin-bottom:6px}
.pkg .pk-when{font-size:13px;color:var(--ink-dim);margin-bottom:16px}
.pkg ul{list-style:none}
.pkg li{font-size:13.5px;color:var(--ink);padding:6px 0 6px 22px;position:relative}
.pkg li::before{content:"✓";position:absolute;left:0;top:6px;color:var(--brand);font-weight:800}

/* testimonials */
.quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}
.quote{padding:26px;border-radius:20px;background:#fff;border:1px solid var(--card-br);box-shadow:0 14px 36px -24px rgba(26,20,40,.2);position:relative}
.quote::before{content:"\201C";position:absolute;top:-18px;left:20px;font-size:100px;line-height:1;color:var(--brand-soft);font-family:Georgia,serif;opacity:.6}
.quote p{font-size:15px;line-height:1.7;color:var(--ink);position:relative}
.quote .who{margin-top:14px;font-size:13px;color:var(--ink-dim)}
.quote .who b{color:var(--ink);font-weight:700;margin-right:6px}

/* event teaser strip */
.event-teaser{overflow:hidden;margin:10px 0 40px;padding:14px 0;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);position:relative}
.event-teaser-track{display:flex;gap:14px;width:max-content;animation:teaserScroll 55s linear infinite}
.event-teaser:hover .event-teaser-track{animation-play-state:paused}
.event-teaser .tt{flex:0 0 auto;width:220px;aspect-ratio:3/2;border-radius:14px;overflow:hidden;border:1px solid rgba(26,20,40,.08);background:var(--surface-2);box-shadow:0 10px 24px -18px rgba(26,20,40,.25);transition:transform .4s var(--ease),box-shadow .4s}
.event-teaser .tt img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.event-teaser .tt:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 22px 40px -20px rgba(155,75,208,.35)}
.event-teaser .tt:hover img{transform:scale(1.08)}
@keyframes teaserScroll{to{transform:translateX(-50%)}}

/* event gallery — fancy masonry */
.event-gallery{columns:3 260px;column-gap:14px}
@media (max-width:900px){.event-gallery{columns:2 180px}}
@media (max-width:500px){.event-gallery{columns:1}}
.event-gallery .eg{break-inside:avoid;margin:0 0 14px;border-radius:16px;overflow:hidden;background:var(--surface-2);border:1px solid rgba(26,20,40,.06);cursor:zoom-in;display:block;position:relative;isolation:isolate;opacity:0;transform:translateY(28px) scale(.96) rotate(var(--r,0deg));transition:opacity .7s var(--ease),transform .7s var(--ease),box-shadow .5s var(--ease),border-color .3s;transition-delay:var(--d,0ms)}
.event-gallery .eg.in{opacity:1;transform:translateY(0) scale(1) rotate(0)}
.event-gallery .eg::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 48%,rgba(26,20,40,.78) 100%);opacity:0;transition:opacity .4s var(--ease);pointer-events:none;z-index:1}
.event-gallery .eg::after{content:"";position:absolute;inset:0;border-radius:16px;padding:1.5px;background:linear-gradient(135deg,rgba(199,125,238,.8),rgba(124,62,191,.5),rgba(199,125,238,.8));-webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s var(--ease);pointer-events:none;z-index:2}
.event-gallery .eg:hover{transform:translateY(-8px) scale(1.02) !important;box-shadow:0 30px 56px -26px rgba(155,75,208,.5);z-index:3;border-color:transparent}
.event-gallery .eg:hover::before,.event-gallery .eg:hover::after{opacity:1}
.event-gallery .eg img{width:100%;display:block;transition:transform .9s var(--ease),filter .5s}
.event-gallery .eg:hover img{transform:scale(1.08);filter:saturate(1.08)}
.eg-caption{position:absolute;left:14px;right:14px;bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:10px;z-index:4;opacity:0;transform:translateY(8px);transition:opacity .4s var(--ease),transform .45s var(--ease);pointer-events:none}
.event-gallery .eg:hover .eg-caption{opacity:1;transform:none}
.eg-num{font-size:10.5px;font-weight:800;letter-spacing:2px;padding:6px 11px;border-radius:999px;background:rgba(255,255,255,.18);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.28);color:#fff;text-transform:uppercase}
.eg-view{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:7px 13px;border-radius:999px;background:rgba(255,255,255,.96);color:var(--brand-2);box-shadow:0 6px 16px -6px rgba(155,75,208,.5)}
.eg-view svg{width:12px;height:12px}
.event-gallery .eg:nth-child(4n+1){--r:-.5deg}
.event-gallery .eg:nth-child(4n+2){--r:.4deg}
.event-gallery .eg:nth-child(4n+3){--r:-.3deg}

.load-more{display:flex;justify-content:center;margin-top:30px}

/* video showcase */
.video-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:22px}
.vcard{border-radius:18px;overflow:hidden;background:#fff;border:1px solid var(--card-br);transition:transform .4s var(--ease),border-color .3s,box-shadow .4s;box-shadow:0 14px 36px -22px rgba(26,20,40,.22)}
.vcard:hover{transform:translateY(-4px);border-color:rgba(155,75,208,.35);box-shadow:0 26px 50px -24px rgba(155,75,208,.3)}
.vcard video{width:100%;aspect-ratio:9/16;object-fit:cover;background:#000;display:block}
.vcard-body{padding:18px 20px}
.vcard-body .tag{font-size:11px;letter-spacing:2px;color:var(--accent-2);font-weight:700;text-transform:uppercase;display:block;margin-bottom:6px}
.vcard-body h4{font-size:17px;font-weight:700;margin-bottom:4px}
.vcard-body p{font-size:13.5px;color:var(--ink-dim)}

/* pill list for arena */
.pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.pill{padding:8px 16px;border-radius:999px;background:#fff;border:1px solid rgba(26,20,40,.1);font-size:13px;color:var(--ink-dim);box-shadow:0 4px 12px -8px rgba(26,20,40,.18)}
.pill b{color:var(--ink);font-weight:700}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(26,20,40,.78);backdrop-filter:blur(14px);display:none;align-items:center;justify-content:center;z-index:100;padding:30px}
.lb.open{display:flex}
.lb img{max-width:95vw;max-height:90vh;object-fit:contain;border-radius:10px;box-shadow:0 40px 80px rgba(26,20,40,.5)}
.lb-close{position:absolute;top:24px;right:24px;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.95);border:1px solid rgba(26,20,40,.1);display:grid;place-items:center;color:var(--ink);font-size:22px}
.lb-close:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.95);border:1px solid rgba(26,20,40,.1);display:grid;place-items:center;color:var(--ink)}
.lb-nav:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.lb-nav.prev{left:24px}.lb-nav.next{right:24px}
.lb-nav svg{width:22px;height:22px}

.secondary-cta{display:flex;gap:12px;justify-content:center;margin-top:24px;flex-wrap:wrap}

@media (max-width:820px){
  .hero-split{grid-template-columns:1fr;padding:40px 24px}
  .hero-visual{order:-1}
}

/* responsive */
@media (max-width:820px){
  .nav-links{display:none}
  .menu-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:999px;background:#fff;border:1px solid rgba(26,20,40,.1);color:var(--ink);box-shadow:0 4px 12px -6px rgba(26,20,40,.2)}
  .nav{padding:0 14px}
  .nav-inner{padding:6px 6px 6px 14px}
  .nav-links.open{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;background:rgba(255,255,255,.98);-webkit-backdrop-filter:saturate(180%) blur(22px);backdrop-filter:saturate(180%) blur(22px);padding:16px;border-radius:22px;border:1px solid rgba(26,20,40,.08);gap:4px;align-items:stretch;box-shadow:0 24px 50px -20px rgba(26,20,40,.25)}
  .nav-links.open a:not(.btn){padding:12px 16px;border-radius:14px;font-size:15px}
  .nav-links.open .btn{margin-top:6px;justify-content:center}
  .hero{padding:60px 24px 40px}
  .section{padding:70px 24px}
  .cat{min-height:460px}
  .thumb{flex:0 0 80px}
  .nav-arrow{width:44px;height:44px}
  .book{aspect-ratio:4/5}
}
