: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}
}

/* ===================================================================
   EDITORIAL RESKIN — match cmsexpertdev (dark · Anton display · purple)
   Appended override layer; delete this whole block to revert.
   =================================================================== */
:root{
  --bg:#14141C;            /* ink */
  --bg-2:#1F1F2A;          /* graphite */
  --surface:#1B1B25;       /* onyx */
  --surface-2:#23232E;     /* stone-ish */
  --ink:#ECE9E2;           /* bone — light text */
  --ink-dim:#9A9AA4;       /* fog — dim text */
  --brand:#CB6CE6;         /* brand purple */
  --brand-2:#C98BEA;       /* lighter purple for text on dark */
  --brand-soft:#B594FF;    /* lavender */
  --accent:#CB6CE6;
  --accent-2:#C98BEA;
  --accent-3:#B594FF;
  --card:rgba(232,229,222,.045);
  --card-br:rgba(232,229,222,.12);
  --line:rgba(232,229,222,.12);
  --glow:0 30px 80px -30px rgba(203,108,230,.5);
  --font-display:'Anton','Inter','Segoe UI',system-ui,sans-serif;
}

/* ambient background — dark with aurora glows */
.bg-stage{background:
  radial-gradient(1100px 600px at 12% -8%,rgba(203,108,230,.16),transparent 60%),
  radial-gradient(900px 520px at 88% 4%,rgba(78,205,196,.07),transparent 60%),
  radial-gradient(1000px 700px at 50% 120%,rgba(181,148,255,.12),transparent 60%),
  linear-gradient(180deg,#14141C 0%,#17171F 55%,#1B1B25 100%);}
.bg-grid{background-image:
  linear-gradient(rgba(232,229,222,.05) 1px,transparent 1px),
  linear-gradient(90deg,rgba(232,229,222,.05) 1px,transparent 1px);}
.blob{opacity:.42;filter:blur(85px)}
.blob.b1{background:#CB6CE6}
.blob.b2{background:#B594FF}
.blob.b3{background:#FF6B47}

/* display type — Anton, uppercase, poster scale */
.hero h1,.hero-split h1{font-family:var(--font-display);font-weight:400;text-transform:uppercase;letter-spacing:.01em;line-height:.94}
.hero h1{font-size:clamp(54px,9vw,128px)}
.hero-split h1{font-size:clamp(42px,6vw,84px)}
.section-head h2,.cta-card h2{font-family:var(--font-display);font-weight:400;text-transform:uppercase;letter-spacing:.012em;line-height:1}
.section-head h2{font-size:clamp(34px,5vw,64px)}
.hero h1 .grad,.section-head h2 .grad{background:linear-gradient(135deg,#CB6CE6,#B594FF);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .num{background:linear-gradient(135deg,#CB6CE6,#B594FF);-webkit-background-clip:text;background-clip:text;color:transparent}

/* nav — dark glass, uppercase */
.nav-inner{background:rgba(20,20,28,.72);border-color:var(--line);box-shadow:0 18px 40px -22px rgba(0,0,0,.65),0 1px 0 rgba(255,255,255,.04) inset}
.nav-links a:not(.btn){color:var(--ink-dim);text-transform:uppercase;letter-spacing:.1em;font-size:12.5px;font-weight:600}
.nav-links a:not(.btn):hover{color:#fff;background:rgba(203,108,230,.14)}
.nav-links a.active{color:#fff;background:rgba(203,108,230,.18)}
.brand-tag{color:var(--ink-dim)}
.brand-logo{filter:brightness(0) invert(1) drop-shadow(0 6px 14px rgba(203,108,230,.35))}
.brand-sep{background:linear-gradient(180deg,transparent,rgba(232,229,222,.3),transparent)}
.menu-btn{background:rgba(232,229,222,.06);border-color:var(--line);color:var(--ink)}
.nav-links.open{background:rgba(20,20,28,.97);border-color:var(--line)}

/* buttons — pill, uppercase, arrow on primary */
.btn{text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-size:12.5px}
.btn-primary{background:linear-gradient(135deg,#CB6CE6,#B594FF);color:#14141C;box-shadow:0 12px 30px -12px rgba(203,108,230,.6)}
.btn-primary:hover{box-shadow:0 22px 46px -14px rgba(203,108,230,.8)}
.btn-ghost{background:rgba(232,229,222,.05);border:1px solid var(--line);color:var(--ink);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(232,229,222,.1);border-color:rgba(203,108,230,.45)}
.btn::after{content:"\2197";font-size:1.05em;line-height:1;margin-left:1px;transition:transform .3s var(--ease)}
.btn:hover::after{transform:translate(2px,-2px)}

/* surfaces — dark glass panels */
.m-item,.cat,.prod,.feature,.model,.em-card,.date-chip,.pkg,.quote,.vcard,.pill,.counter,.ev-card,.stats{
  background:var(--card);border-color:var(--line);
  box-shadow:0 24px 60px -34px rgba(0,0,0,.7)}
.cat:hover,.prod:hover,.feature:hover,.model:hover,.pkg:hover,.vcard:hover{border-color:rgba(203,108,230,.4)}
.cat-cover,.model-img,.gi,.hero-visual,.hero-video,.ev-media .tile,.event-teaser .tt,.event-gallery .eg{background:var(--surface-2);border-color:var(--line)}

/* light chips on dark */
.cat-badge,.cat-pages,.hero-badge{background:rgba(20,20,28,.62);border-color:var(--line);color:var(--ink);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
.gi .pno{background:rgba(20,20,28,.66);border-color:var(--line);color:var(--brand-2)}

/* circular controls — dark glass */
.nav-arrow,.lb-close,.lb-nav{background:rgba(20,20,28,.72);border-color:var(--line);color:var(--ink);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}
.nav-arrow:hover,.lb-close:hover,.lb-nav:hover{background:var(--brand);color:#14141C;border-color:var(--brand)}

/* misc dark fixes */
footer{border-top-color:var(--line)}
.eyebrow{background:rgba(203,108,230,.12);border-color:rgba(203,108,230,.28);color:var(--brand-2)}
.lb{background:rgba(8,8,12,.86)}
.pkg.featured{background:linear-gradient(180deg,rgba(203,108,230,.16),rgba(181,148,255,.08));border-color:rgba(203,108,230,.32)}
.pkg.featured::before{background:linear-gradient(135deg,#CB6CE6,#B594FF);color:#14141C}
.marquee .m-item{font-weight:600}

/* ---- pushed further toward cmsexpertdev ---- */

/* big-type marquee — industries as a poster ticker with ✦ separators */
.marquee{padding:30px 0;margin-top:50px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(232,229,222,.02)}
.marquee-track{gap:0}
.marquee .m-item{background:transparent;border:0;box-shadow:none;padding:0;display:inline-flex;align-items:center;gap:0;font-family:var(--font-display);font-weight:400;text-transform:uppercase;font-size:clamp(26px,3.6vw,50px);letter-spacing:.015em;line-height:1;color:var(--ink);opacity:.92}
.marquee .m-item::after{content:"\2726";display:inline-block;margin:0 clamp(20px,2.4vw,40px);font-size:.34em;color:var(--brand);-webkit-text-fill-color:var(--brand);transform:translateY(-.12em)}

/* hero geometric accents (homepage hero only) */
.hero{z-index:0}
.hero::before{content:"";position:absolute;z-index:-1;top:96px;left:10px;width:clamp(140px,17vw,250px);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle at 34% 30%,#FF8A68,#FF6B47);opacity:.92}
.hero::after{content:"";position:absolute;z-index:-1;top:130px;right:7%;width:clamp(84px,8.5vw,132px);aspect-ratio:1;background:linear-gradient(135deg,#C2A6FF,#9A74F0);transform:rotate(45deg);border-radius:16px;box-shadow:0 30px 60px -20px rgba(181,148,255,.5)}
@media (max-width:820px){.hero::after{display:none}.hero::before{opacity:.7}}

/* alternating "paper" light sections — re-scopes the design tokens */
.section--paper{position:relative;z-index:0;color:var(--ink);
  --ink:#14141C;--ink-dim:#56565E;--card:#FFFFFF;--card-br:rgba(20,20,28,.10);--line:rgba(20,20,28,.10);--brand-2:#A655BC;--accent-2:#A655BC}
.section--paper::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:100vw;height:100%;background:#F4F2EE;z-index:-1}
.section--paper .prod,.section--paper .pkg,.section--paper .feature,.section--paper .cat,.section--paper .model,.section--paper .quote,.section--paper .vcard,.section--paper .em-card{box-shadow:0 20px 44px -30px rgba(20,20,28,.3)}

/* ---- round 2: full-bleed marquee, calmer speed, richer hero accents ---- */

/* full-bleed (edge-to-edge) marquee — body has overflow-x:hidden so 100vw is safe */
.marquee{width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.marquee-track{animation-duration:60s}
@media (max-width:600px){.marquee-track{animation-duration:38s}.marquee .m-item::after{margin:0 22px}}

/* hero accents — soften circle, add an outline ring + glowing dot */
.hero::before{opacity:.82}
.hero-deco{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.hero-deco .ring{position:absolute;right:7%;top:46%;width:clamp(120px,12vw,188px);aspect-ratio:1;border-radius:50%;border:1.5px solid rgba(181,148,255,.5)}
.hero-deco .dot{position:absolute;left:47%;top:63%;width:12px;height:12px;border-radius:50%;background:var(--brand);box-shadow:0 0 24px var(--brand)}
@media (max-width:820px){.hero-deco .ring{right:4%;top:auto;bottom:7%;width:120px}.hero-deco .dot{display:none}}

/* paper sections: also lighten image/placeholder surface */
.section--paper{--surface-2:#ECE9E2}

/* ---- product family: category groups, image-led cards, detail pages ---- */
.cat-group{margin-top:48px}
.cat-group:first-of-type{margin-top:8px}
.cat-group-head{display:flex;align-items:baseline;gap:14px;margin-bottom:22px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.cat-group-head h3{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.01em;font-size:clamp(22px,2.6vw,32px);line-height:1}
.cat-count{color:var(--ink-dim);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}

.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(236px,1fr));gap:22px}
.prod-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--card-br);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:var(--ink);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.prod-card:hover{transform:translateY(-6px);box-shadow:var(--glow);border-color:var(--brand-soft)}
.prod-card-img{position:relative;aspect-ratio:4/5;background:var(--surface-2);display:grid;place-items:center;overflow:hidden}
.prod-card-img img{width:100%;height:100%;object-fit:contain;padding:14px}
.prod-ph{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--ink-dim)}
.prod-ph span{font-size:52px;line-height:1}
.prod-ph small{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase}
.avail-badge{position:absolute;top:12px;left:12px;background:rgba(20,20,28,.72);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:5px 10px;border-radius:999px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.prod-card-body{padding:15px 18px 20px;display:flex;flex-direction:column;gap:6px;flex:1}
.prod-card-body h4{font-size:16.5px;font-weight:800;letter-spacing:-.01em}
.prod-card-body p{color:var(--ink-dim);font-size:13px;line-height:1.5;flex:1}
.prod-card-link{color:var(--brand-2);font-weight:700;font-size:12.5px;letter-spacing:.02em;margin-top:6px}
.prod-card:hover .prod-card-link{color:var(--brand)}

/* product detail */
.product-hero .product-shot{aspect-ratio:4/5;display:grid;place-items:center;background:var(--surface-2);overflow:hidden;border:1px solid var(--card-br)}
.product-hero .product-shot img{width:100%;height:100%;object-fit:contain;padding:22px}
.prod-badges{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:16px 0 20px}
.prod-badges .avail-badge{position:static;background:linear-gradient(135deg,var(--brand),var(--brand-2))}
.price-badge{border:1px solid var(--card-br);color:var(--ink-dim);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:6px 12px;border-radius:999px}
.spec-table{max-width:760px;margin:0 auto;border:1px solid var(--card-br);border-radius:16px;overflow:hidden}
.spec-row{display:grid;grid-template-columns:minmax(140px,34%) 1fr;gap:16px;padding:13px 20px}
.spec-row:nth-child(odd){background:var(--surface-2)}
.spec-k{color:var(--ink-dim);font-weight:600;font-size:13.5px}
.spec-v{font-weight:600}
.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;max-width:1000px;margin:0 auto}
.info-card{background:var(--card);border:1px solid var(--card-br);border-radius:var(--radius);padding:24px 26px}
.info-card p{color:var(--ink-dim);margin-top:8px;line-height:1.7}
@media (max-width:600px){.spec-row{grid-template-columns:1fr;gap:2px}}

/* ---- enquiry / lead form ---- */
.enquire-card{background:var(--card);border:1px solid var(--card-br);border-radius:var(--radius);padding:26px 26px 30px;box-shadow:var(--glow)}
.enquire-head{margin-bottom:18px}
.enquire-head .eyebrow{position:relative}
.enquire-head h3{font-size:22px;font-weight:800;margin-top:10px;letter-spacing:-.01em}
.enquire-form .hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.ef-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.ef-field{display:flex;flex-direction:column;gap:7px;font-size:11.5px;font-weight:700;letter-spacing:.06em;color:var(--ink-dim);text-transform:uppercase}
.ef-field span{color:var(--brand)}
.ef-field input,.ef-field textarea{font:inherit;text-transform:none;letter-spacing:0;font-weight:500;color:var(--ink);background:var(--surface-2);border:1px solid var(--card-br);border-radius:12px;padding:11px 13px;width:100%;transition:border-color .2s,box-shadow .2s}
.ef-field input:focus,.ef-field textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(155,75,208,.18)}
.ef-field textarea{resize:vertical;min-height:104px}
.enquire-form .btn{margin-top:18px}
.ef-fine{margin-top:12px;font-size:11.5px;color:var(--ink-dim)}
.enquire-note h3{font-size:22px;font-weight:800;color:var(--ink)}
.enquire-note p{color:var(--ink-dim);margin-top:6px}
.enquire-err{border-left:3px solid var(--brand);padding-left:14px;margin-bottom:16px}
@media(max-width:560px){.ef-grid{grid-template-columns:1fr}}

/* ---- breadcrumbs ---- */
.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:18px}
.crumbs a{color:var(--ink-dim);transition:color .2s}
.crumbs a:hover{color:var(--brand-2)}
.crumbs i{opacity:.4;font-style:normal}
.crumbs span[aria-current]{color:var(--ink)}
.cat-group-head h3 a{color:inherit;text-decoration:none;transition:color .2s}
.cat-group-head h3 a:hover{color:var(--brand-2)}

/* ---- nav fit + accessibility + polish ---- */
.nav-links a{white-space:nowrap}
.skip-link{position:absolute;left:-9999px;top:0;z-index:100000;background:var(--brand);color:#fff;padding:10px 16px;border-radius:0 0 12px 0;font-weight:700;text-decoration:none}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:4px}
main:focus{outline:none}
.wa-float{position:fixed;right:18px;bottom:18px;z-index:9000;display:inline-flex;align-items:center;gap:9px;background:#25D366;color:#06311a;font-weight:800;font-size:14px;padding:12px 16px;border-radius:999px;box-shadow:0 14px 34px -10px rgba(0,0,0,.5);text-decoration:none;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.wa-float:hover{transform:translateY(-3px);box-shadow:0 18px 40px -10px rgba(37,211,102,.5)}
.wa-float svg{width:20px;height:20px;fill:currentColor;flex:none}
.wa-float span{white-space:nowrap}
@media(max-width:560px){.wa-float span{display:none}.wa-float{padding:13px;border-radius:50%}}
.err404{min-height:54vh;display:grid;place-items:center;text-align:center;padding:130px 24px 70px}
.err404 .big{font-family:var(--font-display,'Anton',sans-serif);font-weight:400;font-size:clamp(84px,18vw,190px);line-height:.9;background:linear-gradient(135deg,#fff,#CB6CE6);-webkit-background-clip:text;background-clip:text;color:transparent}
.err404 p{color:var(--ink-dim);margin:14px 0 24px;max-width:460px}

/* ---- nav dropdown ---- */
.nav-item{position:relative;display:inline-flex;align-items:center}
.nav-sub-toggle{display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.nav-caret{transition:transform .25s var(--ease);opacity:.7}
.nav-sub{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);display:flex;gap:26px;padding:20px 24px;background:rgba(22,22,30,.97);-webkit-backdrop-filter:saturate(180%) blur(22px);backdrop-filter:saturate(180%) blur(22px);border:1px solid var(--card-br);border-radius:18px;box-shadow:0 30px 80px -28px rgba(0,0,0,.72);opacity:0;visibility:hidden;transition:opacity .25s var(--ease),transform .25s var(--ease);z-index:70}
.nav-sub::before{content:"";position:absolute;top:-10px;left:0;right:0;height:12px}
.nav-item:hover .nav-sub,.nav-item:focus-within .nav-sub{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-item:hover .nav-caret,.nav-item:focus-within .nav-caret{transform:rotate(180deg)}
.nav-sub-col{display:flex;flex-direction:column;gap:3px;min-width:172px}
.nav-sub-label{font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-dim);font-weight:700;margin-bottom:7px;opacity:.85}
.nav-sub a{display:block;padding:8px 11px;border-radius:10px;font-size:14px;font-weight:500;color:var(--ink);white-space:nowrap;transition:background .2s,color .2s}
.nav-sub a:hover{background:var(--surface-2);color:var(--brand-2)}
@media(max-width:820px){
	.nav-item{display:block;width:100%}
	.nav-sub-toggle{justify-content:space-between;width:100%}
	.nav-sub{position:static;transform:none;opacity:1;visibility:visible;display:none;flex-direction:column;gap:16px;margin:6px 0;padding:4px 0 4px 14px;background:transparent;border:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:0;border-left:1px solid var(--line)}
	.nav-sub::before{display:none}
	.nav-item.open .nav-sub{display:flex}
	.nav-item.open .nav-caret{transform:rotate(180deg)}
	.nav-sub-col{min-width:0;gap:2px}
}

/* ---- catalog: comparison tables, applications, contained hero ---- */
.priz-richbody{max-width:none;padding:0}
.priz-richbody .section{padding-top:48px;padding-bottom:48px}
.spec-compare{max-width:980px;margin:0 auto;border:1px solid var(--card-br);border-radius:16px;overflow-x:auto}
.spec-compare table{width:100%;border-collapse:collapse;min-width:600px}
.spec-compare th,.spec-compare td{padding:12px 16px;text-align:left;font-size:13.5px;border-bottom:1px solid var(--card-br);white-space:nowrap}
.spec-compare thead th{background:var(--surface-2);font-weight:800;letter-spacing:.02em;color:var(--ink)}
.spec-compare tbody th{font-weight:700;color:var(--ink)}
.spec-compare tbody td{color:var(--ink-dim);font-weight:600}
.spec-compare tbody tr:nth-child(even){background:var(--surface-2)}
.spec-compare tr:last-child th,.spec-compare tr:last-child td{border-bottom:0}
.applist{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:860px;margin:0 auto}
.apill{border:1px solid var(--card-br);background:var(--card);color:var(--ink-dim);font-weight:600;font-size:13.5px;padding:9px 16px;border-radius:999px}
.specs-note{max-width:820px;margin:20px auto 0;text-align:center;color:var(--ink-dim);font-size:14px;line-height:1.7}
.specs-note strong{color:var(--ink)}
.hero-visual--contain{background:var(--surface-2)}
.hero-visual--contain img{object-fit:contain;padding:32px}
.cat-cover--contain img{object-fit:contain;padding:22px}
.cat-cover--contain::after{display:none}

/* ---- mobile polish (audit fixes) ---- */
.spec-hint{display:none;text-align:right;font-style:italic;font-size:11.5px;color:var(--ink-dim);max-width:980px;margin:7px auto 0;padding:0 2px}
@media (max-width:820px){
	.hero::before{display:none} /* coral circle overlapped the mobile headline */
}
@media (max-width:620px){
	.spec-hint{display:block}
	.spec-compare th,.spec-compare td{padding:10px 12px;font-size:13px}
}
/* Mobile nav: backdrop-filter on .nav-inner broke the open menu's solid-bg paint
   (Chromium bug — absolutely-positioned child of a backdrop-filtered element).
   Drop the blur on mobile and use a solid bar so the dropdown panel renders. */
@media (max-width:820px){
	.nav-inner{-webkit-backdrop-filter:none;backdrop-filter:none;background:#16161d}
	.nav-links.open{-webkit-backdrop-filter:none;backdrop-filter:none;background:#1c1c26;max-height:calc(100vh - 100px);overflow-y:auto;overscroll-behavior:contain}
	/* Tapping the toggle focuses it → :focus-within re-applied the desktop translateX(-50%),
	   shoving the accordion off-screen. Reset every desktop-positioning transform on mobile. */
	.nav-sub,.nav-item:hover .nav-sub,.nav-item:focus-within .nav-sub,.nav-item.open .nav-sub{transform:none}
}

