/* Vivid Displays — dark, premium, vivid-LED identity (gpt-image-2 direction) */
:root{
  --bg:#0a0a0f;--bg-2:#121219;--panel:#15151f;--panel-2:#1c1c28;--line:#262633;
  --ink:#f4f4f8;--ink-dim:#a3a3b5;--ink-mute:#6f6f85;
  /* brand spectrum sampled from the Vivid Displays logo: red -> magenta -> purple -> blue */
  --red:#fb1450;--magenta:#ed19a6;--orange:#ff5c9a;--pink:#ff5c9a;--purple:#b023f0;--blue:#1f5cff;--cyan:#22d3ee;
  --grad:linear-gradient(110deg,#fb1450 0%,#e51ba6 36%,#a833f0 64%,#1f5cff 100%);
  --grad-text:linear-gradient(100deg,#ff516f,#ef47b0,#b66bf5,#4f8cff);
  --radius:16px;--maxw:1300px;
  --shadow:0 10px 40px rgba(0,0,0,.45);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,-apple-system,Roboto,sans-serif;background:var(--bg);
  color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--ink);text-decoration:none}a:hover{color:#fff}
h1,h2,h3,h4{line-height:1.08;font-weight:900;letter-spacing:-.01em}
html{overflow-x:clip}   /* kill phantom horizontal scroll from the absolutely-positioned mega dropdown */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.grad{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(10,10,15,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:inline-flex;align-items:center;line-height:1}
.logo-wrap{position:relative;display:inline-block}
.brand img.logo{height:40px;width:auto;display:block;animation:logo-glow 3.6s ease-in-out infinite}
.foot .brand img.logo{height:46px}
/* breathing neon glow in the brand colors (magenta + blue) */
@keyframes logo-glow{
  0%,100%{filter:drop-shadow(0 0 4px rgba(237,25,166,.40)) drop-shadow(0 0 11px rgba(31,92,255,.22))}
  50%{filter:drop-shadow(0 0 8px rgba(237,25,166,.72)) drop-shadow(0 0 20px rgba(31,92,255,.46))}
}
/* chrome shine sweeping across the wordmark, masked to the logo shape */
.logo-wrap::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(110deg,transparent 38%,rgba(255,255,255,.9) 50%,transparent 62%);
  background-size:260% 100%;background-repeat:no-repeat;
  -webkit-mask:url(/static/img/logo.webp) left center/contain no-repeat;
          mask:url(/static/img/logo.webp) left center/contain no-repeat;
  animation:logo-shine 5s ease-in-out infinite}
@keyframes logo-shine{0%{background-position:170% 0}55%,100%{background-position:-70% 0}}
@media(prefers-reduced-motion:reduce){.brand img.logo,.logo-wrap::after{animation:none}}
.brand .v{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-size:1.25rem}
.brand small{font-size:.6rem;letter-spacing:.42em;color:var(--ink-mute);font-weight:700;margin-top:2px}
.nav-links{display:flex;gap:22px;align-items:center}
.nav-links a{color:var(--ink-dim);font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase}
.nav-links a:hover{color:#fff}
.nav-cta{border:1.5px solid var(--orange);color:#ff9ec4!important;padding:9px 18px;border-radius:9px;letter-spacing:.06em}
.nav-cta:hover{background:var(--orange);color:#160a04!important}
.nav-burger{display:none;background:none;border:0;color:#fff;cursor:pointer;padding:6px;line-height:0;margin-left:auto}
.nav-burger .i-close{display:none}
#nav.open .nav-burger .i-open{display:none}
#nav.open .nav-burger .i-close{display:inline}
@media(max-width:900px){
  .nav-burger{display:inline-flex;align-items:center}
  .nav .wrap{flex-wrap:wrap}
  .nav-links{display:none;flex-basis:100%;width:100%;flex-direction:column;align-items:stretch;gap:0;margin-top:6px}
  #nav.open .nav-links{display:flex}
  #nav.open .nav-links>a,#nav.open .nav-group>.nav-top{display:block;padding:14px 4px;border-top:1px solid var(--line);text-transform:uppercase;font-weight:700;letter-spacing:.04em}
  #nav.open .nav-cta{display:block;text-align:center;margin:12px 0 4px;color:#ff9ec4!important;border:1.5px solid var(--orange)}
  #nav.open .nav-group{display:block;width:100%}
  #nav.open .nav-group .nav-top svg{display:inline}
}

/* hero */
.hero{display:grid;grid-template-columns:1.02fr .98fr;gap:38px;align-items:center;padding:54px 0 34px}
.hero .eyebrow{color:var(--orange)}
.hero h1{font-size:clamp(2.3rem,5.2vw,3.7rem);text-transform:uppercase;margin:8px 0 16px}
.hero .sub{font-size:1.1rem;color:var(--ink-dim);max-width:48ch;margin-bottom:22px}
.cta-row{display:flex;gap:13px;flex-wrap:wrap}
.chips{display:flex;gap:18px;flex-wrap:wrap;margin-top:22px;color:var(--ink-dim);font-size:.82rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.chips span{display:inline-flex;align-items:center;gap:7px}.chips svg{width:16px;height:16px;color:var(--magenta)}
.hero-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);min-height:320px;
  background:#15151f center/cover}
.hero-img img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:900px){.hero{grid-template-columns:1fr;padding:34px 0 20px}.hero-img{min-height:240px}}

/* full-bleed homepage hero (panoramic image bleeds behind the nav, text overlaid left) */
.hero-full{position:relative;background:#0a0a0f center/cover;border-bottom:1px solid var(--line)}
.hero-full::before{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(10,10,15,.94) 0%,rgba(10,10,15,.78) 40%,rgba(10,10,15,.30) 78%,rgba(10,10,15,.12) 100%)}
.hero-full-inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:88px 22px 74px}
.hero-full .hero-text{max-width:820px}
.hero-full h1{font-size:clamp(2.5rem,5.6vw,4.15rem);text-transform:uppercase;margin:10px 0 16px;text-shadow:0 2px 24px rgba(0,0,0,.5)}
.hero-full .sub{font-size:1.12rem;color:#cfd0de;max-width:50ch;margin-bottom:24px}
@media(max-width:760px){.hero-full-inner{padding:54px 22px 44px}.hero-full::before{background:linear-gradient(90deg,rgba(10,10,15,.92),rgba(10,10,15,.74))}}

.eyebrow{display:inline-block;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:800;color:var(--orange)}

.btn{display:inline-flex;align-items:center;gap:9px;padding:13px 24px;border-radius:11px;font-weight:800;cursor:pointer;
  border:none;font-size:.95rem;letter-spacing:.03em;text-transform:uppercase}
.btn svg{width:18px;height:18px}
.btn-grad{background:var(--grad);color:#fff;box-shadow:0 8px 24px rgba(236,72,153,.3)}
.btn-grad:hover{filter:brightness(1.08);color:#fff}
.btn-dark{background:var(--panel-2);border:1px solid var(--line);color:var(--ink)}.btn-dark:hover{border-color:var(--orange);color:#fff}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}.btn-ghost:hover{border-color:var(--magenta);color:#fff}

/* sections */
section.block{padding:46px 0;border-top:1px solid var(--line)}
.section-head{margin-bottom:26px}
.section-head h2{font-size:clamp(1.6rem,3.6vw,2.4rem);text-transform:uppercase;margin:6px 0 6px}
.lead{color:var(--ink-dim);max-width:62ch}
.center{text-align:center}.center .lead{margin:0 auto}

.grid{display:grid;gap:18px}.grid>*{min-width:0}.cols-2{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

/* service cards (image + body) */
.svc{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;
  transition:transform .2s,border-color .2s;color:inherit}
.svc:hover{transform:translateY(-4px);border-color:var(--magenta)}
.svc .thumb{position:relative;aspect-ratio:16/10;background:#1c1c28 center/cover;border-bottom:1px solid var(--line)}
.svc .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.svc .badge{position:absolute;top:12px;left:12px;width:42px;height:42px;border-radius:50%;
  border:2px solid rgba(255,255,255,.5);background:rgba(10,10,15,.5);backdrop-filter:blur(5px);
  display:flex;align-items:center;justify-content:center;color:#fff}
.svc .badge svg{width:20px;height:20px}
.svc .thumb .tag-pill{position:absolute;top:10px;left:10px;z-index:1;background:rgba(10,10,15,.72);backdrop-filter:blur(4px)}
.svc .body{padding:18px 18px 20px}
.svc h3{font-size:1.06rem;text-transform:uppercase;margin-bottom:6px;letter-spacing:.02em}
.svc p{color:var(--ink-dim);font-size:.9rem;margin-bottom:12px}
.more{display:inline-flex;align-items:center;gap:6px;color:var(--orange);font-weight:800;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase}
.more:hover{color:#ff9ec4}.more svg{width:14px;height:14px;flex:none}
/* Safety baseline: any inline icon defaults to a sane size so a missing scoped rule can never balloon it. */
svg{flex:none;vertical-align:middle}
svg:not([width]){width:18px;height:18px}

/* portfolio */
.pf{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
@media(max-width:1100px){.pf{grid-template-columns:repeat(3,1fr)}}
@media(max-width:620px){.pf{grid-template-columns:repeat(2,1fr)}}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:980px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gallery{grid-template-columns:1fr}}
.pf-item{position:relative;border-radius:13px;overflow:hidden;aspect-ratio:4/3;background:#1c1c28 center/cover;border:1px solid var(--line)}
.pf-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.pf-item:hover img{transform:scale(1.06)}
.pf-item .tag{position:absolute;left:10px;bottom:10px;background:rgba(10,10,15,.72);backdrop-filter:blur(4px);
  padding:5px 10px;border-radius:7px;font-size:.74rem;font-weight:800;letter-spacing:.03em;border:1px solid rgba(255,255,255,.08)}

/* guide cards */
.guide-card{display:flex;flex-direction:column;transition:transform .2s,border-color .2s;color:inherit}
.guide-card:hover{transform:translateY(-3px);border-color:var(--magenta)}
.guide-card h3{font-size:1.08rem;margin:8px 0 8px;text-transform:none;line-height:1.2}
.guide-card p{color:var(--ink-dim);font-size:.9rem;margin-bottom:14px}
.guide-card .more{margin-top:auto}
.prose h2{scroll-margin-top:80px}.prose .callout ul{margin-bottom:0}
/* article byline, hero, table of contents */
.article-meta{color:var(--ink-mute);font-size:.86rem;margin:10px 0 2px}
.article-meta strong{color:var(--ink-dim)}
.article-hero{max-width:820px;margin:0 0 26px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.article-hero img{width:100%;height:auto;display:block}
.toc{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 22px;margin:6px 0 26px}
.toc-title{font-weight:800;font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-dim);margin-bottom:8px}
.toc ol{margin:0;padding-left:18px}.toc li{margin-bottom:5px;font-size:.92rem}
.toc a{color:var(--orange)}.toc a:hover{color:#fff;text-decoration:underline}
/* "by the numbers" cited-stat box */
.bynumbers{max-width:820px;background:linear-gradient(180deg,#101019,#0c0c12);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin:6px 0 26px}
.bn-title{font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-dim);margin-bottom:12px}
.bn-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}
.bn-val{font-size:1.5rem;font-weight:900;line-height:1.05;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.bn-lab{font-size:.82rem;color:var(--ink-dim);margin-top:3px;line-height:1.3}
.bn-src{font-size:.68rem;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.04em;margin-top:4px}

/* clients / industries band */
.clients{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:920px;margin:0 auto}
.client-pill{border:1px solid var(--line);background:var(--panel);border-radius:50px;padding:9px 18px;
  font-size:.82rem;font-weight:700;color:var(--ink-dim);letter-spacing:.02em;text-transform:uppercase}
.client-pill:hover{border-color:var(--magenta);color:#fff}

/* stat band — dark band, big pink numbers, vertical dividers (mockup) */
.statband-band{background:linear-gradient(180deg,#101019,#0a0a10);border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:16px 0}
.statband{display:grid;grid-template-columns:repeat(5,1fr);max-width:var(--maxw);margin:0 auto;padding:30px 22px}
.statband .s{display:flex;align-items:center;justify-content:center;gap:13px;padding:6px 16px;border-right:1px solid var(--line)}
.statband .s:last-child{border-right:none}
.statband .s>svg{width:26px;height:26px;color:var(--magenta);flex:none}
.statband .n{font-size:2.35rem;line-height:1;font-weight:900;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.statband .l{font-size:.7rem;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}
@media(max-width:760px){.statband{grid-template-columns:repeat(2,1fr);gap:18px 0;padding:22px 0}
  .statband .s:nth-child(2n){border-right:none}.statband .s:last-child{grid-column:span 2}}

/* CTA band over skyline */
.cta-band{position:relative;overflow:hidden;border-radius:var(--radius);padding:50px 40px;margin:30px 0;text-align:center;
  background:#0c0c12 center/cover}
.cta-band::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,15,.72),rgba(10,10,15,.86))}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{font-size:clamp(1.7rem,4vw,2.6rem);text-transform:uppercase;margin-bottom:8px}
.cta-band p{color:var(--ink-dim);margin-bottom:18px}
.cta-band .cta-row{justify-content:center}

/* cards / prose / tables / forms */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.card h3{font-size:1.05rem;margin-bottom:6px}.card p{color:var(--ink-dim);font-size:.92rem}
.card .num{display:inline-flex;width:30px;height:30px;border-radius:9px;align-items:center;justify-content:center;
  background:rgba(237,25,166,.14);color:var(--orange);font-weight:900;margin-bottom:10px}
.prose{max-width:760px;color:var(--ink-dim)}.prose p{margin:0 0 14px}.prose strong{color:var(--ink)}
.prose h2{color:var(--ink);font-size:1.5rem;margin:26px 0 10px;text-transform:uppercase}.prose h3{color:var(--ink);font-size:1.15rem;margin:20px 0 8px}
.prose ul,.prose ol{margin:0 0 14px 20px}.prose li{margin-bottom:6px}
.check-list{list-style:none;margin-left:0!important}.check-list li{position:relative;padding-left:24px;margin-bottom:8px}
.check-list li:before{content:"→";position:absolute;left:0;color:var(--magenta);font-weight:900}
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel)}
table{width:100%;border-collapse:collapse;font-size:.92rem;min-width:460px}
th,td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line)}
th{font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-mute);background:var(--bg-2)}
tr:last-child td{border-bottom:none}
.callout{border-left:3px solid var(--magenta);background:var(--panel);border-radius:0 11px 11px 0;padding:14px 18px;margin:16px 0}
.callout .cl-label{font-weight:800;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--orange);margin-bottom:3px}
.tool{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.field{margin-bottom:14px}.field label{display:block;font-size:.82rem;color:var(--ink-dim);font-weight:700;margin-bottom:5px;text-transform:uppercase;letter-spacing:.03em}
.field input,.field select,.field textarea{width:100%;padding:12px;border:1px solid var(--line);border-radius:10px;background:var(--bg-2);color:var(--ink);font:inherit}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--magenta)}
.linklist{display:flex;flex-wrap:wrap;gap:9px;margin-top:8px}
.linklist a{background:var(--panel);border:1px solid var(--line);border-radius:50px;padding:7px 15px;font-size:.84rem;color:var(--ink-dim)}
.linklist a:hover{border-color:var(--magenta);color:#fff}
.page-head{padding:30px 0 6px}.page-head h1{font-size:clamp(2rem,4.6vw,2.9rem);text-transform:uppercase;margin-bottom:10px}
.page-head .sub{color:var(--ink-dim);max-width:70ch}
.crumbs{font-size:.8rem;color:var(--ink-mute);padding:16px 0 0}.crumbs a{color:var(--ink-dim)}
.muted{color:var(--ink-mute)}.mt{margin-top:16px}.tag-pill{display:inline-block;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--orange);background:rgba(237,25,166,.1);border-radius:50px;padding:4px 12px}

/* footer */
.foot{border-top:1px solid var(--line);margin-top:40px;padding:34px 0;color:var(--ink-dim);font-size:.88rem;background:var(--bg-2)}
.foot .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px}
@media(max-width:760px){.foot .cols{grid-template-columns:1fr 1fr}}
.foot h4{color:var(--ink);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.foot a{display:block;color:var(--ink-dim);margin-bottom:7px;font-size:.86rem}.foot a:hover{color:#fff}
.foot .fine{margin-top:24px;padding-top:16px;border-top:1px solid var(--line);font-size:.8rem;color:var(--ink-mute)}

/* ── Events mega-dropdown ─────────────────────────────────────────── */
.nav-group{position:relative;display:flex;align-items:center}
.nav-top{display:inline-flex;align-items:center;gap:6px;color:var(--ink-dim);font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;cursor:pointer}
.nav-top:hover{color:#fff}
.nav-top svg{width:15px;height:15px;color:var(--magenta)}
.mega{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);width:min(900px,93vw);
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:18px 20px;opacity:0;visibility:hidden;transition:opacity .16s ease,transform .16s ease;z-index:60}
.nav-group:hover .mega,.nav-group:focus-within .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega::before{content:"";position:absolute;top:-8px;left:0;right:0;height:8px}
.mega-inner{max-width:100%}
.mega-head{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:12px}
.mega-head strong{font-size:.95rem;color:var(--ink)}
.mega-head a{color:#ff9ec4;font-size:.8rem;font-weight:700}
.mega-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:14px 18px;max-height:62vh;overflow:auto}
.mega-col{min-width:0}
.mega-h{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--orange);font-weight:800;margin-bottom:6px}
.mega-col a{display:block;color:var(--ink-dim);font-size:.82rem;text-transform:none;font-weight:600;letter-spacing:0;padding:3px 0;line-height:1.25}
.mega-col a:hover{color:#fff}
@media(max-width:900px){.mega{display:none}.nav-top svg{display:none}}

/* ── Image placeholder (event/long-tail pages ship with no pictures yet) ── */
.ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;width:100%;height:100%;min-height:220px;
  background:radial-gradient(120% 120% at 30% 20%,#1a1a26,#0c0c12);border-radius:inherit;color:var(--ink-mute)}
.ph-mark svg{width:38px;height:38px;color:var(--magenta);opacity:.6}
.ph-lab{font-size:.82rem;font-weight:700;letter-spacing:.04em;color:var(--ink-dim);text-align:center;padding:0 16px}

/* ── slideshow (private-events SEG hero) ─────────────────────────────── */
.vd-slideshow{position:relative;width:100%;aspect-ratio:16/10;border-radius:16px;overflow:hidden;background:var(--bg)}
/* phones: taller slideshow so portrait media isn't tiny + let the specs table wrap (placed AFTER the base rules so it wins) */
@media(max-width:620px){.vd-slideshow{aspect-ratio:4/3}table{min-width:0}}
.vd-slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease;will-change:opacity}
.vd-slide.active{opacity:1}
/* whole photo shown (contain) on the site background color — no crop, no blurred fill */
.vd-slide-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;z-index:1}
.vd-ss-badge{position:absolute;top:12px;left:12px;z-index:3;background:rgba(10,10,15,.66);
  backdrop-filter:blur(6px);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.05em;
  text-transform:uppercase;padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.15)}
.vd-dots{position:absolute;bottom:13px;left:0;right:0;display:flex;justify-content:center;gap:7px;z-index:3}
.vd-dot{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.45);
  cursor:pointer;padding:0;transition:.25s}
.vd-dot.active{background:#fff;width:24px;border-radius:5px}

/* ── booth catalog grid + filters ────────────────────────────────────── */
.booth-filters{display:flex;flex-wrap:wrap;gap:22px;align-items:center;margin-bottom:4px}
.fgroup{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.flabel{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);margin-right:2px}
.fbtn{background:var(--panel);border:1px solid var(--line);color:var(--ink-dim);padding:7px 15px;
  border-radius:999px;font-size:.85rem;cursor:pointer;transition:.15s;font-weight:600}
.fbtn:hover{border-color:var(--purple);color:var(--ink)}
.fbtn.active{background:var(--grad);border-color:transparent;color:#fff}
.booth-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:18px}
.booth-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  display:flex;flex-direction:column;transition:.18s}
.booth-card:hover{border-color:var(--purple);transform:translateY(-3px)}
.booth-img{position:relative;background:var(--bg-2)}
.booth-img img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.booth-size{position:absolute;top:10px;right:10px;font-size:.72rem;font-weight:700;
  background:rgba(10,10,15,.72);color:#fff;padding:4px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.14)}
.booth-meta{padding:13px 15px 16px;display:flex;flex-direction:column;gap:6px}
.booth-id{font-weight:800;color:var(--ink);font-size:1rem}
.booth-type{font-size:.8rem;color:var(--ink-mute)}
.btn-sm{padding:9px 14px;font-size:.85rem;margin-top:6px;text-align:center;width:100%}

/* ── scrollable product catalog strip (service pages) ────────────────── */
.cat-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:10px;margin:6px 0 14px}
.cat-hint{font-size:.82rem;color:var(--ink-mute)}
.cat-strip{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x proximity;padding:4px 2px 16px;
  scrollbar-width:thin;scrollbar-color:var(--purple) var(--panel)}
.cat-strip::-webkit-scrollbar{height:9px}
.cat-strip::-webkit-scrollbar-thumb{background:var(--purple);border-radius:9px}
.cat-strip::-webkit-scrollbar-track{background:var(--panel);border-radius:9px}
.cat-card{flex:0 0 auto;width:270px;scroll-snap-align:start;background:var(--panel);
  border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;
  transition:.18s;text-decoration:none}
.cat-card:hover{border-color:var(--purple);transform:translateY(-3px)}
.cat-card.page{width:236px;background:#fff}
.cat-card .cc-img{width:100%;display:block}
.cat-card.photo .cc-img{aspect-ratio:4/3;object-fit:cover}
.cc-meta{padding:11px 14px 14px;display:flex;flex-direction:column;gap:3px}
.cc-name{font-weight:700;color:var(--ink);font-size:.95rem}
.cat-card.page .cc-name{color:#0c0c14}
.cc-sub{font-size:.78rem;color:var(--ink-mute)}
.cat-card.page .cc-sub{color:#5a5a66}
.cat-more{flex:0 0 auto;width:200px;scroll-snap-align:start;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:10px;background:var(--panel-2);border:1px dashed var(--line);
  border-radius:14px;color:var(--ink);text-decoration:none;font-weight:700;transition:.18s}
.cat-more:hover{border-color:var(--purple);color:#fff}

/* product catalog grid — white-bg cards holding portrait PDF-page renders (contain, never cropped) */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;margin-top:18px}
.prod-grid>*{min-width:0}
.prod-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;
  flex-direction:column;text-decoration:none;transition:.16s}
.prod-card:hover{border-color:var(--purple);transform:translateY(-3px)}
.prod-card .pc-img{width:100%;height:auto;display:block}
.prod-card .pc-meta{padding:11px 13px 13px;display:flex;flex-direction:column;gap:3px}
.prod-card .pc-name{color:#0c0c14;font-weight:700;font-size:.93rem;line-height:1.25}
.prod-card .pc-cat{color:#5a5a66;font-size:.76rem}
@media(max-width:620px){.prod-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}}

/* private-event use-case cards link to their landing page */
.card-link{text-decoration:none;display:block;transition:.16s}
.card-link:hover{border-color:var(--purple);transform:translateY(-3px)}
.card-more{display:inline-block;margin-top:10px;color:var(--orange);font-weight:700;font-size:.85rem}

/* ── industry "design demo" concept hero (labeled AI render, shown whole) ───── */
.demo-hero{display:flex;flex-direction:column}
.demo-hero img{width:100%;height:auto;display:block;border-radius:var(--radius);
  border:1px solid var(--line);box-shadow:var(--shadow)}
.demo-cap{font-size:.8rem;color:var(--ink-mute);margin-top:9px;line-height:1.45}
.demo-cap a{color:#ff9ec4;font-weight:700;white-space:nowrap}
