
/* ═══════════════════════════════════════════════════════════
   THEME HEADER OVERRIDE — Events pages only
   Makes the existing theme header transparent + overlay on hero
   ═══════════════════════════════════════════════════════════ */

/* Force header to sit over the hero */
.prem-events-page #masthead,
.prem-events-page #site-header,
.prem-events-page .site-header,
.prem-events-page header.header,
.prem-events-page #header,
.prem-events-page .main-navigation,
.prem-events-page #main-header,
.prem-events-page .header-main,
.prem-events-page .navbar,
.prem-events-page #navbar {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 400 !important;
    background: transparent !important;
    background-color: transparent !important;
    border-bottom: none !important;
    box-shadow: none !important;
    transition: background .4s ease, backdrop-filter .4s ease !important;
}

/* Scrolled state — add dark glass */
.prem-events-page .header-scrolled #masthead,
.prem-events-page .header-scrolled #site-header,
.prem-events-page .header-scrolled .site-header,
.prem-events-page .header-scrolled header.header,
.prem-events-page .header-scrolled #header,
.prem-events-page .scrolled-header,
.prem-events-page #masthead.scrolled,
.prem-events-page #site-header.scrolled,
.prem-events-page .site-header.scrolled,
.prem-events-page header.header.scrolled,
.prem-events-page #header.scrolled {
    background: rgba(3,14,8,0.92) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
}

/* Make nav links white on transparent header */
.prem-events-page #masthead a,
.prem-events-page #site-header a,
.prem-events-page .site-header a,
.prem-events-page header.header a,
.prem-events-page #header a,
.prem-events-page .main-navigation a,
.prem-events-page #main-header a {
    color: rgba(255,255,255,0.75) !important;
    transition: color .2s !important;
}
.prem-events-page #masthead a:hover,
.prem-events-page #site-header a:hover,
.prem-events-page .site-header a:hover,
.prem-events-page header.header a:hover,
.prem-events-page #header a:hover,
.prem-events-page .main-navigation a:hover,
.prem-events-page #main-header a:hover {
    color: #3DBFB8 !important;
}

/* Logo — invert if dark */
.prem-events-page #masthead .site-logo img,
.prem-events-page #site-header .site-logo img,
.prem-events-page .site-header .custom-logo,
.prem-events-page header .custom-logo {
    filter: brightness(0) invert(1) !important;
    opacity: 0.9;
    transition: filter .4s, opacity .4s !important;
}

/* Push hero content down to account for header height */
.prem-events-wrap .prem-hero,
.prem-single-wrap .prem-single-hero {
    padding-top: 80px !important;
}

/* Hamburger / mobile menu icon — white */
.prem-events-page #masthead .menu-toggle,
.prem-events-page .site-header .menu-toggle,
.prem-events-page header .menu-toggle,
.prem-events-page #masthead button,
.prem-events-page .site-header button:not(.prem-btn-hero-white):not(.prem-btn-primary) {
    color: rgba(255,255,255,0.75) !important;
    border-color: rgba(255,255,255,0.2) !important;
}

/* Dark mode toggle — make visible */
.prem-events-page .dark-mode-toggle,
.prem-events-page .color-scheme-toggle {
    filter: invert(1) !important;
    opacity: 0.7 !important;
}

/* Search icon — white */
.prem-events-page #masthead .search-toggle,
.prem-events-page .site-header .search-icon {
    color: rgba(255,255,255,0.75) !important;
}

/* Remove any white background on header inner wrappers */
.prem-events-page #masthead .site-branding,
.prem-events-page #masthead .header-inner,
.prem-events-page #masthead .container,
.prem-events-page #masthead nav,
.prem-events-page .site-header .header-inner,
.prem-events-page .site-header .container,
.prem-events-page .site-header nav {
    background: transparent !important;
    background-color: transparent !important;
}
/* ═══════════════════════════════════════════════════════════
   PREMBLY EVENTS PLUGIN — CSS
   Plaid-inspired design with Prembly dark green palette
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,700;1,800;1,900&display=swap');

:root {
  --prem-green-darkest: #030e08;
  --prem-green-dark:    #0C2D25;
  --prem-green-mid:     #163D30;
  --prem-green-light:   #082018;
  --prem-teal:          #3DBFB8;
  --prem-teal-dark:     #2A9490;
  --prem-white:         #ffffff;
  --prem-gray-50:       #f9fafb;
  --prem-gray-100:      #f3f4f6;
  --prem-gray-200:      #e5e7eb;
  --prem-gray-300:      #d1d5db;
  --prem-gray-400:      #9ca3af;
  --prem-gray-500:      #6b7280;
  --prem-gray-700:      #374151;
  --prem-gray-800:      #1f2937;
  --prem-gray-900:      #111827;
  --radius-pill:        999px;
  --radius-card:        14px;
}

*,*::before,*::after{box-sizing:border-box}

/* ── SCROLL PROGRESS BAR ── */
#prem-scroll-bar{
  position:fixed;top:0;left:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--prem-teal),#2dba7a,#a78bfa,var(--prem-teal));
  background-size:300%;z-index:9999;pointer-events:none;transition:width .08s;
  animation:spFlow 3s linear infinite;
}
@keyframes spFlow{0%{background-position:0%}100%{background-position:300%}}

/* ═══════════════════════════════════════════════════════════
   EVENTS LISTING PAGE (archive-events.php)
   ═══════════════════════════════════════════════════════════ */

.prem-events-wrap {
  font-family: 'Inter', sans-serif;
  background: #fff;
  min-height: 100vh;
}

/* ── HERO ── */
.prem-hero {
  background: var(--prem-green-darkest);
  min-height: 720px;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0 48px;
}
.prem-hero-canvas { position:absolute;inset:0;width:100%;height:100%;z-index:0 }
.prem-hero-blob {
  position:absolute;border-radius:50%;pointer-events:none;z-index:0;
}
.prem-hero-blob-1 {
  width:600px;height:400px;top:-100px;right:-100px;
  background:radial-gradient(ellipse,rgba(61,191,184,0.12) 0%,transparent 65%);
}
.prem-hero-blob-2 {
  width:500px;height:500px;bottom:-150px;left:-80px;
  background:radial-gradient(ellipse,rgba(45,186,122,0.10) 0%,transparent 65%);
  animation:blobFloat 10s ease-in-out infinite reverse;
}
@keyframes blobFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-24px)}}
.prem-cursor-glow {
  position:absolute;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(61,191,184,0.07) 0%,transparent 70%);
  pointer-events:none;z-index:1;
  transform:translate(-50%,-50%);
  transition:left .18s ease,top .18s ease;
}

.prem-hero-inner {
  position:relative;z-index:2;
  max-width:1100px;margin:0 auto;width:100%;
  padding:100px 0 100px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
}
.prem-hero-eyebrow {
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--prem-teal);margin-bottom:28px;
  opacity:0;animation:fadeUp .6s .1s cubic-bezier(.4,0,.2,1) forwards;
}
.prem-hero-eyebrow-dot {
  width:6px;height:6px;border-radius:50%;background:var(--prem-teal);
  animation:dotBlink 2s infinite;
}
@keyframes dotBlink{0%,100%{opacity:1}50%{opacity:0.3}}
.prem-hero-h1 {
  font-size:68px;font-weight:900;
  background:linear-gradient(135deg,#ffffff 0%,rgba(255,255,255,0.85) 40%,var(--prem-teal) 100%);
  background-size:200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:gradShift 4s ease infinite;
  line-height:1.0;letter-spacing:-0.04em;margin-bottom:24px;
  opacity:0;animation:fadeUp .7s .2s cubic-bezier(.4,0,.2,1) forwards,gradShift 4s 1s ease infinite;
}
@keyframes gradShift{0%{background-position:0%}50%{background-position:100%}100%{background-position:0%}}
.prem-hero-sub {
  font-size:17px;color:rgba(255,255,255,0.45);
  max-width:620px;line-height:1.8;font-weight:400;
  margin-bottom:72px;
  opacity:0;animation:fadeUp .7s .35s cubic-bezier(.4,0,.2,1) forwards;
}

/* ── FEATURED CARD ── */
.prem-feature-wrap {
  position:relative;z-index:2;
  max-width:1000px;width:100%;margin:0 auto;
  opacity:0;animation:fadeUp .9s .5s cubic-bezier(.4,0,.2,1) forwards;
}
.prem-feature-wrap::before {
  content:'';position:absolute;inset:-1px;border-radius:17px;
  background:linear-gradient(135deg,rgba(61,191,184,0.3),rgba(45,186,122,0.2),transparent 60%);
  z-index:-1;filter:blur(1px);
}
.prem-feature-wrap::after {
  content:'';position:absolute;inset:-8px;border-radius:22px;z-index:-2;
  background:radial-gradient(ellipse,rgba(61,191,184,0.12) 0%,transparent 70%);
  animation:cardGlow 3s ease-in-out infinite;filter:blur(8px);
}
@keyframes cardGlow{0%,100%{opacity:.5}50%{opacity:1}}
.prem-feature-card {
  display:grid;grid-template-columns:1fr 1fr;
  border-radius:16px;overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,0.6),0 4px 20px rgba(0,0,0,0.4);
}
.prem-fc-left {
  background:var(--prem-green-light);
  position:relative;overflow:hidden;
  min-height:420px;display:flex;flex-direction:column;
  justify-content:space-between;padding:40px 44px;
}
.prem-fc-canvas { position:absolute;inset:0;width:100%;height:100% }
.prem-fc-left::after {
  content:'';position:absolute;bottom:-60px;left:0;right:0;height:180px;
  background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(61,191,184,0.15) 0%,transparent 70%);
  pointer-events:none;z-index:1;animation:innerGlow 4s ease-in-out infinite;
}
@keyframes innerGlow{0%,100%{opacity:.6}50%{opacity:1}}
.prem-fc-loc-row { position:relative;z-index:2;text-align:center }
.prem-fc-loc {
  display:block;font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.45);margin-bottom:2px;
}
.prem-fc-date-label {
  font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.45);
}
.prem-fc-name-row {
  position:relative;z-index:2;display:flex;align-items:center;gap:18px;
}
.prem-fc-name-text {
  font-size:64px;font-weight:900;color:#fff;
  letter-spacing:-0.04em;line-height:0.95;font-style:italic;
  text-shadow:0 0 80px rgba(61,191,184,0.15);
}
.prem-fc-badge {
  width:72px;height:72px;border-radius:50%;flex-shrink:0;
  background:rgba(61,191,184,0.15);
  border:1.5px solid rgba(61,191,184,0.4);
  backdrop-filter:blur(16px);
  color:#fff;font-size:22px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  letter-spacing:-0.02em;
  animation:badgePulse 2.8s ease-in-out infinite;
}
@keyframes badgePulse{
  0%,100%{box-shadow:0 0 12px rgba(61,191,184,0.3)}
  50%{box-shadow:0 0 32px rgba(61,191,184,0.7)}
}
.prem-fc-right {
  background:#fff;padding:56px 56px;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.prem-fc-right::before {
  content:'';position:absolute;top:-60px;left:-60px;width:200px;height:200px;
  background:radial-gradient(ellipse,rgba(61,191,184,0.06) 0%,transparent 70%);
  pointer-events:none;
}
.prem-fc-label {
  font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--prem-teal);margin-bottom:14px;
  display:flex;align-items:center;gap:6px;
}
.prem-fc-label::before { content:'';width:18px;height:1.5px;background:var(--prem-teal) }
.prem-fc-title {
  font-size:32px;font-weight:800;color:var(--prem-green-dark);
  line-height:1.2;letter-spacing:-0.03em;margin-bottom:20px;
}
.prem-fc-desc {
  font-size:15px;color:#64748B;line-height:1.85;margin-bottom:40px;font-weight:400;
}
.prem-fc-cta {
  display:flex;flex-direction:column;gap:6px;width:fit-content;
}
.prem-btn-recap {
  display:inline-flex;align-items:center;gap:12px;
  font-size:18px;font-weight:700;color:var(--prem-green-dark);
  background:none;border:none;cursor:pointer;
  font-family:'Inter',sans-serif;padding:0;
  transition:color .25s;
}
.prem-btn-recap:hover { color:var(--prem-teal) }
.prem-btn-circle {
  width:40px;height:40px;border-radius:50%;
  border:2px solid var(--prem-green-dark);
  display:flex;align-items:center;justify-content:center;
  transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;
  position:relative;overflow:hidden;
}
.prem-btn-circle::after {
  content:'';position:absolute;inset:0;border-radius:50%;
  background:var(--prem-teal);transform:scale(0);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.prem-btn-recap:hover .prem-btn-circle { border-color:var(--prem-teal);transform:translateX(4px) }
.prem-btn-recap:hover .prem-btn-circle::after { transform:scale(1) }
.prem-btn-circle svg { position:relative;z-index:1;transition:stroke .3s }
.prem-btn-recap:hover .prem-btn-circle svg { stroke:#fff }
.prem-fc-sub-label { font-size:12px;color:#9CA3AF;font-weight:400 }

/* ── ALL EVENTS SECTION ── */
.prem-all-events {
  background:#f2f2ee;padding:104px 56px 120px;
  position:relative;
}
.prem-all-events::before {
  content:'';position:absolute;top:0;left:56px;right:56px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(61,191,184,0.2),transparent);
}
.prem-ae-inner { max-width:1200px;margin:0 auto }
.prem-ae-title {
  font-size:60px;font-weight:900;color:var(--prem-green-dark);
  letter-spacing:-0.04em;margin-bottom:72px;
  position:relative;display:inline-block;
  opacity:0;transform:translateY(28px);
  transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1);
}
.prem-ae-title.prem-vis { opacity:1;transform:none }
.prem-ae-title::after {
  content:'';position:absolute;bottom:-6px;left:0;width:0;height:4px;
  background:linear-gradient(90deg,var(--prem-teal),#2dba7a);
  border-radius:2px;
  transition:width .9s cubic-bezier(.4,0,.2,1) .4s;
}
.prem-ae-title.prem-vis::after { width:100% }

.prem-ae-layout {
  display:grid;grid-template-columns:200px 1fr;gap:64px;align-items:start;
}

/* ── FILTER SIDEBAR ── */
.prem-ae-filters { position:sticky;top:80px }
.prem-ae-filters { position:sticky !important; top:80px !important; }
.prem-ae-filter-sec { margin-bottom:24px !important; padding-bottom:0 !important; }
.prem-ae-filter-title {
  font-size:10px !important; font-weight:700 !important;
  color:#9ca3af !important; margin-bottom:4px !important;
  letter-spacing:0.12em !important; text-transform:uppercase !important;
  padding-left:12px !important; display:block !important;
}
.prem-ae-filter-opt {
  display:block !important; width:100% !important; text-align:left !important;
  font-size:14px !important; color:#111827 !important;
  padding:9px 12px 9px 12px !important;
  border:none !important; background:transparent !important;
  cursor:pointer !important; font-family:inherit !important;
  line-height:1.4 !important; position:relative !important;
  border-left:3px solid transparent !important;
  font-weight:500 !important; margin-bottom:1px !important;
  border-radius:0 8px 8px 0 !important;
  transition:all .15s !important;
  box-sizing:border-box !important;
  -webkit-appearance:none !important;
  appearance:none !important;
}
.prem-ae-filter-opt:hover {
  color:#0C2D25 !important;
  border-left-color:rgba(61,191,184,0.5) !important;
  background:rgba(12,45,37,0.07) !important;
}
.prem-ae-filter-opt.active {
  color:#0C2D25 !important;
  font-weight:700 !important;
  border-left-color:#3DBFB8 !important;
  background:rgba(61,191,184,0.1) !important;
}

/* Filter tabs (mobile) */
.prem-filter-tabs {
  display:none;
  align-items:center;gap:2px;background:#EFEFEF;
  border-radius:999px;padding:4px;margin-bottom:24px;
}
.prem-filter-tab {
  padding:8px 20px;border-radius:999px;font-size:13px;font-weight:500;
  color:var(--prem-gray-500);border:none;background:transparent;
  cursor:pointer;transition:background .18s,color .18s,box-shadow .18s;
  font-family:'Inter',sans-serif;white-space:nowrap;
}
.prem-filter-tab:hover { color:var(--prem-gray-900) }
.prem-filter-tab.active {
  background:#fff;color:var(--prem-teal);font-weight:700;
  box-shadow:0 1px 3px rgba(0,0,0,.15);
}

/* ── EVENT CARDS GRID ── */
.prem-events-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}

/* Card */
.prem-ev-card{
  display:flex;
  flex-direction:column;
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  text-decoration:none;
  color:inherit;
  border:1px solid rgba(0,0,0,0.05);
  box-shadow:0 2px 8px rgba(0,0,0,0.04);
  transition:transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s;
  opacity:0;
  transform:translateY(40px);
  cursor:pointer;
}
.prem-ev-card.prem-vis{
  opacity:1;
  transform:translateY(0);
}
.prem-ev-card:hover{
  transform:translateY(-8px);
  box-shadow:0 20px 56px rgba(12,45,37,0.12), 0 0 0 1.5px rgba(61,191,184,0.18);
  text-decoration:none;
  color:inherit;
}

/* Image area — always 190px, never collapses */
.prem-ev-card-img{
  position:relative;
  height:190px;
  flex-shrink:0;
  overflow:hidden;
}
.prem-ev-card-img img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .5s cubic-bezier(.4,0,.2,1);
  z-index:1;
}
.prem-ev-card:hover .prem-ev-card-img img{transform:scale(1.06)}
.prem-ev-card-img canvas{
  position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block;
}
/* Dark gradient overlay on image */
.prem-ev-card-img::after{
  content:'';position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg, rgba(0,0,0,0.08) 0%, rgba(0,0,0,0.4) 100%);
  transition:opacity .3s;
}
.prem-ev-card:hover .prem-ev-card-img::after{opacity:0.7}

/* Tags */
.prem-ev-card-tags{
  position:absolute;top:14px;left:14px;right:14px;
  display:flex;justify-content:space-between;align-items:center;
  z-index:3;
  gap:8px;
}
.prem-ev-tag-loc,
.prem-ev-tag-type{
  font-size:9px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  padding:4px 10px;border-radius:20px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:48%;
}
.prem-ev-tag-loc{
  color:rgba(255,255,255,0.92);
  background:rgba(0,0,0,0.4);
  border:1px solid rgba(255,255,255,0.12);
  backdrop-filter:blur(8px);
}
.prem-ev-tag-type{
  border:1px solid rgba(255,255,255,0.2);
  color:#fff;
  background:rgba(0,0,0,0.3);
  backdrop-filter:blur(8px);
}
.prem-tag-summit{background:rgba(61,191,184,0.75)!important}
.prem-tag-webinar{background:rgba(99,102,241,0.75)!important}
.prem-tag-workshop{background:rgba(245,158,11,0.75)!important}
.prem-tag-roundtable{background:rgba(236,72,153,0.75)!important}

/* Live badge */
.prem-ev-live-badge{
  position:absolute;bottom:14px;left:14px;z-index:3;
  font-size:9px;font-weight:700;letter-spacing:0.1em;
  color:#fff;background:#ef4444;
  padding:4px 10px;border-radius:20px;
  animation:livePulse 1.5s ease-in-out infinite;
}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.5}}

/* Body — grows to fill remaining space */
.prem-ev-card-body{
  display:flex;
  flex-direction:column;
  flex:1;
  padding:22px 22px 20px;
}
.prem-ev-card-series{
  font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  color:#3DBFB8;margin-bottom:10px;
  display:flex;align-items:center;gap:7px;
}
.prem-ev-card-series::before{
  content:'';width:14px;height:1.5px;
  background:#3DBFB8;flex-shrink:0;
}
.prem-ev-card-title{
  font-size:16px;font-weight:700;color:#0C2D25;
  line-height:1.35;margin:0 0 10px;letter-spacing:-0.02em;
  display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden;
  transition:color .2s;
}
.prem-ev-card:hover .prem-ev-card-title{color:#3DBFB8}
.prem-ev-card-desc{
  font-size:13px;color:#6b7280;line-height:1.75;
  margin:0 0 20px;flex:1;
  display:-webkit-box;-webkit-line-clamp:3;
  -webkit-box-orient:vertical;overflow:hidden;
}
.prem-ev-card-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:16px;border-top:1px solid #f3f4f6;
  margin-top:auto;gap:8px;
}
.prem-ev-card-date{
  font-size:12px;color:#9ca3af;font-weight:500;
}
.prem-ev-card-btn{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:700;color:#0C2D25;
  white-space:nowrap;flex-shrink:0;
  transition:color .2s, gap .2s;
}
.prem-ev-card:hover .prem-ev-card-btn{color:#3DBFB8;gap:11px}
.prem-ev-card-btn-circle{
  width:28px;height:28px;border-radius:50%;
  border:2px solid currentColor;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;position:relative;overflow:hidden;
  transition:all .3s cubic-bezier(.4,0,.2,1);
}
.prem-ev-card-btn-circle::after{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:#3DBFB8;transform:scale(0);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.prem-ev-card:hover .prem-ev-card-btn-circle{border-color:#3DBFB8;transform:rotate(45deg)}
.prem-ev-card:hover .prem-ev-card-btn-circle::after{transform:scale(1)}
.prem-ev-card-btn-circle svg{position:relative;z-index:1;transition:stroke .3s}
.prem-ev-card:hover .prem-ev-card-btn-circle svg{stroke:#fff}

/* No events */
.prem-no-events {
  grid-column:1/-1;text-align:center;padding:64px 0;
  color:var(--prem-gray-400);font-size:15px;
}

/* ═══════════════════════════════════════════════════════════
   SINGLE EVENT PAGE (single-event.php)
   ═══════════════════════════════════════════════════════════ */

.prem-single-wrap {
  font-family:'Inter',sans-serif;
  background:var(--prem-green-darkest);
  min-height:100vh;color:#fff;
}

/* Single hero */
.prem-single-hero {
  min-height:100vh;background:var(--prem-green-darkest);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:80px 48px;text-align:center;
}
.prem-single-hero-canvas { position:absolute;inset:0;width:100%;height:100%;z-index:0 }
.prem-single-grid-canvas { position:absolute;bottom:0;left:0;right:0;height:55%;z-index:0;opacity:.7 }
.prem-single-hero-inner { position:relative;z-index:2;max-width:900px;width:100% }
.prem-single-eyebrow {
  font-size:11px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(255,255,255,0.4);margin-bottom:16px;
  display:flex;align-items:center;justify-content:center;gap:16px;
}
.prem-single-event-name {
  font-size:96px;font-weight:900;color:rgba(255,255,255,0.55);
  letter-spacing:-0.05em;line-height:.92;font-style:italic;margin-bottom:8px;
  opacity:0;animation:fadeUp .7s .2s cubic-bezier(.4,0,.2,1) forwards;
}
.prem-single-badge {
  width:72px;height:72px;border-radius:50%;
  background:rgba(61,191,184,0.15);
  border:1.5px solid rgba(61,191,184,0.4);
  backdrop-filter:blur(12px);color:#fff;
  font-size:22px;font-weight:800;
  display:inline-flex;align-items:center;justify-content:center;
  animation:badgePulse 3s ease-in-out infinite;
  vertical-align:middle;
}
.prem-single-meta-line {
  font-size:13px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;
  color:rgba(255,255,255,0.45);margin-bottom:28px;
  opacity:0;animation:fadeUp .6s .3s cubic-bezier(.4,0,.2,1) forwards;
}
.prem-single-subtitle {
  font-size:36px;font-weight:800;color:#fff;
  letter-spacing:-0.03em;line-height:1.15;margin-bottom:16px;
  font-style:italic;
  opacity:0;animation:fadeUp .7s .4s cubic-bezier(.4,0,.2,1) forwards;
}
.prem-single-desc {
  font-size:16px;color:rgba(255,255,255,0.4);
  max-width:600px;margin:0 auto 48px;line-height:1.8;
  opacity:0;animation:fadeUp .7s .5s cubic-bezier(.4,0,.2,1) forwards;
}
.prem-single-ctas {
  display:flex;align-items:center;justify-content:center;gap:14px;
  opacity:0;animation:fadeUp .7s .6s cubic-bezier(.4,0,.2,1) forwards;
}
/* Featuring strip */
.prem-single-featuring {
  background:var(--prem-green-darkest);
  border-top:1px solid rgba(255,255,255,0.05);
  border-bottom:1px solid rgba(255,255,255,0.05);
  padding:24px 40px;display:flex;align-items:center;gap:36px;overflow:hidden;
}
.prem-single-feat-label {
  font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.25);white-space:nowrap;flex-shrink:0;
}
.prem-single-feat-divider { width:1px;height:28px;background:rgba(255,255,255,0.1);flex-shrink:0 }
.prem-single-feat-logos {
  display:flex;align-items:center;gap:48px;
  animation:logoScroll 20s linear infinite;flex-wrap:nowrap;
}
@keyframes logoScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.prem-single-feat-logo {
  font-size:14px;font-weight:700;color:rgba(255,255,255,0.35);
  white-space:nowrap;flex-shrink:0;letter-spacing:-0.01em;
  transition:color .2s;
}
.prem-single-feat-logo:hover { color:rgba(255,255,255,0.65) }

/* Buttons */
.prem-btn-primary {
  padding:14px 40px;
  background:linear-gradient(135deg,var(--prem-teal),#2dba7a);
  color:#fff;border:none;border-radius:999px;
  font-size:15px;font-weight:700;cursor:pointer;
  font-family:'Inter',sans-serif;transition:all .25s;
  box-shadow:0 0 32px rgba(61,191,184,0.4);
  position:relative;overflow:hidden;display:inline-block;
  text-decoration:none;
}
.prem-btn-primary:hover { transform:translateY(-2px);box-shadow:0 8px 40px rgba(61,191,184,0.6);color:#fff }
.prem-btn-hero-white {
  display:inline-flex;align-items:center;
  padding:15px 48px;color:var(--prem-gray-900);background:#fff;
  border-radius:999px;font-size:16px;font-weight:700;
  cursor:pointer;font-family:'Inter',sans-serif;border:none;
  transition:transform .25s,box-shadow .25s;
  position:relative;text-decoration:none;
}
.prem-btn-hero-white::before {
  content:'';position:absolute;inset:-2px;border-radius:999px;
  background:linear-gradient(135deg,#f9c846,var(--prem-teal),#a78bfa);z-index:-1;
}
.prem-btn-hero-white::after {
  content:'';position:absolute;inset:2px;border-radius:999px;background:#fff;z-index:-1;
}
.prem-btn-hero-white:hover { transform:translateY(-2px);color:var(--prem-green-dark) }
.prem-btn-ghost {
  padding:14px 40px;background:transparent;
  color:rgba(255,255,255,0.7);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:999px;font-size:15px;font-weight:600;
  cursor:pointer;font-family:'Inter',sans-serif;
  transition:all .25s;text-decoration:none;display:inline-block;
}
.prem-btn-ghost:hover { border-color:rgba(61,191,184,0.5);color:#fff;background:rgba(61,191,184,0.08) }

/* Agenda sections */
.prem-agenda-banner {
  background:linear-gradient(135deg,#0a1f12 0%,var(--prem-green-darkest) 50%,#082018 100%);
  padding:100px 48px;text-align:center;
  border-top:1px solid rgba(255,255,255,0.05);
}
.prem-agenda-banner-title {
  font-size:60px;font-weight:900;color:#fff;
  letter-spacing:-0.04em;line-height:1.1;
  opacity:0;transform:translateY(24px);transition:opacity .6s,transform .6s;
}
.prem-agenda-banner-title.prem-vis { opacity:1;transform:none }
.prem-agenda-sec {
  padding:100px 48px;border-top:1px solid rgba(255,255,255,0.05);
  background:var(--prem-green-darkest);position:relative;overflow:hidden;
}
.prem-agenda-sec.prem-alt { background:#0a1f12 }
.prem-agenda-sec > img { position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;z-index:0 }
.prem-agenda-sec-inner {
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 460px;gap:80px;align-items:start;
  position:relative;z-index:1;
}
.prem-agenda-sec-label {
  font-size:11px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(255,255,255,0.4);margin-bottom:18px;display:block;
}
.prem-agenda-sec-title {
  font-size:44px;font-weight:900;color:#fff;
  letter-spacing:-0.04em;line-height:1.1;margin-bottom:44px;
  opacity:0;transform:translateY(20px);transition:opacity .6s,transform .6s;
}
.prem-agenda-sec-title.prem-vis { opacity:1;transform:none }
.prem-agenda-divider { height:1px;background:rgba(255,255,255,0.08);margin:0 0 32px }
.prem-agenda-list { display:flex;flex-direction:column }
.prem-agenda-row {
  display:grid;grid-template-columns:130px 1fr;gap:28px;align-items:start;
  padding:22px 0;border-bottom:1px solid rgba(255,255,255,0.07);
  opacity:0;transform:translateX(-12px);transition:opacity .4s,transform .4s;
  cursor:default;
}
.prem-agenda-row.prem-vis { opacity:1;transform:none }
.prem-agenda-row:last-child { border-bottom:none }
.prem-agenda-row:hover {
  background:rgba(61,191,184,0.025);border-radius:10px;
  padding-left:12px;padding-right:12px;margin:0 -12px;
}
.prem-agenda-row:hover .prem-agenda-pill {
  background:rgba(61,191,184,0.12);border-color:rgba(61,191,184,0.3);
}
.prem-agenda-pill {
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.1);
  border-radius:10px;padding:10px 16px;
  font-size:13px;font-weight:700;color:rgba(255,255,255,0.75);
  white-space:nowrap;min-width:120px;letter-spacing:0.04em;
  height:fit-content;transition:background .2s,border-color .2s;
}
.prem-agenda-row-title { font-size:16px;font-weight:700;color:#fff;margin-bottom:7px;letter-spacing:-0.01em }
.prem-agenda-row-desc { font-size:14px;color:rgba(255,255,255,0.45);line-height:1.65 }
/* Sticky agenda visual */
.prem-agenda-visual { position:sticky;top:90px;align-self:start }
.prem-agenda-visual img {
  display:block;width:100%;height:520px;
  object-fit:contain;object-position:center bottom;
  -webkit-mask-image:radial-gradient(ellipse 80% 90% at 55% 55%,black 40%,rgba(0,0,0,.6) 60%,transparent 80%);
  mask-image:radial-gradient(ellipse 80% 90% at 55% 55%,black 40%,rgba(0,0,0,.6) 60%,transparent 80%);
}
.prem-agenda-visual-canvas { display:block;width:100%;height:460px;border-radius:16px }

/* Registration section */
.prem-reg-sec {
  background:#020b06;padding:120px 48px 120px;
  border-top:1px solid rgba(255,255,255,0.05);position:relative;overflow:hidden;
}
.prem-reg-sec::before {
  content:'';position:absolute;top:-300px;right:-200px;width:700px;height:700px;
  border-radius:50%;background:radial-gradient(ellipse,rgba(61,191,184,0.06) 0%,transparent 65%);
  pointer-events:none;
}
.prem-reg-inner { max-width:1200px;margin:0 auto }
.prem-reg-title {
  font-size:48px;font-weight:900;color:#fff;
  letter-spacing:-0.04em;text-align:center;margin-bottom:12px;
  opacity:0;transform:translateY(24px);transition:opacity .6s,transform .6s;
}
.prem-reg-title.prem-vis { opacity:1;transform:none }
.prem-reg-sub { font-size:16px;color:rgba(255,255,255,0.35);text-align:center;margin-bottom:56px }
.prem-reg-layout { display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start }

/* Attend cards */
.prem-attend-stack { display:flex;flex-direction:column;gap:20px }
.prem-attend-card {
  border-radius:20px;overflow:hidden;cursor:pointer;position:relative;
  transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;
}
.prem-attend-card:hover { transform:translateY(-4px) }
.prem-attend-card.sel:hover { box-shadow:0 16px 48px rgba(61,191,184,0.2) }
.prem-attend-card.sel {
  padding:2px;
  background:linear-gradient(135deg,var(--prem-teal),#a78bfa,#f472b6,#f9c846,var(--prem-teal));
  animation:cGlow 3s ease-in-out infinite;
}
@keyframes cGlow{
  0%,100%{box-shadow:0 0 20px rgba(61,191,184,0.15)}
  50%{box-shadow:0 0 40px rgba(61,191,184,0.3),0 0 80px rgba(167,139,250,0.1)}
}
.prem-attend-card.sel::after {
  content:'';position:absolute;inset:0;border-radius:18px;
  background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,0.05) 50%,transparent 70%);
  background-size:250% 100%;animation:cShimmer 4s ease-in-out infinite;
  pointer-events:none;z-index:5;
}
@keyframes cShimmer{0%{background-position:200% 0}70%,100%{background-position:-100% 0}}
.prem-attend-card:not(.sel) {
  border:1px solid rgba(61,191,184,0.15);
  background:linear-gradient(135deg,#082018 0%,var(--prem-green-dark) 60%,#0a1f12 100%);
}
.prem-ac-inner {
  border-radius:18px;overflow:hidden;position:relative;
  background:linear-gradient(145deg,#080f28 0%,#0c1a40 35%,#0a1535 60%,#0d1e48 100%);
}
.prem-attend-card:not(.sel) .prem-ac-inner {
  background:linear-gradient(135deg,#082018 0%,var(--prem-green-dark) 60%,#0a1f12 100%);
}
.prem-ac-bg { position:absolute;inset:0;z-index:0;overflow:hidden }
.prem-ac-bg-t {
  position:absolute;top:0;left:0;width:100%;height:55%;
  object-fit:cover;object-position:top;opacity:0.55;
}
.prem-ac-bg-b {
  position:absolute;bottom:0;left:0;width:100%;height:55%;
  object-fit:cover;object-position:bottom;opacity:0.55;
}
.prem-ac-overlay {
  position:absolute;inset:0;
  background:linear-gradient(145deg,rgba(6,12,32,0.88) 0%,rgba(8,18,48,0.78) 40%,rgba(6,12,32,0.65) 100%);
}
.prem-attend-card:not(.sel) .prem-ac-bg-t,
.prem-attend-card:not(.sel) .prem-ac-bg-b { display:none }
.prem-attend-card:not(.sel) .prem-ac-overlay { background:transparent }
.prem-ac-portrait {
  position:absolute;bottom:0;right:0;width:52%;height:auto;
  object-fit:contain;object-position:bottom right;z-index:1;pointer-events:none;
  -webkit-mask-image:linear-gradient(to left,rgba(0,0,0,0.9) 20%,rgba(0,0,0,0.55) 50%,transparent 78%);
  mask-image:linear-gradient(to left,rgba(0,0,0,0.9) 20%,rgba(0,0,0,0.55) 50%,transparent 78%);
}
.prem-attend-card:not(.sel) .prem-ac-portrait { display:none }
.prem-ac-content { position:relative;z-index:2;padding:36px 40px 0 }
.prem-ac-row1 { display:flex;align-items:center;justify-content:space-between;margin-bottom:20px }
.prem-ac-type { font-size:52px;font-weight:300;color:#fff;letter-spacing:-0.04em;line-height:1 }
.prem-attend-card.sel .prem-ac-badge {
  background:rgba(160,240,235,0.88);color:#082828;
  font-size:11px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;
  padding:12px 22px;border-radius:10px;flex-shrink:0;
  animation:bBreath 2.8s ease-in-out infinite;
}
@keyframes bBreath{0%,100%{box-shadow:0 0 0 0 rgba(160,240,235,0)}50%{box-shadow:0 0 0 6px rgba(160,240,235,0)}}
.prem-attend-card:not(.sel) .prem-ac-badge {
  background:rgba(0,0,0,0.45);color:rgba(255,255,255,0.9);
  font-size:11px;font-weight:700;letter-spacing:0.09em;text-transform:uppercase;
  padding:12px 22px;border-radius:10px;flex-shrink:0;
}
.prem-ac-row2 { display:flex;flex-direction:column;gap:9px;margin-bottom:28px }
.prem-ac-loc {
  display:flex;align-items:center;gap:9px;font-size:12px;font-weight:700;
  letter-spacing:0.08em;text-transform:uppercase;color:var(--prem-teal);
  opacity:0;animation:metaFade .35s ease forwards;
}
.prem-ac-loc:nth-child(1) { animation-delay:.06s }
.prem-ac-loc:nth-child(2) { animation-delay:.12s }
@keyframes metaFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.prem-ac-row3 { display:flex;flex-direction:column;gap:16px;position:relative;z-index:2;padding:0 0 36px }
.prem-ac-perk {
  display:flex;align-items:center;gap:13px;
  font-size:12px;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;
  color:rgba(255,255,255,0.85);
  opacity:0;animation:perkFade .4s cubic-bezier(.4,0,.2,1) forwards;
}
.prem-ac-perk:nth-child(1){animation-delay:.1s}.prem-ac-perk:nth-child(2){animation-delay:.17s}
.prem-ac-perk:nth-child(3){animation-delay:.24s}.prem-ac-perk:nth-child(4){animation-delay:.31s}
.prem-ac-perk:nth-child(5){animation-delay:.38s}
@keyframes perkFade{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:none}}
.prem-ac-chk {
  color:var(--prem-teal);font-size:14px;font-weight:700;flex-shrink:0;
  display:inline-block;opacity:0;animation:chkPop .45s cubic-bezier(.4,0,.2,1) forwards;
}
.prem-ac-perk:nth-child(1) .prem-ac-chk{animation-delay:.12s}
.prem-ac-perk:nth-child(2) .prem-ac-chk{animation-delay:.19s}
.prem-ac-perk:nth-child(3) .prem-ac-chk{animation-delay:.26s}
.prem-ac-perk:nth-child(4) .prem-ac-chk{animation-delay:.33s}
.prem-ac-perk:nth-child(5) .prem-ac-chk{animation-delay:.4s}
@keyframes chkPop{0%{opacity:0;transform:scale(0) rotate(-20deg)}60%{opacity:1;transform:scale(1.4) rotate(5deg)}100%{opacity:1;transform:scale(1) rotate(0)}}
.prem-attend-card:not(.sel) .prem-ac-row2,
.prem-attend-card:not(.sel) .prem-ac-row3,
.prem-attend-card:not(.sel) .prem-ac-portrait { display:none }
.prem-attend-card:not(.sel) .prem-ac-row1 { margin-bottom:0;justify-content:flex-start;gap:40px }
.prem-attend-card:not(.sel) .prem-ac-content { padding:28px 36px }
.prem-attend-card:not(.sel) .prem-ac-type { font-size:40px;font-weight:400 }

/* Form */
.prem-reg-form-side {}
.prem-reg-form-title { font-size:40px;font-weight:800;color:#fff;letter-spacing:-0.04em;margin-bottom:40px }
.prem-f-input, .prem-f-select {
  width:100%;padding:16px 20px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:999px;font-family:'Inter',sans-serif;
  font-size:15px;color:#fff;outline:none;
  transition:border-color .2s,background .2s,box-shadow .2s,transform .15s;
  -webkit-appearance:none;margin-bottom:18px;
}
.prem-f-input::placeholder { color:rgba(255,255,255,0.3) }
.prem-f-input:focus, .prem-f-select:focus {
  border-color:rgba(61,191,184,0.5);
  background:rgba(61,191,184,0.04);
  box-shadow:0 0 0 4px rgba(61,191,184,0.08);
  transform:scale(1.01);
}
.prem-f-select option { background:#0a2014 }
.prem-f-row { display:grid;grid-template-columns:1fr 1fr;gap:14px }
.prem-f-privacy { font-size:14px;color:rgba(255,255,255,0.45);line-height:1.6;margin-bottom:24px }
.prem-f-privacy a { color:#fff;text-decoration:underline;text-underline-offset:3px }
.prem-btn-submit-wrap {
  position:relative;display:inline-block;width:100%;
  border-radius:999px;
  background:linear-gradient(135deg,var(--prem-teal),#2dba7a,#a78bfa);padding:2px;
}
.prem-btn-submit {
  width:100%;padding:16px;background:#fff;color:#111;
  border:none;border-radius:999px;font-family:'Inter',sans-serif;
  font-size:15px;font-weight:700;cursor:pointer;
  transition:all .25s;display:block;position:relative;overflow:hidden;
}
.prem-btn-submit::after {
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(0,0,0,0.04),transparent);
  transform:translateX(-100%);border-radius:999px;
  animation:btnShimmer 2.5s ease-in-out infinite;
}
@keyframes btnShimmer{0%{transform:translateX(-100%)}100%{transform:translateX(200%)}}
.prem-btn-submit:hover { transform:translateY(-1px);box-shadow:0 8px 24px rgba(255,255,255,0.15);background:#f0faf8 }
.prem-btn-submit:disabled { opacity:.5;cursor:not-allowed;transform:none }
.prem-form-success { display:none;text-align:center;padding:32px 0 }
.prem-form-success-icon {
  width:60px;height:60px;border-radius:50%;
  background:rgba(61,191,184,0.12);border:1px solid rgba(61,191,184,0.3);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
}
.prem-form-success h3 { font-size:22px;font-weight:800;color:#fff;margin-bottom:8px;letter-spacing:-0.02em }
.prem-form-success p { font-size:14px;color:rgba(255,255,255,0.4);line-height:1.7 }

/* Speakers */
.prem-speakers-sec { background:var(--prem-green-darkest);padding:96px 48px }
.prem-speakers-inner { max-width:1200px;margin:0 auto }
.prem-speakers-hd { display:flex;align-items:center;justify-content:space-between;margin-bottom:52px }
.prem-speakers-title {
  font-size:32px;font-weight:800;color:#fff;letter-spacing:-0.03em;
  opacity:0;transform:translateY(16px);transition:opacity .5s,transform .5s;
}
.prem-speakers-title.prem-vis { opacity:1;transform:none }
.prem-sp-arrows { display:flex;gap:10px }
.prem-sp-arrow {
  width:40px;height:40px;border-radius:50%;
  border:1.5px solid rgba(61,191,184,0.35);background:transparent;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .2s;color:rgba(255,255,255,0.5);
}
.prem-sp-arrow:hover { border-color:var(--prem-teal);color:var(--prem-teal);background:rgba(61,191,184,0.06) }
.prem-speakers-scroll { overflow:hidden }
.prem-speakers-track { display:flex;gap:20px;transition:transform .5s cubic-bezier(.4,0,.2,1) }
.prem-sp-card {
  flex-shrink:0;width:calc(25% - 15px);border-radius:16px;overflow:hidden;cursor:pointer;
  opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s,box-shadow .3s;
}
.prem-sp-card.prem-vis { opacity:1;transform:none }
.prem-sp-card:hover { box-shadow:0 16px 48px rgba(0,0,0,.5);transform:translateY(-6px) }
.prem-sp-img {
  height:300px;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--prem-green-dark),var(--prem-green-mid));
  display:flex;align-items:center;justify-content:center;
}
.prem-sp-img canvas { position:absolute;inset:0;width:100%;height:100% }
.prem-sp-img img { position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top }
.prem-sp-initials {
  font-size:52px;font-weight:900;color:rgba(255,255,255,0.12);
  letter-spacing:-0.04em;font-style:italic;position:relative;z-index:1;
}
.prem-sp-overlay { position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,0.5) 100%);z-index:2 }
.prem-sp-company {
  position:absolute;bottom:14px;left:14px;z-index:3;
  font-size:11px;font-weight:700;color:rgba(255,255,255,0.7);
  background:rgba(0,0,0,0.4);padding:4px 10px;border-radius:5px;
  backdrop-filter:blur(8px);
}
.prem-sp-body {
  background:#0a1f12;padding:16px 16px 18px;
  border:1px solid rgba(255,255,255,0.06);border-top:none;border-radius:0 0 16px 16px;
}
.prem-sp-name { font-size:14px;font-weight:700;color:#fff;margin-bottom:4px }
.prem-sp-role { font-size:12px;color:rgba(255,255,255,0.38);line-height:1.4 }

/* Leaders section */
.prem-leaders-sec { background:var(--prem-green-darkest);padding:0 40px }
.prem-leaders-card {
  max-width:1200px;margin:0 auto;border-radius:20px;overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;
  border:1px solid rgba(255,255,255,0.06);
}
.prem-leaders-left {
  background:linear-gradient(135deg,#082018 0%,#0a1f12 50%,#082018 100%);
  padding:72px 64px;position:relative;overflow:hidden;
}
.prem-leaders-canvas { position:absolute;inset:0;width:100%;height:100% }
.prem-leaders-content { position:relative;z-index:1 }
.prem-leaders-title {
  font-size:40px;font-weight:800;color:#fff;
  letter-spacing:-0.035em;line-height:1.15;margin-bottom:20px;
  opacity:0;transform:translateY(20px);transition:opacity .6s,transform .6s;
}
.prem-leaders-title.prem-vis { opacity:1;transform:none }
.prem-leaders-desc { font-size:15px;color:rgba(255,255,255,0.4);line-height:1.8;margin-bottom:32px }
.prem-leaders-locs { display:flex;flex-direction:column;gap:10px }
.prem-leaders-loc {
  display:flex;align-items:center;gap:10px;
  font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--prem-teal);
}
.prem-leaders-right {
  background:#0a1f12;position:relative;overflow:hidden;min-height:440px;
  display:flex;align-items:flex-end;
}
#premVenueCanvas { position:absolute;inset:0;width:100%;height:100% }
.prem-venue-silhouettes {
  position:absolute;bottom:0;left:0;right:0;height:40%;
  background:linear-gradient(0deg,var(--prem-green-darkest) 0%,transparent 100%);z-index:1;
}
.prem-leaders-right-overlay {
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(3,14,8,0.6) 100%);z-index:2;
}

/* ── FEATURING STRIP ── */
.prem-featuring{
  background:linear-gradient(135deg,#020b06 0%,#0a1f12 35%,#0d2a1a 65%,#020b06 100%);
  border-top:1px solid rgba(61,191,184,0.08);
  border-bottom:1px solid rgba(61,191,184,0.08);
  overflow:hidden;position:relative;
}
.prem-featuring-inner{
  display:flex;align-items:center;
  height:96px;padding:0 64px;
}
.prem-feat-label{
  font-size:12px;font-weight:800;letter-spacing:0.22em;text-transform:uppercase;
  color:rgba(255,255,255,0.3);white-space:nowrap;flex-shrink:0;padding-right:36px;
}
.prem-feat-divider{
  width:1px;height:36px;flex-shrink:0;margin-right:0;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,0.15),transparent);
}
.prem-feat-track-wrap{
  flex:1;overflow:hidden;position:relative;height:96px;display:flex;align-items:center;
}
.prem-feat-track{
  display:flex;align-items:center;gap:96px;
  white-space:nowrap;width:max-content;padding-left:48px;
  animation:premLogoScroll 22s linear infinite;
}
.prem-feat-track:hover{animation-play-state:paused}
@keyframes premLogoScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.prem-feat-logo{
  font-size:20px;font-weight:800;color:rgba(255,255,255,0.82);
  letter-spacing:-0.02em;white-space:nowrap;flex-shrink:0;
  cursor:default;transition:color .2s,transform .2s;
}
.prem-feat-logo:hover{color:#3DBFB8;transform:translateY(-1px)}
.prem-feat-fade-l,.prem-feat-fade-r{
  position:absolute;top:0;bottom:0;width:80px;pointer-events:none;z-index:2;
}
.prem-feat-fade-l{left:0;background:linear-gradient(to right,#020b06,transparent)}
.prem-feat-fade-r{right:0;background:linear-gradient(to left,#020b06,transparent)}

/* PARTICLES */
.prem-particle {
  position:absolute;border-radius:50%;pointer-events:none;
  animation:particleRise linear infinite;
}
@keyframes particleRise{
  0%{opacity:0;transform:translateY(0)}
  5%{opacity:.7}90%{opacity:.15}
  100%{opacity:0;transform:translateY(-100vh) translateX(var(--dx))}
}

/* Reg layout reveal */
.prem-reg-layout { opacity:0;transform:translateY(32px);transition:opacity .7s,transform .7s }
.prem-reg-layout.prem-vis { opacity:1;transform:none }

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}

/* RESPONSIVE */
@media(max-width:1024px){
  .prem-feature-card,.prem-leaders-card,.prem-reg-layout,.prem-agenda-sec-inner{grid-template-columns:1fr}
  .prem-events-grid,.prem-ae-layout{grid-template-columns:1fr}
  .prem-sp-card{width:calc(50% - 10px)}
  .prem-hero-h1,.prem-single-event-name{font-size:48px}
  .prem-ae-title{font-size:44px}
}
@media(max-width:640px){
  .prem-hero,.prem-single-hero{padding:60px 20px 0}
  .prem-all-events,.prem-agenda-sec,.prem-speakers-sec,.prem-reg-sec,.prem-featuring{padding-left:20px;padding-right:20px}
  .prem-footer{padding:48px 20px 24px}
  .prem-footer-grid{grid-template-columns:1fr 1fr}
  .prem-hero-h1,.prem-single-event-name{font-size:36px}
  .prem-agenda-sec-inner{grid-template-columns:1fr}
  .prem-agenda-visual{display:none}
  .prem-f-row{grid-template-columns:1fr}
  .prem-feature-wrap{width:calc(100% + 0px)}
}

/* ── FILTERED EMPTY STATE ── */
#premNoEvents{
  grid-column:1/-1;text-align:center;padding:80px 20px;
  background:#fff;border-radius:16px;border:1px dashed #d1d5db;
}
#premNoEvents p{font-size:15px;color:#9ca3af;margin:0}

/* ── FILTER ACTIVE ANIMATION ── */
.prem-ae-filter-opt{transition:all .15s ease !important}
.prem-ae-filter-opt.active{
  animation:filterPop .2s cubic-bezier(.4,0,.2,1);
}
@keyframes filterPop{
  0%{transform:scale(.97)}50%{transform:scale(1.02)}100%{transform:scale(1)}
}

/* ── CARD HIDE/SHOW ── */
.prem-ev-card[style*="display: none"]{pointer-events:none}
