/* ========================================
   RAHSTA EXPO 2026 — Shared Design System
   Palette: red / white / grey / black
   Built on Bootstrap 5
   ======================================== */

:root{
  --r-red:#E11D2E;
  --r-red-dark:#B5121F;
  --r-red-soft:#FDECEE;
  --r-black:#111111;
  --r-ink:#1A1A1A;
  --r-grey-900:#2A2A2A;
  --r-grey-700:#4A4A4A;
  --r-grey-500:#7A7A7A;
  --r-grey-300:#D6D6D6;
  --r-grey-100:#F2F2F2;
  --r-grey-50:#F8F8F8;
}

/* ===== Base ===== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--r-ink);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5,.display-1,.display-2,.display-3,.display-4,.display-5,.display-6{
  font-family:'Poppins',sans-serif;letter-spacing:-0.02em;line-height:1.1;font-weight:700;
}
a{text-decoration:none}

/* ===== Utility ===== */
.text-red{color:var(--r-red)!important}
.bg-red{background:var(--r-red)!important;color:#fff}
.bg-black{background:var(--r-black)!important;color:#fff}
.bg-grey-50{background:var(--r-grey-50)!important}
.bg-grey-100{background:var(--r-grey-100)!important}
.border-red{border-color:var(--r-red)!important}

/* ===== Top utility bar ===== */
.topbar{background:var(--r-black);color:#fff;font-size:13px;padding:9px 0}
.topbar a{color:#fff;opacity:.85}
.topbar a:hover{opacity:1;color:#fff}
.pulse-dot{
  width:8px;height:8px;border-radius:50%;background:var(--r-red);display:inline-block;
  box-shadow:0 0 0 0 rgba(225,29,46,.8);animation:pulse 1.6s infinite;margin-right:8px;vertical-align:middle;
}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(225,29,46,.8)}70%{box-shadow:0 0 0 10px rgba(225,29,46,0)}100%{box-shadow:0 0 0 0 rgba(225,29,46,0)}}

/* ===== Brand ===== */
.brand-logo{display:flex;align-items:center;gap:10px;font-family:'Poppins';font-weight:800;font-size:22px;color:var(--r-black); height: 90px;}
.brand-mark{
  width:42px;height:42px;border-radius:8px;background:#fff;border:2px solid var(--r-black);
  position:relative;display:grid;place-items:center;color:var(--r-black);font-weight:900;font-size:13px;line-height:1;
}
.brand-mark .ed{position:absolute;top:-8px;left:-8px;background:var(--r-red);color:#fff;font-size:9px;font-weight:800;padding:2px 5px;border-radius:4px;letter-spacing:.04em}
.brand-mark::after{
  content:"";position:absolute;left:6px;right:6px;bottom:5px;height:2px;
  background:repeating-linear-gradient(90deg,var(--r-red) 0 4px,transparent 4px 7px);
}

/* ===== Navbar ===== */
.navbar{padding:14px 0;background:#fff;border-bottom:1px solid var(--r-grey-100)}
.navbar.scrolled{box-shadow:0 6px 24px -10px rgba(0,0,0,.12)}
.navbar .nav-link{color:var(--r-black);font-weight:600;font-size:14.5px;letter-spacing:.02em;text-transform:uppercase;padding:8px 14px!important}
.navbar .nav-link:hover,.navbar .nav-link.active{color:var(--r-red)}
.navbar .dropdown-menu{border:1px solid var(--r-grey-100);border-radius:12px;box-shadow:0 16px 40px -10px rgba(0,0,0,.12);padding:8px;margin-top:6px}
.navbar .dropdown-item{padding:10px 14px;border-radius:8px;font-size:14px;font-weight:500}
.navbar .dropdown-item:hover{background:var(--r-red-soft);color:var(--r-red)}

/* ===== Buttons ===== */
.btn{font-weight:600;border-radius:999px;padding:11px 22px;font-size:14.5px;letter-spacing:.02em;transition:all .2s}
.btn-lg{padding:15px 30px;font-size:16px}
.btn-red{background:var(--r-red);color:#fff;border:2px solid var(--r-red)}
.btn-red:hover{background:var(--r-red-dark);border-color:var(--r-red-dark);color:#fff;transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(225,29,46,.5)}
.btn-black{background:var(--r-black);color:#fff;border:2px solid var(--r-black)}
.btn-black:hover{background:#000;color:#fff}
.btn-outline-black{background:transparent;color:var(--r-black);border:2px solid var(--r-black)}
.btn-outline-black:hover{background:var(--r-black);color:#fff}
.btn-outline-white{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.45)}
.btn-outline-white:hover{background:#fff;color:var(--r-black);border-color:#fff}
.btn-white{background:#fff;color:var(--r-red);border:2px solid #fff}
.btn-white:hover{background:var(--r-black);color:#fff;border-color:var(--r-black)}
.btn .arr{transition:transform .2s;display:inline-block;margin-left:4px}
.btn:hover .arr{transform:translateX(4px)}

/* ===== HERO (home only) ===== */
.hero{
  position:relative;overflow:hidden;color:#fff;padding:90px 0 100px;
  background:
    radial-gradient(900px 500px at 90% 0%, rgba(225,29,46,.35), transparent 60%),
    radial-gradient(700px 400px at 0% 100%, rgba(225,29,46,.18), transparent 60%),
    linear-gradient(180deg,#0A0A0A 0%,#1A1A1A 100%);
}
.hero::before{
  content:"";position:absolute;inset:0;opacity:.08;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.6) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.6) 1px,transparent 1px);
  background-size:42px 42px;
}
.hero .container{position:relative;z-index:2}
.eyebrow{
  display:inline-flex;align-items:center;gap:3px;padding:7px 14px;border-radius:999px;
  background:rgba(225,29,46,.18);border: 2px solid rgb(225 29 46);
  color:#fff;font-weight:600;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;
}
.hero h1{font-size:clamp(38px,6.5vw,80px);font-weight:800;margin:22px 0 18px;color:#fff}
.hero h1 .hl{position:relative;color:var(--r-red);white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:-4px;right:-4px;bottom:4px;height:14px;z-index:-1;background:rgba(225,29,46,.22);border-radius:3px;transform:skewX(-8deg)}
.hero .lead{font-size:clamp(17px,1.55vw,20px);max-width:680px;color:rgba(255,255,255,.78);margin-bottom:32px}
.hero-meta{display:flex;flex-wrap:wrap;gap:30px;color:rgba(255,255,255,.85);font-size:14.5px}
.hero-meta .ic-tile{width:36px;height:36px;border-radius:8px;display:grid;place-items:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:var(--r-red)}
.hero-meta b{color:#fff;font-weight:700}

/* ===== Countdown ===== */
.countdown{margin-top:46px;display:flex;gap:10px;flex-wrap:wrap}
.cd{flex:1;min-width:120px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.13);border-radius:12px;padding:18px 12px;text-align:center;backdrop-filter:blur(8px)}
.cd .num{font-family:'Space Grotesk';font-size:44px;font-weight:700;letter-spacing:-.03em;color:#fff;line-height:1}
.cd .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:rgba(255,255,255,.55);margin-top:8px}
.cd:nth-child(1) .num{color:var(--r-red)}

/* ===== Page hero (inner pages) ===== */
.page-hero{
  position:relative;overflow:hidden;color:#fff;padding:80px 0 70px;
  background:
    radial-gradient(700px 400px at 90% 0%, rgba(225,29,46,.3), transparent 60%),
    linear-gradient(180deg,#0A0A0A 0%,#1A1A1A 100%);
}
.page-hero::before{
  content:"";position:absolute;inset:0;opacity:.06;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.6) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.6) 1px,transparent 1px);
  background-size:42px 42px;
}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{font-size:clamp(34px,5.2vw,60px);color:#fff;margin:18px 0 14px; text-transform: uppercase;}
.page-hero h1 .hl{position:relative;color:var(--r-red)}
.page-hero h1 .hl::after{content:"";position:absolute;left:-4px;right:-4px;bottom:4px;height:12px;z-index:-1;/*background:rgba(225,29,46,.22);*/border-radius:3px;transform:skewX(-8deg)}
.page-hero .lead{font-size:clamp(16px,1.5vw,19px);max-width:720px;color:rgba(255,255,255,.8);margin:0}
.breadcrumb-r{display:flex;gap:10px;font-size:13px;color:rgba(255,255,255,.55);margin-bottom:16px;flex-wrap:wrap}
.breadcrumb-r a{color:rgba(255,255,255,.7)}
.breadcrumb-r a:hover{color:var(--r-red)}
.breadcrumb-r .sep{color:rgba(255,255,255,.4)}

/* ===== Marquee ===== */
.marquee{background:#fff;border-top:1px solid var(--r-grey-100);border-bottom:1px solid var(--r-grey-100);padding:20px 0;overflow:hidden}
.marquee-row{display:flex;gap:60px;align-items:center;animation:scroll 36s linear infinite;width:max-content}
.marquee-row span{font-family:'Poppins';font-weight:600;font-size:17px;color:var(--r-grey-500);letter-spacing:.02em;white-space:nowrap}
.marquee-row span::after{content:"●";margin-left:60px;color:var(--r-red);font-size:7px;vertical-align:middle}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== Section helpers ===== */
section{padding:90px 0}
.kicker{color:var(--r-red);font-weight:700;font-size:12.5px;letter-spacing:.2em;text-transform:uppercase}
.section-head h2{font-size:clamp(30px,3.6vw,48px);font-weight:700;margin:14px 0 12px}
.section-head p.sub{color:var(--r-grey-500);font-size:17px;max-width:680px;margin:0 auto}

/* ===== Stats ===== */
.stats{padding:70px 0;background:#fff;border-bottom:1px solid var(--r-grey-100)}
.stat .num{font-family:'Poppins';font-weight:800;font-size:clamp(38px,4.6vw,56px);letter-spacing:-.03em;color:var(--r-black);line-height:1}
.stat .num .accent{color:var(--r-red)}
.stat .lbl{margin-top:8px;color:var(--r-grey-500);font-size:14.5px;font-weight:500}
.stat .div{height:3px;width:36px;background:var(--r-red);margin-top:12px;border-radius:2px}

/* ===== Generic feature cards ===== */
.why-card{
  background:#fff;border:1px solid var(--r-grey-100);border-radius:16px;
  padding:32px;height:100%;transition:all .25s;position:relative;overflow:hidden;
}
.why-card:hover{transform:translateY(-6px);border-color:var(--r-red);box-shadow:0 24px 50px -20px rgba(0,0,0,.15)}
.why-card .ic{width:54px;height:54px;border-radius:12px;display:grid;place-items:center;background:var(--r-red-soft);color:var(--r-red);margin-bottom:18px;font-size:24px}
.why-card h3{font-size:21px;margin-bottom:8px;color:var(--r-black)}
.why-card p{color:var(--r-grey-500);font-size:14.5px;line-height:1.6;margin:0}
.why-card .num-tag{position:absolute;top:22px;right:24px;font-family:'Poppins';font-weight:800;font-size:13px;color:var(--r-grey-300);letter-spacing:.1em}

/* ===== Pillars (dark) ===== */
.pillars{background:var(--r-black);color:#fff;position:relative;overflow:hidden}
.pillars::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 400px at 100% 0%, rgba(225,29,46,.2), transparent 60%);pointer-events:none}
.pillars .section-head h2{color:#fff}
.pillars .section-head p.sub{color:rgba(255,255,255,.7)}
.pillar{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;
  padding:32px;height:100%;display:flex;gap:22px;align-items:flex-start;transition:all .25s;
}
.pillar:hover{background:rgba(225,29,46,.08);border-color:rgba(225,29,46,.45);transform:translateY(-4px)}
.pillar .big{font-family:'Poppins';font-weight:800;font-size:40px;color:var(--r-red);min-width:60px;line-height:1}
.pillar h3{font-size:21px;margin-bottom:6px;color:#fff}
.pillar p{color:rgba(255,255,255,.7);font-size:14.5px;margin:0}

/* ===== Perks / visitor pass card ===== */
.perks-card{
  background:linear-gradient(135deg,var(--r-black) 0%,var(--r-grey-900) 100%);
  color:#fff;border-radius:20px;padding:36px;position:relative;overflow:hidden;height:100%;
}
.perks-card::after{content:"";position:absolute;right:-50px;bottom:-50px;width:240px;height:240px;background:radial-gradient(circle,var(--r-red) 0%,transparent 70%);opacity:.45}
.perks-card h3{font-size:26px;margin-bottom:6px;position:relative}
.perks-card .tag{position:relative;color:rgba(255,255,255,.7);margin-bottom:22px}
.perks-card .price{display:flex;align-items:baseline;gap:10px;margin-bottom:6px;position:relative}
.perks-card .price .free{font-family:'Poppins';font-weight:800;font-size:60px;color:var(--r-red);letter-spacing:-.03em;line-height:1}
.perks-card .price .strike{text-decoration:line-through;color:rgba(255,255,255,.5);font-size:18px}
.perks-card .small-note{font-size:12.5px;color:rgba(255,255,255,.6);margin-bottom:20px;position:relative}
.check-list{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.check-list li{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:var(--r-black)}
.check-list.on-dark li{color:rgba(255,255,255,.85)}
.chk{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--r-red);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}

/* ===== Categories ===== */
.cat-group{margin-bottom:36px}
.cat-group h4{font-size:16px;font-weight:700;color:var(--r-black);margin-bottom:14px;text-transform:uppercase;letter-spacing:.06em}
.cat-group h4 .bar{display:inline-block;width:24px;height:3px;background:var(--r-red);vertical-align:middle;margin-right:10px}
.cat-pill{display:inline-block;background:#fff;border:1px solid var(--r-grey-300);color:var(--r-grey-900);font-weight:500;font-size:13.5px;padding:9px 16px;border-radius:999px;margin:0 6px 8px 0;transition:all .2s;cursor:default}
.cat-pill:hover{border-color:var(--r-red);background:var(--r-red);color:#fff;transform:translateY(-2px)}

/* ===== Speakers ===== */
.sp-av{width:100%;aspect-ratio:1;border-radius:16px;background:linear-gradient(135deg,var(--r-grey-900),var(--r-black));margin-bottom:14px;position:relative;overflow:hidden;display:grid;place-items:center;color:#fff;font-family:'Poppins';font-weight:700;font-size:38px}
.sp-av::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--r-red)}
.sp h4{font-size:16.5px;margin-bottom:4px;color:var(--r-black)}
.sp .role{color:var(--r-grey-500);font-size:13px;margin:0}

/* ===== Voices / testimonials ===== */
.voice{background:#fff;border:1px solid var(--r-grey-100);border-radius:16px;padding:30px;height:100%;position:relative}
.voice .quote{font-family:'Space Grotesk';font-size:48px;color:var(--r-red);line-height:0;position:absolute;top:30px;right:24px;opacity:.35}
.voice p.body{font-size:15.5px;line-height:1.65;color:var(--r-black);margin-bottom:20px}
.voice .who{display:flex;gap:12px;align-items:center}
.voice .av{width:42px;height:42px;border-radius:50%;background:var(--r-red);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}
.voice .who b{display:block;font-size:14px}
.voice .who span{color:var(--r-grey-500);font-size:12.5px}

/* ===== Exhibitor CTA strip ===== */
.exhibitor-cta{background:linear-gradient(135deg,var(--r-black) 0%,var(--r-grey-900) 100%);color:#fff;padding:80px 0;position:relative;overflow:hidden}
.exhibitor-cta::after{content:"";position:absolute;top:-80px;right:-80px;width:380px;height:380px;background:radial-gradient(circle,var(--r-red) 0%,transparent 70%);opacity:.35}
.ec-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:28px;backdrop-filter:blur(8px);position:relative;z-index:2}
.progress-bar-r{height:8px;background:rgba(255,255,255,.12);border-radius:4px;overflow:hidden}
.progress-bar-r > div{height:100%;background:var(--r-red);border-radius:4px}

/* ===== FAQ accordion ===== */
.accordion-button{font-weight:600;font-size:17px;color:var(--r-black);padding:22px 0;background:#fff;box-shadow:none!important;border:none!important}
.accordion-button:not(.collapsed){background:#fff;color:var(--r-red)}
.accordion-button::after{background-image:none;content:"+";font-size:24px;color:var(--r-red);font-weight:300;width:auto;height:auto;transition:transform .2s}
.accordion-button:not(.collapsed)::after{transform:rotate(45deg)}
.accordion-item{border:none;border-bottom:1px solid var(--r-grey-100);border-radius:0!important; padding: 0px 20px 0px 20px;}
.accordion-body{padding:0 0 22px;color:var(--r-grey-500);font-size:15.5px;line-height:1.7}

/* ===== Final CTA ===== */
.final{background:var(--r-red);color:#fff;padding:90px 0;text-align:center;position:relative;overflow:hidden}
.final::before{content:"";/*position:absolute;*/inset:0;background-image:linear-gradient(rgba(255,255,255,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.12) 1px,transparent 1px);background-size:42px 42px;opacity:.35}
.final h2{font-size:clamp(34px,5vw,60px);margin-bottom:14px;position:relative;color:#fff}
.final p.lead{font-size:19px;opacity:.92;margin-bottom:30px;position:relative;color:#fff}

/* ===== Footer ===== */
footer{background:var(--r-black);color:#fff;padding:60px 0 28px}
footer h5{color:#fff;margin-bottom:16px;font-family:'Poppins';font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase}
footer ul{list-style:none;padding:0;display:grid;gap:9px;margin:0}
footer ul a{color:rgba(255,255,255,.62);font-size:13.5px;transition:color .2s}
footer ul a:hover{color:var(--r-red)}
footer .blurb{color:rgba(255,255,255,.62);font-size:13.5px;margin-top:12px;line-height:1.6}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;margin-top:40px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;color:rgba(255,255,255,.45);font-size:12.5px}
.foot-bottom a{color:rgba(255,255,255,.55)}
.social-row a{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;margin-right:8px;transition:background .2s}
.social-row a:hover{background:var(--r-red)}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ===== Page-specific utilities ===== */

/* Booth pricing cards */
.booth{background:#fff;border:1px solid var(--r-grey-100);border-radius:18px;padding:32px;height:100%;transition:all .25s;position:relative}
.booth.featured{border-color:var(--r-red);box-shadow:0 24px 60px -20px rgba(225,29,46,.25)}
.booth.featured::before{content:"Most popular";position:absolute;top:-12px;left:24px;background:var(--r-red);color:#fff;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.booth h3{font-size:22px;margin-bottom:6px;color:var(--r-black)}
.booth .price-tag{font-family:'Poppins';font-weight:800;font-size:44px;color:var(--r-black);margin:14px 0 4px;letter-spacing:-.03em}
.booth .price-tag .cur{font-size:22px;font-weight:700;color:var(--r-grey-500);vertical-align:top}
.booth .price-unit{color:var(--r-grey-500);font-size:13px;margin-bottom:18px}
.booth ul{list-style:none;padding:0;margin:0 0 22px;display:grid;gap:10px}
.booth ul li{font-size:14px;color:var(--r-grey-700);display:flex;gap:8px;align-items:flex-start}
.booth ul li i{color:var(--r-red);margin-top:2px}

/* Sponsorship tiers */
.tier{background:#fff;border:1px solid var(--r-grey-100);border-radius:16px;padding:24px;text-align:center;height:100%;transition:all .2s}
.tier:hover{border-color:var(--r-red);transform:translateY(-4px)}
.tier .crown{width:48px;height:48px;border-radius:12px;background:var(--r-red-soft);color:var(--r-red);margin:0 auto 14px;display:grid;place-items:center;font-size:22px}
.tier.gold .crown{background:#FFF4D6;color:#B5870F}
.tier.platinum .crown{background:#E8E8E8;color:#444}
.tier.diamond .crown{background:#E6F0FF;color:#1A4FB5}
.tier.title .crown{background:var(--r-red);color:#fff}
.tier h5{font-size:13px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--r-grey-500);margin-bottom:6px}
.tier h3{font-size:20px;color:var(--r-black);margin-bottom:10px}
.tier .amount{font-family:'Poppins';font-weight:800;font-size:24px;color:var(--r-red);letter-spacing:-.02em}
.tier .amount small{font-size:12px;color:var(--r-grey-500);font-weight:500;display:block;margin-top:2px}

/* Donut/chart-ish stat block */
.bar-row{margin-bottom:18px}
.bar-row .label{display:flex;justify-content:space-between;font-size:14px;color:var(--r-black);margin-bottom:6px}
.bar-row .label b{color:var(--r-red)}
.bar-track{height:10px;background:var(--r-grey-100);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--r-red),#FF4A5C);border-radius:6px}

/* Article cards */
.article{background:#fff;border:1px solid var(--r-grey-100);border-radius:16px;overflow:hidden;height:100%;transition:all .25s}
.article:hover{transform:translateY(-6px);box-shadow:0 24px 50px -20px rgba(0,0,0,.15)}
.article .thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--r-grey-300),var(--r-grey-100));position:relative;overflow:hidden;display:grid;place-items:center;color:var(--r-grey-500);font-size:42px}
.article .thumb .tag{position:absolute;top:14px;left:14px;background:var(--r-red);color:#fff;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:5px 10px;border-radius:6px}
.article .body{padding:22px}
.article .meta{font-size:12px;color:var(--r-grey-500);letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px}
.article h3{font-size:19px;line-height:1.3;color:var(--r-black);margin-bottom:10px}
.article p{font-size:14px;color:var(--r-grey-500);margin-bottom:14px}
.article a.more{font-weight:600;font-size:14px;color:var(--r-red)}

/* Gallery tiles */
.gallery-tile{border-radius:12px;overflow:hidden;position:relative;background:#111;cursor:pointer}
      .gallery-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
      .gallery-tile:hover img{transform:scale(1.05)}
      .gallery-tile .cap{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:linear-gradient(transparent,rgba(0,0,0,.72));color:#fff;font-size:13px;font-weight:500}
      .g-img-tall{aspect-ratio:3/4}
      .g-img-wide{aspect-ratio:16/9}
      .g-img-sq{aspect-ratio:4/3}
      /* Lightbox */
      #lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;align-items:center;justify-content:center;flex-direction:column}
      #lb.open{display:flex}
      #lb img{max-width:90vw;max-height:82vh;border-radius:8px;object-fit:contain}
      #lb-cap{color:rgba(255,255,255,.8);font-size:14px;margin-top:14px;font-family:'Poppins',sans-serif}
      #lb-close{position:absolute;top:20px;right:28px;color:#fff;font-size:36px;cursor:pointer;line-height:1;opacity:.7}
      #lb-close:hover{opacity:1}
      #lb-prev,#lb-next{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:40px;cursor:pointer;opacity:.65;user-select:none}
      #lb-prev:hover,#lb-next:hover{opacity:1}
      #lb-prev{left:20px}
      #lb-next{right:20px}

/* Contact form */
.cform .form-control,.cform .form-select{
  border:1.5px solid var(--r-grey-300);border-radius:10px;padding:13px 16px;font-size:15px;
  transition:border-color .2s,box-shadow .2s;
}
.cform .form-control:focus,.cform .form-select:focus{
  border-color:var(--r-red);box-shadow:0 0 0 4px rgba(225,29,46,.1);
}
.cform label{font-weight:600;font-size:13.5px;color:var(--r-black);margin-bottom:6px}
.cform textarea{min-height:140px;resize:vertical}
.contact-card{background:#fff;border: 1px solid #bfbfbf;border-radius:14px;padding:24px;height:100%;transition:all .2s}
.contact-card:hover{border-color:var(--r-red);transform:translateY(-3px)}
.contact-card .ic{width:44px;height:44px;border-radius:10px;background:var(--r-red-soft);color:var(--r-red);display:grid;place-items:center;font-size:20px;margin-bottom:14px}
.contact-card h5{font-size:16px;color:var(--r-black);margin-bottom:6px;font-family:'Poppins';font-weight:700;letter-spacing:-.02em}
.contact-card a{color:var(--r-grey-700);font-size:14px;display:block;margin-bottom:2px}
.contact-card a:hover{color:var(--r-red)}

/* Timeline */
.timeline{position:relative;padding-left:30px}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--r-grey-100)}
.tl-item{position:relative;padding:0 0 28px 0}
.tl-item::before{content:"";position:absolute;left:-30px;top:6px;width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--r-red);z-index:2}
.tl-item.done::before{background:var(--r-red)}
.tl-date{font-family:'Poppins';font-weight:700;font-size:13px;color:var(--r-red);letter-spacing:.05em;text-transform:uppercase;margin-bottom:4px}
.tl-item h4{font-size:18px;color:var(--r-black);margin-bottom:4px}
.tl-item p{font-size:14.5px;color:var(--r-grey-500);margin:0}

/* Schedule rows */
.sched-row{display:grid;grid-template-columns:120px 1fr auto;gap:24px;padding:18px 0;border-bottom:1px solid var(--r-grey-100);align-items:center}
.sched-row:last-child{border-bottom:none}
.sched-time{font-family:'Poppins';font-weight:700;color:var(--r-red);font-size:15px}
.sched-row h5{font-size:16px;color:var(--r-black);margin-bottom:4px;font-family:'Poppins';font-weight:700}
.sched-row .who{color:var(--r-grey-500);font-size:13.5px}
.sched-row .track{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:999px;background:var(--r-red-soft);color:var(--r-red);white-space:nowrap}

/* Demographic bars (visitor profile) */
.demo-chart{background:#fff;border:1px solid var(--r-grey-100);border-radius:16px;padding:28px}
.demo-chart h4{font-size:16px;color:var(--r-black);margin-bottom:18px;font-family:'Poppins';font-weight:700}

/* Audience donut placeholder */
.donut{
  width:200px;height:200px;border-radius:50%;
  background:conic-gradient(var(--r-red) 0 35%, #FF4A5C 35% 55%, var(--r-grey-900) 55% 75%, var(--r-grey-500) 75% 88%, var(--r-grey-300) 88% 100%);
  position:relative;margin:0 auto;
}
.donut::after{content:"";position:absolute;inset:30px;border-radius:50%;background:#fff}
.donut-legend{list-style:none;padding:0;margin:24px 0 0}
.donut-legend li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--r-grey-700);margin-bottom:8px}
.donut-legend .sw{width:12px;height:12px;border-radius:3px;flex-shrink:0}

/* Award category card */
.award-cat{background:#fff;border:1px solid var(--r-grey-100);border-radius:12px;padding:18px;transition:all .2s;height:100%;display:flex;gap:14px;align-items:flex-start}
.award-cat:hover{border-color:var(--r-red);transform:translateY(-3px)}
.award-cat .ic{flex-shrink:0;width:38px;height:38px;border-radius:8px;background:var(--r-red-soft);color:var(--r-red);display:grid;place-items:center}
.award-cat h5{font-size:14.5px;color:var(--r-black);margin:0;line-height:1.3;font-family:'Poppins';font-weight:700}
.award-cat p{font-size:12.5px;color:var(--r-grey-500);margin:4px 0 0}

/* Map placeholder */
.map-block{aspect-ratio:16/8;border-radius:14px;background:linear-gradient(135deg,#1A1A1A,#2A2A2A);position:relative;overflow:hidden;border:1px solid var(--r-grey-100)}
.map-block::before{
  content:"";position:absolute;inset:0;opacity:.4;
  background-image:
    radial-gradient(circle at 30% 40%, var(--r-red) 0 6px, transparent 7px),
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:auto, 40px 40px, 40px 40px;
}
.map-block .pin{position:absolute;left:30%;top:38%;color:var(--r-red);font-size:32px}
.map-block .badge-loc{position:absolute;left:24px;bottom:24px;background:#fff;padding:12px 18px;border-radius:10px;color:var(--r-black);font-size:14px;font-weight:600;box-shadow:0 8px 24px -8px rgba(0,0,0,.3)}

/* ===== Logo wall (credibility grids) ===== */
.logo-card{
  background:#fff;border:1px solid var(--r-grey-100);border-radius:10px;
  padding:18px 14px;height:84px;
  display:grid;place-items:center;text-align:center;
  font-family:'Poppins',sans-serif;font-weight:700;font-size:14px;
  color:var(--r-grey-700);letter-spacing:.01em;line-height:1.2;
  transition:all .2s;
}
.logo-card:hover{border-color:var(--r-red);color:var(--r-red);transform:translateY(-3px);box-shadow:0 14px 30px -14px rgba(0,0,0,.12)}
.logo-card.dark{background:var(--r-black);color:#fff;border-color:transparent}
.logo-card.dark:hover{color:var(--r-red)}

/* Category section header */
.cat-section-h{
  font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--r-grey-500);margin-bottom:16px;display:flex;align-items:center;gap:12px;
}
.cat-section-h::before{content:"";display:inline-block;width:28px;height:3px;background:var(--r-red);border-radius:2px}
.cat-section-h .count{
  display:inline-block;background:var(--r-red-soft);color:var(--r-red);
  font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;letter-spacing:.06em;
}

/* Project pipeline tile */
.pipe-tile{
  background:#fff;border:1px solid var(--r-grey-100);border-radius:14px;
  padding:22px;transition:all .2s;height:100%;
}
.pipe-tile:hover{border-color:var(--r-red);transform:translateY(-3px)}
.pipe-tile .pipe-tag{
  display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;padding:3px 9px;border-radius:6px;
  background:var(--r-red-soft);color:var(--r-red);margin-bottom:10px;
}
.pipe-tile .pipe-tag.gov{background:#E6F0FF;color:#1A4FB5}
.pipe-tile .pipe-tag.state{background:#FFF4D6;color:#B5870F}
.pipe-tile h4{font-size:17px;color:var(--r-black);margin-bottom:6px;font-family:'Poppins',sans-serif;font-weight:700;line-height:1.3}
.pipe-tile .pipe-amt{font-family:'Poppins',sans-serif;font-weight:800;font-size:24px;color:var(--r-red);letter-spacing:-.02em;margin:8px 0}
.pipe-tile .pipe-meta{font-size:13px;color:var(--r-grey-500)}

/* ===== Registration page ===== */

/* Top role selector */
.role-tabs{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.role-tabs a{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1.5px solid var(--r-grey-300);color:var(--r-black);
  font-weight:600;font-size:14px;padding:11px 20px;border-radius:999px;
  transition:all .2s;
}
.role-tabs a:hover{border-color:var(--r-red);color:var(--r-red);transform:translateY(-2px)}
.role-tabs a.primary{background:var(--r-red);color:#fff;border-color:var(--r-red)}
.role-tabs a.primary:hover{background:var(--r-red-dark);border-color:var(--r-red-dark);color:#fff}
.role-tabs i{font-size:18px}

/* Pricing comparison cards */
.pass-card{
  background:#fff;border:1.5px solid var(--r-grey-100);border-radius:18px;
  padding:28px;height:100%;transition:all .25s;position:relative;display:flex;flex-direction:column; background: #fff;
    border: 1.5px solid #bfbfbf;
}
.pass-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -20px rgba(0,0,0,.15)}
.pass-card.featured{border-color:var(--r-red);box-shadow:0 20px 50px -20px rgba(225,29,46,.25)}
.pass-card.featured::before{
  content:"Most popular";position:absolute;top:-12px;left:24px;
  background:var(--r-red);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:5px 12px;border-radius:999px;
}
.pass-card .pass-label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--r-grey-500);margin-bottom:6px}
.pass-card h3{font-size:22px;color:var(--r-black);margin-bottom:6px}
.pass-card .pass-tagline{color:var(--r-grey-500);font-size:13.5px;margin-bottom:18px;min-height:36px}
.pass-card .pass-price{font-family:'Poppins',sans-serif;font-weight:800;font-size:42px;color:var(--r-black);line-height:1;letter-spacing:-.03em}
.pass-card .pass-price .cur{font-size:18px;font-weight:700;color:var(--r-grey-500);vertical-align:top}
.pass-card .pass-price.free{color:var(--r-red)}
.pass-card .pass-unit{color:var(--r-grey-500);font-size:12.5px;margin:6px 0 18px;min-height:18px}
.pass-card ul.pass-feats{list-style:none;padding:0;margin:0 0 22px;display:grid;gap:10px;flex-grow:1}
.pass-card ul.pass-feats li{font-size:13.5px;color:var(--r-grey-700);display:flex;gap:8px;align-items:flex-start;line-height:1.5}
.pass-card ul.pass-feats li i{color:var(--r-red);margin-top:2px;font-size:14px;flex-shrink:0}
.pass-card ul.pass-feats li.dim{color:var(--r-grey-300);text-decoration:line-through}
.pass-card ul.pass-feats li.dim i{color:var(--r-grey-300)}
.pass-card .pass-cta{margin-top:auto}

/* Form panels */
.form-panel{background:#fff;border:1px solid var(--r-grey-100);border-radius:18px;padding:32px}
.form-panel + .form-panel{margin-top:20px}
.form-panel h3.panel-title{
  font-size:18px;color:var(--r-black);margin-bottom:4px;font-weight:700;
  display:flex;align-items:center;gap:10px;
}
.form-panel h3.panel-title .step-num{
  width:28px;height:28px;border-radius:50%;background:var(--r-red);color:#fff;
  display:grid;place-items:center;font-size:13px;font-weight:700;flex-shrink:0;
}
.form-panel p.panel-sub{color:var(--r-grey-500);font-size:13.5px;margin-bottom:22px;margin-left:38px}

/* Chip-style multi-select */
.chip-group{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  display:inline-flex;align-items:center;gap:6px;
  background:#fff;border:1.5px solid var(--r-grey-300);color:var(--r-grey-700);
  font-weight:500;font-size:13.5px;padding:9px 16px;border-radius:999px;
  cursor:pointer;transition:all .15s;user-select:none;
}
.chip:hover{border-color:var(--r-red);color:var(--r-red)}
.chip input{display:none}
.chip.active,.chip:has(input:checked){background:var(--r-red);color:#fff;border-color:var(--r-red)}
.chip.active::before,.chip:has(input:checked)::before{content:"✓ ";font-weight:700;margin-right:2px}

/* Team member rows */
.team-row{
  display:grid;grid-template-columns:1.2fr 1.4fr 1fr auto;gap:10px;
  background:var(--r-grey-50);border:1px solid var(--r-grey-100);border-radius:12px;
  padding:14px;margin-bottom:10px;align-items:center;
}
.team-row .form-control,.team-row .form-select{padding:9px 12px;font-size:14px;border-radius:8px}
.team-row .btn-remove{
  background:transparent;border:none;color:var(--r-grey-500);font-size:18px;
  width:36px;height:36px;border-radius:8px;cursor:pointer;transition:all .15s;
}
.team-row .btn-remove:hover{background:var(--r-red-soft);color:var(--r-red)}
.btn-add-team{
  display:inline-flex;align-items:center;gap:8px;background:transparent;
  border:1.5px dashed var(--r-grey-300);color:var(--r-grey-700);
  font-weight:600;font-size:14px;padding:11px 18px;border-radius:10px;cursor:pointer;
  transition:all .2s;
}
.btn-add-team:hover{border-color:var(--r-red);color:var(--r-red);background:var(--r-red-soft)}

/* Summary side card */
.summary-card{
  background:linear-gradient(135deg,var(--r-black) 0%,var(--r-grey-900) 100%);
  color:#fff;border-radius:18px;padding:28px;position:sticky;top:90px;overflow:hidden;
}
.summary-card::after{content:"";position:absolute;right:-50px;bottom:-50px;width:200px;height:200px;background:radial-gradient(circle,var(--r-red) 0%,transparent 70%);opacity:.4}
.summary-card h4{font-size:14px;color:rgba(255,255,255,.6);font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;position:relative}
.summary-card .sum-line{display:flex;justify-content:space-between;font-size:14px;color:rgba(255,255,255,.85);padding:10px 0;border-bottom:1px dashed rgba(255,255,255,.12);position:relative}
.summary-card .sum-line:last-of-type{border-bottom:none}
.summary-card .sum-line b{color:#fff;font-weight:600}
.summary-card .sum-total{display:flex;justify-content:space-between;align-items:baseline;margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.15);position:relative}
.summary-card .sum-total span{color:rgba(255,255,255,.7);font-size:14px}
.summary-card .sum-total b{font-family:'Poppins',sans-serif;font-weight:800;font-size:30px;color:#fff;letter-spacing:-.02em}

/* Engagement banner cards (exhibitor / sponsor / speaker) */
.engage-card{
  background:#fff;border:1.5px solid var(--r-grey-100);border-radius:18px;padding:32px;/*height:100%;*/
  transition:all .25s;display:flex;flex-direction:column;
}
.engage-card:hover{transform:translateY(-4px);border-color:var(--r-red);box-shadow:0 24px 50px -20px rgba(0,0,0,.15)}
.engage-card .e-ic{
  width:52px;height:52px;border-radius:12px;display:grid;place-items:center;
  background:var(--r-red-soft);color:var(--r-red);margin-bottom:16px;font-size:24px;
}
.engage-card h3{font-size:20px;color:var(--r-black);margin-bottom:6px}
.engage-card p.lead{color:var(--r-grey-500);font-size:14px;margin-bottom:18px;flex-grow:1}

/* Tier selector for sponsor */
.tier-select{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.tier-pick{
  background:#fff;border:1.5px solid var(--r-grey-300);border-radius:10px;
  padding:14px 10px;text-align:center;cursor:pointer;transition:all .15s;
}
.tier-pick:hover,.tier-pick.active,.tier-pick:has(input:checked){border-color:var(--r-red);background:var(--r-red-soft)}
.tier-pick input{display:none}
.tier-pick .tname{font-weight:700;font-size:12.5px;color:var(--r-black);letter-spacing:.04em;text-transform:uppercase}
.tier-pick .tprice{font-size:12px;color:var(--r-grey-500);margin-top:3px;font-weight:500}
.tier-pick:has(input:checked) .tname,.tier-pick.active .tname{color:var(--r-red)}

/* Success toast */
.toast-success{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(100px);
  background:var(--r-black);color:#fff;padding:14px 22px;border-radius:12px;
  box-shadow:0 20px 40px -10px rgba(0,0,0,.4);z-index:100;font-weight:500;font-size:14.5px;
  display:flex;align-items:center;gap:10px;opacity:0;transition:opacity .3s, transform .3s;
}
.toast-success.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast-success i{color:var(--r-red);font-size:20px}

@media (max-width: 768px){
  section{padding:60px 0}
  .hero{padding:60px 0 80px}
  .page-hero{padding:60px 0 50px}
  .topbar .meta{display:none}
  .sched-row{grid-template-columns:1fr;gap:8px}
  .team-row{grid-template-columns:1fr;gap:8px}
  .tier-select{grid-template-columns:repeat(2,1fr)}
}
.hero {
  position: relative;
  overflow: hidden;
}
.hero-video-wrap {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-video-wrap video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero-video-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(10,14,30,0.82) 0%,
    rgba(10,14,30,0.60) 55%,
    rgba(10,14,30,0.40) 100%
  );
}
.hero > .container {
  position: relative;
  z-index: 2;
}

/* ── Video Controls ── */
.video-controls {
  position: absolute;
  bottom: 28px;
  right: 28px;
  z-index: 10;
  display: flex;
  gap: 10px;
}
.vid-btn {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.55);
  background: rgba(0,0,0,0.40);
  color: #fff;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: background 0.2s, border-color 0.2s, transform 0.15s;
  flex-shrink: 0;
}
.vid-btn:hover {
  background: rgba(200,30,40,0.75);
  border-color: rgba(200,30,40,0.9);
  transform: scale(1.08);
}
.vid-btn i {
  pointer-events: none;
}
@media (max-width: 576px) {
  .video-controls {
    bottom: 16px;
    right: 16px;
  }
  .vid-btn {
    width: 40px;
    height: 40px;
    font-size: 15px;
  }
}

/* ── Hero Download Buttons ── */
.hero-downloads { margin-top: 28px; }
.btn-dl {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: 6px;
  background: rgba(255,255,255,0.13);
  border: 1.5px solid rgba(255,255,255,0.38);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: background .2s, border-color .2s, transform .15s;
  text-decoration: none;
  white-space: nowrap;
}
.btn-dl i { font-size: 16px; }
.btn-dl:hover {
  background: #c81e28;
  border-color: #c81e28;
  color: #fff;
  transform: translateY(-2px);
}

/* ── Endorsements ── */
.endorsements {
  background: #f4f6f9;
  padding: 72px 0;
}
.endorsements .kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: #c81e28;
  display: block;
  margin-bottom: 8px;
}
.endorsements h2 {
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 800;
  color: #0a0e1e;
  margin-bottom: 10px;
}
.endorsements .sub {
  color: #5a6272;
  font-size: 16px;
  max-width: 580px;
  margin: 0 auto 44px;
}
.endorse-card {
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
  overflow: hidden;
  height: 100%;
  transition: transform .25s, box-shadow .25s;
}
.endorse-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 42px rgba(0,0,0,0.14);
}
.endorse-card img {
  width: 100%;
  height: 550px;
  object-fit: cover;
  object-position: top;
  display: block;
}
.endorse-card .ec-body { padding: 18px 20px 20px; }
.endorse-card .ec-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #c81e28;
  margin-bottom: 5px;
}
.endorse-card h4 { font-size: 15px; font-weight: 700; color: #0a0e1e; margin: 0; }
@media (max-width: 767px) { .endorse-card img { height: 220px; } }

/* ── Partners — dark strip, one row of 6 ── */
.partners-section {
  background: #0a0e1e;
  padding: 56px 0 60px;
}
.partners-section .kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: #c81e28;
  display: block;
  margin-bottom: 8px;
}
.partners-section h2 {
  font-size: clamp(22px, 2.6vw, 34px);
  font-weight: 800;
  color: #fff;
  margin-bottom: 6px;
}
.partners-section .sub {
  color: rgba(255,255,255,.55);
  font-size: 15px;
  margin-bottom: 0;
}
.partner-tier-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255,255,255,.35);
  text-align: center;
  margin: 36px 0 18px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.partner-tier-label::before,
.partner-tier-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255,255,255,.12);
}

/* Silver partner — single centred card */
.silver-partner-wrap {
  display: flex;
  justify-content: center;
  gap: 10px;
}
.partner-logo-silver {
  background: rgba(255,255,255,0.05);
  border: 1.5px solid rgba(255,255,255,0.15);
  border-radius: 10px;
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s, border-color .2s, transform .2s;
}
.partner-logo-silver:hover {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.30);
  transform: translateY(-3px);
}
.partner-logo-silver img {
  height: auto;
  width:100%;
  object-fit: contain;
 /* filter: brightness(0) invert(1);*/
  opacity: .85;
  transition: opacity .2s;
}
.partner-logo-silver:hover img { opacity: 1; }

/* Supporting — 6 per row grid */
.partners-row-6 {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
}
@media (max-width: 991px) {
  .partners-row-6 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 575px) {
  .partners-row-6 { grid-template-columns: repeat(2, 1fr); gap: 10px; }
}
.p-logo-cell {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px;
  /*min-height: 72px;*/
  transition: background .2s, border-color .2s, transform .2s;
}
.p-logo-cell:hover {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.25);
  transform: translateY(-3px);
}
.p-logo-cell img {
  height: auto;
  width: 100%;
  /*max-width: 110px;*/
  object-fit: contain;
  /*filter: brightness(0) invert(1);*/
  /*opacity: .70;*/
  transition: opacity .2s;
}
.p-logo-cell:hover img { opacity: 1; }

:root {
      --navy:    #03093a;
      --red:     #d62020;
      --gold:    #f5a800;
      --cyan:    #00c8ff;
      --white:   #ffffff;
    }

   /* body {
      background: var(--navy);
      font-family: 'Montserrat', sans-serif;
    }*/

    /* ══════════════════════════════════════════
       OUTER WRAPPER
    ══════════════════════════════════════════ */
    .banner-wrap {
      width: 100%;
      display: flex;
      flex-wrap: wrap;
      overflow: hidden;
      position: relative;
    }

    /* ══════════════════════════════════════════
       LEFT HALF
    ══════════════════════════════════════════ */
    .left-half {
      flex: 0 0 50%;
      max-width: 50%;
      background:
        radial-gradient(ellipse 70% 90% at 35% 55%, #1a3a9e 0%, transparent 60%),
        radial-gradient(ellipse 50% 60% at 70% 80%, #6b1a00 0%, transparent 50%),
        linear-gradient(160deg, #04092e 0%, #060d3a 60%, #080e30 100%);
      position: relative;
      display: flex;
      align-items: stretch;
      overflow: hidden;
      padding: 20px 0;
    }

    .left-half::before {
      content: '';
      position: absolute; inset: 0;
      background-image: radial-gradient(circle, rgba(255,255,255,.13) 1px, transparent 1px);
      background-size: 22px 22px;
      pointer-events: none;
      z-index: 0;
    }

    /* ── Logo + copy column ── */
    .left-copy {
      position: relative;
      z-index: 2;
      flex: 0 0 65%;
      padding: 18px 0 14px 22px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
    }

    .logo-date-row {
      display: flex;
      align-items: flex-start;
      flex-wrap: wrap;
      gap: 10px;
      margin-bottom: 15px;
    }

    .logo-outer img {
      width: clamp(100px, 14vw, 170px);
      height: auto;
    }

    .date-pill {
      display: inline-block;
      border: 2px solid var(--cyan);
      border-radius: 8px;
      padding: 5px 14px;
      line-height: 1.15;
      align-self: flex-start;
      animation: pillGlow 3s ease-in-out infinite;
      margin-top: 14px;
    }
    .date-pill .dp-date {
      font-weight: 900;
      font-size: clamp(12px, 1.8vw, 22px);
      color: var(--white);
    }
    .date-pill .dp-venue {
      font-size: clamp(9px, 1vw, 13px);
      color: var(--white);
    }

    .hl-reg {
      font-weight: 800;
      font-size: clamp(18px, 3.5vw, 44px);
      color: var(--white);
      line-height: 1;
      text-transform: uppercase;
      margin-bottom: 1px;
    }

    .hl-win-row {
      display: flex;
      align-items: baseline;
      gap: 8px;
      flex-wrap: wrap;
      margin-bottom: 3px;
    }
    .hl-win {
      font-weight: 900;
      font-size: clamp(32px, 5.5vw, 74px);
      color: var(--gold);
      line-height: 1;
      margin-bottom: -10px;
    }
    .hl-iphone {
      font-weight: 800;
      font-size: clamp(11px, 2vw, 26px);
      color: var(--white);
    }

    .subline {
      font-size: clamp(9px, 1.4vw, 18px);
      color: rgba(255,255,255,.88);
      font-weight: 600;
      margin-bottom: 0;
    }

    .cta-bar {
      border-radius: 20px;
      border: 3px solid var(--gold);
      padding: clamp(6px, 1vw, 8px) clamp(10px, 1.5vw, 20px);
      margin-top: 6px;
      background: linear-gradient(100deg, #d62020 40%, #ff4a4a 50%, #d62020 60%);
      background-size: 200% auto;
      animation: ctaShimmer 3s linear infinite;
    }
    .cta-bar .cta-main {
      font-weight: 800;
      font-size: clamp(10px, 1.6vw, 21px);
      color: var(--white);
    }
    .cta-bar .cta-sub {
      font-size: clamp(8px, .85vw, 11px);
      color: rgba(255,255,255,.9);
      margin-top: 2px;
    }

    /* ── Phone column ── */
    .phone-col {
      flex: 1;
      position: relative;
      z-index: 2;
      display: flex;
      align-items: flex-end;
      justify-content: center;
      padding-bottom: 6px;
    }
    .phone-svg {
      height: clamp(180px, 28vw, 350px);
      animation: phoneFloat 4.5s ease-in-out infinite, phonePulse 3s ease-in-out infinite;
      transform-origin: center bottom;
    }
    .win-tag {
      position: absolute;
      bottom: 28px;
      right: 10px;
      background: var(--gold);
      color: var(--navy);
      font-weight: 900;
      font-size: clamp(12px, 1.8vw, 22px);
      border-radius: 50%;
      width: clamp(44px, 6vw, 80px);
      height: clamp(44px, 6vw, 80px);
      text-align: center;
      line-height: clamp(40px, 5.7vw, 75px);
      border: 2px solid var(--white);
      animation: winPulse 2.5s ease-in-out infinite;
    }

    /* ══════════════════════════════════════════
       RIGHT HALF
    ══════════════════════════════════════════ */
    .right-half {
      flex: 0 0 50%;
      max-width: 50%;
      background:
        radial-gradient(ellipse 60% 70% at 85% 30%, #0d2080 0%, transparent 55%),
        radial-gradient(ellipse 40% 50% at 10% 90%, #0a1560 0%, transparent 50%),
        linear-gradient(160deg, #060d3a 0%, #050b30 100%);
      position: relative;
      padding: 18px clamp(10px, 2vw, 20px) 10px clamp(10px, 2vw, 24px);
      display: flex;
      flex-direction: column;
      overflow: hidden;
    }

    .right-half::before {
      content: '';
      position: absolute; inset: 0;
      background-image: radial-gradient(circle, rgba(255,255,255,.10) 1px, transparent 1px);
      background-size: 22px 22px;
      pointer-events: none;
      z-index: 0;
    }
    .right-half::after {
      content: '';
      position: absolute;
      bottom: -10px; right: -10px;
      width: 260px; height: 140px;
      background: repeating-linear-gradient(-30deg, transparent, transparent 10px, rgba(0,200,255,.08) 10px, rgba(0,200,255,.08) 11px);
      border-radius: 50% 0 0 0;
      pointer-events: none;
      z-index: 0;
    }
    .right-half > * { position: relative; z-index: 1; }

    .how-title {
      font-weight: 900;
      font-size: clamp(14px, 2vw, 26px);
      color: var(--white);
      letter-spacing: .1em;
      text-transform: uppercase;
      margin-bottom: clamp(6px, 1vw, 12px);
    }
    .how-title::after { content: ' ·'; color: var(--cyan); }

    .steps-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: clamp(4px, .7vw, 8px);
      margin-bottom: clamp(6px, 1vw, 10px);
      flex: 1;
    }
    .step-card {
      border: 1.5px solid rgba(0,200,255,.35);
      border-radius: 8px;
      background: rgba(255,255,255,.03);
      padding: clamp(5px, .8vw, 8px) clamp(6px, .9vw, 10px);
      display: flex;
      align-items: flex-start;
      gap: clamp(5px, .7vw, 9px);
      transition: border-color .3s, box-shadow .3s;
    }
    .step-card:hover {
      border-color: rgba(0,200,255,.8);
      box-shadow: 0 0 14px 2px rgba(0,200,255,.3);
    }
    .step-num {
      flex-shrink: 0;
      width: clamp(20px, 2.2vw, 28px);
      height: clamp(20px, 2.2vw, 28px);
      background: var(--gold);
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-weight: 900;
      font-size: clamp(10px, 1.2vw, 16px);
      color: var(--navy);
    }
    .step-text .st-title {
      font-weight: 700;
      font-size: clamp(9px, 1.3vw, 18px);
      color: var(--gold);
      margin-bottom: 2px;
      text-transform: uppercase;
    }
    .step-text .st-desc {
      font-size: clamp(8px, .9vw, 11.5px);
      color: rgba(255,255,255,.9);
      line-height: 1.35;
    }

    .bottom-row {
      display: flex;
      gap: clamp(6px, 1vw, 10px);
      align-items: stretch;
      flex-wrap: wrap;
    }

    .qual-box {
      flex: 1;
      min-width: 120px;
      border: 2px solid var(--cyan);
      border-radius: 8px;
      background: rgba(0,0,0,.3);
      padding: clamp(6px, 1vw, 10px) clamp(8px, 1.2vw, 14px);
      animation: qualBorderPulse 3.5s ease-in-out infinite;
    }
    .qual-label {
      font-weight: 800;
      font-size: clamp(11px, 1.8vw, 30px);
      color: var(--gold);
      text-transform: uppercase;
      margin-bottom: 2px;
    }
    .qual-rule {
      font-weight: 800;
      font-size: clamp(11px, 1.8vw, 30px);
      color: var(--white);
      line-height: 1.05;
      margin-bottom: 3px;
      text-transform: uppercase;
    }
    .qual-note {
      font-size: clamp(8px, .85vw, 11px);
      color: rgba(255,255,255,.75);584
      line-height: 1.4;
    }

    .cta-bar1 {
      border-radius: 20px;
      border: 3px solid var(--gold);
      padding: clamp(6px, .8vw, 8px) clamp(10px, 1.5vw, 20px);
      background: linear-gradient(100deg, #d62020 40%, #ff4a4a 50%, #d62020 60%);
      background-size: 200% auto;
      animation: ctaShimmer 3s linear infinite;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      height: 50px;
    margin-top: 40px;
    }
    .cta-bar1 .cta-main {
      font-weight: 800;
      font-size: clamp(10px, 1.6vw, 21px);
      color: var(--white);
    }
    .cta-bar1 a { color: inherit; text-decoration: none; }

    .footer-strip {
      background: var(--navy);
      text-align: left;
      font-size: clamp(8px, .85vw, 10.5px);
      color: var(--white);
      padding: 6px clamp(10px, 1.5vw, 20px);
      letter-spacing: .03em;
      border-top: 1px solid rgba(255,255,255,.07);
      width: 100%;
      order: 99;
    }

    /* scattered accent dots */
    .adot {
      position: absolute;
      border-radius: 50%;
      z-index: 1;
      animation: particleFloat var(--dur, 4s) ease-in-out infinite;
      animation-delay: var(--del, 0s);
    }

    /* ══════════════════════════════════════════
       MORPHING ORBS
    ══════════════════════════════════════════ */
    @keyframes orbDrift1 {
      0%   { transform: translate(0,0) scale(1);         border-radius: 60% 40% 70% 30% / 50% 60% 40% 50%; }
      33%  { transform: translate(18px,-12px) scale(1.08); border-radius: 40% 60% 30% 70% / 60% 40% 70% 30%; }
      66%  { transform: translate(-10px,16px) scale(.94);  border-radius: 70% 30% 50% 50% / 30% 70% 50% 60%; }
      100% { transform: translate(0,0) scale(1);         border-radius: 60% 40% 70% 30% / 50% 60% 40% 50%; }
    }
    @keyframes orbDrift2 {
      0%   { transform: translate(0,0) scale(1);          border-radius: 50% 50% 40% 60% / 60% 30% 70% 40%; }
      40%  { transform: translate(-14px,10px) scale(1.12); border-radius: 30% 70% 60% 40% / 40% 60% 30% 70%; }
      80%  { transform: translate(10px,-8px) scale(.9);   border-radius: 65% 35% 45% 55% / 55% 45% 65% 35%; }
      100% { transform: translate(0,0) scale(1);          border-radius: 50% 50% 40% 60% / 60% 30% 70% 40%; }
    }
    @keyframes orbDrift3 {
      0%   { transform: translate(0,0) scale(1);  }
      50%  { transform: translate(12px,-14px) scale(1.06); }
      100% { transform: translate(0,0) scale(1);  }
    }

    .morph-orb {
      position: absolute;
      pointer-events: none;
      filter: blur(38px);
      opacity: .55;
      z-index: 0;
    }
    .morph-orb-1  { width: 260px; height: 240px; background: radial-gradient(ellipse, #1a3a9e 0%, transparent 75%); top:-20px; left:-40px; animation: orbDrift1 9s ease-in-out infinite; }
    .morph-orb-2  { width: 220px; height: 200px; background: radial-gradient(ellipse, #8a1500 0%, transparent 75%); bottom:-30px; left:30%; animation: orbDrift2 11s ease-in-out infinite; }
    .morph-orb-3  { width: 180px; height: 180px; background: radial-gradient(ellipse, #f5a800 0%, transparent 80%); top:10%; right:-20px; opacity:.22; animation: orbDrift3 7s ease-in-out infinite; }
    .morph-orb-r1 { width: 240px; height: 220px; background: radial-gradient(ellipse, #0d2080 0%, transparent 75%); top:-30px; right:-20px; animation: orbDrift1 10s ease-in-out infinite reverse; }
    .morph-orb-r2 { width: 200px; height: 180px; background: radial-gradient(ellipse, #00c8ff 0%, transparent 80%); bottom:-20px; left:10%; opacity:.18; animation: orbDrift2 13s ease-in-out infinite; }

    /* ══════════════════════════════════════════
       KEYFRAME ANIMATIONS
    ══════════════════════════════════════════ */
    @keyframes particleFloat {
      0%   { transform: translateY(0) translateX(0) scale(1); opacity:.7; }
      50%  { transform: translateY(-28px) translateX(8px) scale(1.3); opacity:1; }
      100% { transform: translateY(0) translateX(0) scale(1); opacity:.7; }
    }
    @keyframes phoneFloat {
      0%,100% { transform: translateY(0px) rotate(-1.5deg); }
      50%      { transform: translateY(-10px) rotate(1deg); }
    }
    @keyframes phonePulse {
      0%,100% { filter: drop-shadow(0 6px 28px rgba(0,180,255,.4)); }
      50%      { filter: drop-shadow(0 8px 44px rgba(0,200,255,.85)) drop-shadow(0 0 22px rgba(245,168,0,.35)); }
    }
    @keyframes winPulse {
      0%,100% { box-shadow: 0 0 0px rgba(245,168,0,0); }
      50%      { box-shadow: 0 0 18px 4px rgba(245,168,0,.7); }
    }
    @keyframes pillGlow {
      0%,100% { box-shadow: 0 0 0px rgba(0,200,255,0); }
      50%      { box-shadow: 0 0 14px 3px rgba(0,200,255,.55); }
    }
    @keyframes ctaShimmer {
      0%   { background-position: -200% center; }
      100% { background-position: 200% center; }
    }
    @keyframes qualBorderPulse {
      0%,100% { border-color: rgba(0,200,255,.35); box-shadow: 0 0 0 rgba(0,200,255,0); }
      50%      { border-color: rgba(0,200,255,.9);  box-shadow: 0 0 12px 2px rgba(0,200,255,.35); }
    }

    /* ══════════════════════════════════════════
       TABLET  ≤ 900px  — stack vertically
    ══════════════════════════════════════════ */
    @media (max-width: 900px) {
      .banner-wrap { flex-direction: column; }

      .left-half,
      .right-half {
        flex: 0 0 100%;
        max-width: 100%;
        padding: 20px 16px;
      }

      .left-half { padding-bottom: 0; }

      /* On tablet+ the left-half is row: copy | phone */
      .left-copy {
        flex: 1;
        padding: 0 12px 0 0;
      }

      .phone-col { padding-bottom: 0; min-height: 200px; }
      .phone-svg { height: clamp(160px, 30vw, 280px); }

      .win-tag {
        bottom: 8px;
        right: 6px;
        width: clamp(40px, 8vw, 64px);
        height: clamp(40px, 8vw, 64px);
        font-size: clamp(11px, 2.2vw, 18px);
        line-height: clamp(36px, 7.6vw, 60px);
      }

      .steps-grid { grid-template-columns: 1fr 1fr; }

      .footer-strip { text-align: center; }
    }

    /* ══════════════════════════════════════════
       MOBILE  ≤ 600px  — single column, bigger type
    ══════════════════════════════════════════ */
    @media (max-width: 600px) {
      .left-half {
        flex-direction: column;
        padding: 16px 14px 0;
      }

      .left-copy {
        flex: none;
        padding: 0;
        width: 100%;
      }

      /* Phone floats below copy on mobile */
      .phone-col {
        width: 100%;
        justify-content: center;
        padding: 10px 0 0;
        min-height: 220px;
      }
      .phone-svg { height: clamp(180px, 55vw, 260px); }

      .win-tag {
        bottom: 10px;
        right: calc(50% - 140px);
        width: 52px; height: 52px;
        font-size: 14px;
        line-height: 48px;
      }

      .logo-date-row { flex-direction: column; gap: 8px; }

      .logo-outer img { width: clamp(110px, 40vw, 150px); }

      .date-pill {
        padding: 4px 10px;
        margin-left: 0;
      }
      .date-pill .dp-date  { font-size: clamp(14px, 4.5vw, 18px); }
      .date-pill .dp-venue { font-size: clamp(9px, 2.8vw, 12px); }

      .hl-reg   { font-size: clamp(22px, 7vw, 36px); }
      .hl-win   { font-size: clamp(38px, 12vw, 56px); margin-bottom: -8px; }
      .hl-iphone { font-size: clamp(13px, 4vw, 20px); }
      .subline  { font-size: clamp(10px, 3.2vw, 14px); }

      .cta-bar  { border-radius: 14px; }
      .cta-bar .cta-main  { font-size: clamp(11px, 3.5vw, 16px); }
      .cta-bar .cta-sub   { font-size: clamp(8px, 2.4vw, 10px); }

      .right-half {
        padding: 16px 14px 10px;
      }

      .how-title { font-size: clamp(15px, 4.5vw, 20px); margin-bottom: 8px; }

      .steps-grid {
        grid-template-columns: 1fr;
        gap: 6px;
      }

      .step-text .st-title { font-size: clamp(11px, 3.5vw, 15px); }
      .step-text .st-desc  { font-size: clamp(9px, 2.8vw, 12px); }

      .bottom-row { flex-direction: column; gap: 8px; }

      .qual-box { min-width: unset; }
      .qual-label { font-size: clamp(13px, 4vw, 18px); }
      .qual-rule  { font-size: clamp(13px, 4vw, 18px); }
      .qual-note  { font-size: clamp(9px, 2.8vw, 11px); }

      .cta-bar1 { border-radius: 14px; padding: 8px 16px; }
      .cta-bar1 .cta-main { font-size: clamp(13px, 4vw, 18px); }

      .footer-strip {
        font-size: clamp(8px, 2.4vw, 10px);
        text-align: center;
        padding: 8px 10px;
        line-height: 1.6;
      }
    }

    /* ══════════════════════════════════════════
       SMALL MOBILE  ≤ 380px
    ══════════════════════════════════════════ */
    @media (max-width: 380px) {
      .hl-win   { font-size: 34px; }
      .hl-reg   { font-size: 20px; }
      .phone-svg { height: 160px; }
      .win-tag  {
        right: calc(50% - 110px);
        width: 44px; height: 44px;
        font-size: 12px; line-height: 40px;
      }
    }

    /* ══════════════════════════════════════════
       HEADER TITLE SECTION
    ══════════════════════════════════════════ */
    @keyframes titleGlow {
      0%,100% { text-shadow: 0 0 18px rgba(245,168,0,.0), 0 2px 8px rgba(0,0,0,.4); }
      50%      { text-shadow: 0 0 28px rgba(245,168,0,.55), 0 0 60px rgba(0,200,255,.2), 0 2px 8px rgba(0,0,0,.4); }
    }
    @keyframes underlineExpand {
      0%   { width: 0; opacity: 0; }
      100% { width: 80px; opacity: 1; }
    }
    @keyframes fadeSlideDown {
      0%   { opacity: 0; transform: translateY(-18px); }
      100% { opacity: 1; transform: translateY(0); }
    }

    .banner-header {
      width: 100%;
      background:
        radial-gradient(ellipse 60% 120% at 50% 0%, rgba(26,58,158,.5) 0%, transparent 70%),
        linear-gradient(180deg, #02072e 0%, #03093a 100%);
      text-align: center;
      padding: clamp(18px, 3vw, 32px) clamp(16px, 4vw, 40px) clamp(14px, 2.5vw, 26px);
      position: relative;
      overflow: hidden;
      /*border-bottom: 1px solid rgba(0,200,255,.12);*/
    }
    .banner-header::before {
      content: '';
      position: absolute; inset: 0;
      background-image: radial-gradient(circle, rgba(255,255,255,.08) 1px, transparent 1px);
      background-size: 22px 22px;
      pointer-events: none;
    }
   /* .banner-header::after {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 3px;
      background: linear-gradient(90deg, transparent 0%, #00c8ff 30%, #f5a800 60%, transparent 100%);
    }*/

    .bh-label {
      display: inline-block;
      font-size: clamp(9px, 1vw, 11px);
      font-weight: 700;
      letter-spacing: .22em;
      text-transform: uppercase;
      color: #00c8ff;
      background: rgba(0,200,255,.1);
      border: 1px solid rgba(0,200,255,.3);
      border-radius: 20px;
      padding: 3px 14px;
      margin-bottom: clamp(8px, 1.2vw, 12px);
      animation: fadeSlideDown .7s ease both;
      position: relative;
      z-index: 1;
    }

    .bh-title {
      font-family: 'Montserrat', sans-serif;
      font-weight: 900;
      font-size: clamp(20px, 3.8vw, 42px);
      color: #ffffff;
      line-height: 1.1;
      letter-spacing: -.01em;
      margin-bottom: clamp(6px, 1vw, 10px);
      animation: fadeSlideDown .8s ease both, titleGlow 3.5s ease-in-out 1s infinite;
      position: relative;
      z-index: 1;
      text-transform: uppercase;
          width: 950px;
    margin: 0 auto;
    }
    .bh-title .accent-win {
      color: #f5a800;
      position: relative;
    }
    /*.bh-title .accent-win::after {
      content: '';
      position: absolute;
      bottom: -4px; left: 0;
      height: 3px;
      border-radius: 2px;
      background: linear-gradient(90deg, #f5a800, #00c8ff);
      animation: underlineExpand .9s ease 1.2s both;
    }
*/
    .bh-sub {
      font-size: clamp(11px, 1.4vw, 17px);
      font-weight: 500;
      color: rgba(255,255,255,.75);
      /*max-width: 680px;*/
      margin: 0 auto;
      line-height: 1.55;
      animation: fadeSlideDown 1s ease .2s both;
      position: relative;
      z-index: 1;
    }
    .bh-sub strong { color: #ffffff; font-weight: 700; }

    @media (max-width: 600px) {
      .bh-title { font-size: clamp(18px, 6.5vw, 28px); }
      .bh-sub   { font-size: clamp(11px, 3.5vw, 14px); }
    }

    .spk-card {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #f0f0f0;
    transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
    cursor: default;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 28px 20px 24px;
  }
  .spk-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 48px rgba(0,0,0,0.12);
    border-color: var(--r-red, #e63329);
  }
  .spk-photo-wrap {
    width: 110px;
    height: 110px;
    border-radius: 50%;
    overflow: hidden;
    margin: 0 auto 18px;
    border: 3px solid #f0f0f0;
    transition: border-color 0.28s ease;
    flex-shrink: 0;
    background: #e9ecef;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .spk-card:hover .spk-photo-wrap {
    border-color: var(--r-red, #e63329);
  }
  .spk-photo-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .spk-photo-wrap.spk-initials {
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
    background: #2c2c2c;
  }
  .spk-photo-wrap.spk-initials-red {
    font-size: 1.8rem;
    font-weight: 700;
    color: #fff;
    background: var(--r-red, #e63329);
  }
  .spk-badge {
    display: inline-block;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--r-red, #e63329);
    background: rgba(230,51,41,0.08);
    border-radius: 999px;
    padding: 3px 12px;
    margin-bottom: 10px;
  }
  .spk-card h4 {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 6px;
    line-height: 1.3;
    color: #1a1a1a;
  }
  .spk-card .spk-role {
    font-size: 0.82rem;
    color: #666;
    line-height: 1.5;
    margin: 0;
  }
  .spk-card .spk-org {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--r-red, #e63329);
    margin-top: 4px;
  }
  /* Keynote card — slightly larger, centred, no-grid */
  .spk-card.keynote-card {
    max-width: 300px;
    padding: 36px 28px 30px;
  }
  .spk-card.keynote-card .spk-photo-wrap {
    width: 130px;
    height: 130px;
  }
  .spk-card.keynote-card h4 {
    font-size: 1.15rem;
  }
  /* Reveal animation */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ── Registration section (top, dark) ── */
.reg-section{
  background:linear-gradient(135deg,#0A0A0A 0%,#1A1A1A 60%,#2A0A0E 100%);
  position:relative;overflow:hidden;padding:70px 0;
}
.reg-section::before{
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.6) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.6) 1px,transparent 1px);
  background-size:42px 42px;
}
.reg-section::after{
  content:"";position:absolute;top:-100px;right:-100px;width:500px;height:500px;
  background:radial-gradient(circle,rgba(225,29,46,.25) 0%,transparent 70%);pointer-events:none;
}
.reg-section .container{position:relative;z-index:2}

/* Left promo column */
.reg-promo h2{font-size:clamp(26px,3.5vw,42px);color:#fff;margin-bottom:14px;line-height:1.15}
.reg-promo h2 .hl{color:var(--r-red)}
.reg-promo .lead-sub{font-size:16px;color:rgba(255,255,255,.7);line-height:1.65;margin-bottom:28px}
.reg-feat{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.reg-feat .ic{width:42px;height:42px;border-radius:10px;background:rgba(225,29,46,.18);border:1px solid rgba(225,29,46,.35);color:var(--r-red);display:grid;place-items:center;font-size:18px;flex-shrink:0}
.reg-feat span{font-size:14.5px;color:rgba(255,255,255,.82);font-weight:500}

/* Card */
.reg-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:20px;
  overflow:hidden;box-shadow:0 30px 70px -20px rgba(0,0,0,.6);
}
.reg-aside{
  background:#fff;border:1px solid var(--r-grey-100);border-radius:20px;
  overflow:hidden;box-shadow:0 24px 60px -20px rgba(0,0,0,.18);position:sticky;top:96px;
}
.reg-aside-head,.reg-card-head{background:var(--r-red);padding:20px 28px;color:#fff}
.reg-aside-head h3,.reg-card-head h3{font-size:20px;font-weight:700;margin-bottom:2px;color:#fff}
.reg-aside-head p,.reg-card-head p{font-size:13px;opacity:.88;margin:0;color:#fff}
.reg-aside-body,.reg-card-body{padding:28px;background:#fff}
.price-main{font-family:'Poppins';font-weight:800;font-size:46px;color:var(--r-black);letter-spacing:-.03em;line-height:1}
.price-main .cur{font-size:22px;font-weight:700;color:var(--r-grey-500);vertical-align:top;margin-top:6px;display:inline-block}
.price-note{font-size:13px;color:var(--r-grey-500);margin-bottom:6px}
.early-pill{display:inline-block;background:var(--r-red-soft);color:var(--r-red);font-size:12px;font-weight:700;padding:4px 12px;border-radius:999px;letter-spacing:.04em;margin-bottom:20px}
.cform .form-control,.cform .form-select{
  border:1.5px solid var(--r-grey-300);border-radius:10px;padding:13px 16px;font-size:15px;
  transition:border-color .2s,box-shadow .2s;font-family:'Poppins';
}
.cform .form-control:focus,.cform .form-select:focus{
  border-color:var(--r-red);box-shadow:0 0 0 4px rgba(225,29,46,.1);
}
.cform label{font-weight:600;font-size:12.5px;color:var(--r-black);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}
.privacy-note{font-size:11.5px;color:var(--r-grey-500);margin-top:10px;line-height:1.5;text-align:center}
.privacy-note a{color:var(--r-grey-500);text-decoration:underline}

/* ── Day schedule card ── */
.day-card{
  background:#fff;border:1px solid var(--r-grey-100);border-radius:18px;overflow:hidden;
  height:100%;transition:all .25s;
}
.day-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -20px rgba(0,0,0,.12)}
.day-card-head{padding:20px 24px;border-bottom:1px solid var(--r-grey-100);display:flex;align-items:center;gap:18px}
.day-num{font-family:'Poppins';font-weight:800;font-size:48px;color:var(--r-red);line-height:1;min-width:56px}
.day-title{font-size:17px;font-weight:700;color:var(--r-black);line-height:1.25;margin-bottom:4px}
.day-date{font-size:12.5px;color:var(--r-grey-500);font-weight:500}
.day-card-body{padding:22px 24px}
.topic-row{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--r-grey-100);font-size:14.5px;color:var(--r-grey-700);line-height:1.5}
.topic-row:last-child{border-bottom:none;padding-bottom:0}
.topic-row i{color:var(--r-red);margin-top:2px;font-size:14px;flex-shrink:0}

/* ── Who cards ── */
.who-card{
  background:#fff;border:1px solid var(--r-grey-100);border-radius:14px;
  padding:22px 24px;display:flex;gap:16px;align-items:center;height:100%;
  transition:all .2s;
}
.who-card:hover{border-color:var(--r-red);transform:translateY(-3px)}
.who-icon{
  width:52px;height:52px;border-radius:12px;background:var(--r-red-soft);color:var(--r-red);
  display:grid;place-items:center;font-size:22px;flex-shrink:0;
}
.who-card h5{font-size:15px;font-weight:700;color:var(--r-black);margin-bottom:3px}
.who-card p{font-size:13px;color:var(--r-grey-500);margin:0}

/* Included items (get section) */
.get-item{
  background:#fff;border:1px solid var(--r-grey-100);border-radius:16px;
  padding:28px;height:100%;transition:all .25s;
}
.get-item:hover{transform:translateY(-4px);border-color:var(--r-red);box-shadow:0 20px 48px -18px rgba(0,0,0,.13)}
.get-item .get-num{font-family:'Poppins';font-weight:800;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--r-red);margin-bottom:12px}
.get-item h4{font-size:19px;color:var(--r-black);margin-bottom:8px}
.get-item p{font-size:14.5px;color:var(--r-grey-500);line-height:1.65;margin:0}

/* Exhibitor CTA strip (repurposed for contact) */
.cta-strip{background:linear-gradient(135deg,var(--r-black) 0%,var(--r-grey-900) 100%);color:#fff;padding:80px 0;position:relative;overflow:hidden}
.cta-strip::after{content:"";position:absolute;top:-80px;right:-80px;width:380px;height:380px;background:radial-gradient(circle,var(--r-red) 0%,transparent 70%);opacity:.35}
.cta-strip .container{position:relative;z-index:2}
.cta-strip h2{ font-size: 54px; text-transform: uppercase; }
.reg-promo {color: #fff; font-size: 52px;}
.lead-sub {color: #fff;}

@media(max-width:768px){
  section{padding:60px 0}
  .page-hero{padding:60px 0 50px}
  .topbar .meta{display:none}
  .reg-aside{position:static}
}