/* =====================================================
   MNG SUMMIT · Experiment build · SXSW-inspired
   Dark, app-like, less scroll. Single accent (electric yellow).
   ===================================================== */

:root{
  /* surfaces */
  --bg:#0A0A0A;
  --bg-card:#141414;
  --bg-card-hover:#1A1A1A;
  --bg-drawer:#0F0F0F;

  /* lines */
  --line:#262626;
  --line-hot:#3A3A3A;

  /* text */
  --ink:#FFFFFF;
  --mute:#9A9A9A;
  --mute-2:#5A5A5A;

  /* accents — aligned to MNG brand: navy / yellow / red */
  --accent:#F5B71A;        /* brand yellow */
  --accent-2:#D32F3E;      /* brand red */
  --accent-blue:#1A3B8B;   /* brand navy */

  /* track colors (schedule grid) */
  --t-keynote:#F5B71A;
  --t-panel:#FFFFFF;
  --t-workshop:#D32F3E;
  --t-social:#9A9A9A;
  --t-network:#1A3B8B;

  /* type */
  --sans:'Montserrat',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;

  /* layout */
  --max:1440px;
  --pad:clamp(16px,3vw,40px);
  --nav-h:60px;
  --filter-h:52px;
  --ease:cubic-bezier(.2,.9,.2,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);color:var(--ink);
  font-family:var(--sans);
  font-size:15.5px;line-height:1.55;font-weight:500;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;border:0;background:0;color:inherit;}
a{color:inherit;text-decoration:none;transition:color .15s var(--ease);}
a:hover{color:var(--accent);}
::selection{background:var(--accent);color:var(--bg);}

/* ---------- type ---------- */
h1,h2,h3,h4{
  margin:0;font-weight:900;line-height:.95;
  letter-spacing:-0.045em;text-transform:uppercase;
}
h1{font-size:clamp(48px,7vw,104px);letter-spacing:-0.055em;}
h2{font-size:clamp(32px,4.5vw,64px);letter-spacing:-0.045em;}
h3{font-size:clamp(20px,2vw,28px);letter-spacing:-0.03em;line-height:1.05;text-transform:none;}
h4{font-size:13px;letter-spacing:.12em;line-height:1.2;}
em.italic-display{font-style:italic;font-weight:900;}
p{margin:0 0 1em;}
p:last-child{margin-bottom:0;}
strong,b{font-weight:800;}
.hot{color:var(--accent);}
.hot-2{color:var(--accent-2);}
.micro{
  font-size:11px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);
}
.micro--hot{color:var(--accent);}

/* ---------- layout primitives ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad);}
.row{display:flex;align-items:center;gap:12px;}
.row--between{justify-content:space-between;}

/* ---------- nav (SXSW-style two-tier sticky) ---------- */
:root{--nav-h:108px;}
.app-nav{
  position:sticky;top:0;z-index:50;
  background:#000;
  border-bottom:2px solid var(--accent);
}
/* Tier 1: logo on left, pill buttons + search on right */
.app-nav-tier1{
  height:72px;
  display:flex;align-items:center;gap:20px;
  padding:0 var(--pad);max-width:var(--max);margin:0 auto;
}
.app-nav-logo{display:flex;align-items:center;gap:10px;}
.app-nav-logo img{height:40px;width:auto;display:block;}
.app-nav-logo-full{height:46px !important;}
.app-nav-logo-mark{
  font-weight:900;font-size:22px;letter-spacing:-0.02em;
  text-transform:uppercase;color:#FFF;
}
.app-nav-logo-arrow{
  font-weight:900;color:#FFF;font-size:18px;margin-left:-2px;
}
.app-nav-sponsor{
  display:flex;align-items:center;gap:8px;margin-left:16px;
  font-size:10px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:#9A9A9A;
  padding-left:16px;border-left:1px solid #262626;
}
.app-nav-sponsor b{color:#FFF;font-weight:900;letter-spacing:.04em;}
.app-nav-right{
  margin-left:auto;display:flex;align-items:center;gap:8px;
}
/* pill buttons */
.app-nav-pill{
  display:inline-flex;align-items:center;justify-content:center;
  height:38px;padding:0 22px;
  border-radius:999px;
  font-size:12px;font-weight:900;letter-spacing:.04em;
  text-transform:uppercase;
  background:#3A3A3A;color:#FFF;
  border:0;cursor:pointer;
  transition:background .15s var(--ease),color .15s var(--ease);
  white-space:nowrap;
}
.app-nav-pill:hover{background:#FFF;color:#000;}
.app-nav-pill--hot{background:var(--accent);color:#000;}
.app-nav-pill--hot:hover{background:#FFF;color:#000;}
.app-nav-pill--ghost{background:#E8E8E8;color:#000;}
.app-nav-pill--ghost:hover{background:#FFF;color:#000;}
.app-nav-pill--icon{
  width:38px;height:38px;padding:0;border-radius:50%;
  font-size:16px;
}
/* Tier 2: full menu + date|location strip */
.app-nav-tier2{
  height:44px;
  display:flex;align-items:center;
  padding:0 var(--pad);max-width:var(--max);margin:0 auto;
  border-top:1px solid #1A1A1A;
  overflow-x:auto;scrollbar-width:none;
  white-space:nowrap;
}
.app-nav-tier2::-webkit-scrollbar{display:none;}
.app-nav-links{
  display:flex;align-items:center;gap:0;flex:none;
}
.app-nav-link{
  display:inline-flex;align-items:center;gap:4px;
  height:44px;padding:0 16px;
  font-size:13px;font-weight:900;letter-spacing:.06em;
  text-transform:uppercase;color:#FFF;
  transition:color .15s var(--ease);
  white-space:nowrap;flex:none;
}
.app-nav-link:hover{color:var(--accent);}
.app-nav-link.is-active{color:var(--accent);}
.app-nav-link-arrow{
  font-size:8px;margin-left:2px;color:#9A9A9A;
}
.app-nav-link:hover .app-nav-link-arrow,
.app-nav-link.is-active .app-nav-link-arrow{color:var(--accent);}
.app-nav-when{
  margin-left:auto;padding-left:24px;
  font-size:13px;font-weight:900;letter-spacing:.06em;
  text-transform:uppercase;color:#FFF;
  display:flex;align-items:center;gap:10px;
  white-space:nowrap;flex:none;
}
.app-nav-when .sep{color:#5A5A5A;}
.app-nav-toggle{display:none;}

/* old single-tier .app-nav-bar (kept for any legacy uses) becomes tier1 */
.app-nav-bar{
  height:64px;
  display:flex;align-items:center;gap:20px;
  padding:0 var(--pad);max-width:var(--max);margin:0 auto;
}

/* ---------- filter bar (second tier) ---------- */
.app-filterbar{
  position:sticky;top:var(--nav-h);z-index:49;
  background:var(--bg);border-bottom:1px solid var(--line);
}
.app-filterbar-inner{
  height:var(--filter-h);max-width:var(--max);margin:0 auto;
  padding:0 var(--pad);
  display:flex;align-items:center;gap:8px;overflow-x:auto;
  scrollbar-width:none;
}
.app-filterbar-inner::-webkit-scrollbar{display:none;}
.app-filterbar-label{
  font-size:11px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);
  margin-right:8px;flex:none;
}

/* ---------- chips ---------- */
.chip{
  display:inline-flex;align-items:center;gap:6px;
  height:32px;padding:0 14px;
  font-size:12.5px;font-weight:700;letter-spacing:.02em;
  background:var(--bg-card);color:var(--ink);
  border:1px solid var(--line);
  transition:all .15s var(--ease);
  white-space:nowrap;flex:none;
}
.chip:hover{border-color:var(--line-hot);}
.chip.is-on{background:var(--accent);color:var(--bg);border-color:var(--accent);}
.chip-dot{width:8px;height:8px;background:currentColor;display:inline-block;flex:none;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  height:40px;padding:0 18px;
  font-size:12.5px;font-weight:800;letter-spacing:.06em;
  text-transform:uppercase;
  background:var(--ink);color:var(--bg);
  border:1px solid var(--ink);
  transition:all .15s var(--ease);
}
.btn:hover{background:var(--accent);border-color:var(--accent);color:var(--bg);}
.btn--hot{background:var(--accent);color:var(--bg);border-color:var(--accent);}
.btn--hot:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.btn--ghost{background:0;color:var(--ink);border-color:var(--line);}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent);background:0;}
.btn--lg{height:48px;padding:0 24px;font-size:13px;}
.btn--sm{height:30px;padding:0 12px;font-size:11px;}

/* ---------- hero (short, single-viewport) ---------- */
.app-hero{
  position:relative;
  padding:clamp(48px,7vw,96px) var(--pad) clamp(40px,5vw,64px);
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:32px;
}
.app-hero-eyebrow{
  display:flex;flex-wrap:wrap;gap:16px;align-items:center;
  font-size:11px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);
}
.app-hero-eyebrow .hot{color:var(--accent);}
.app-hero-eyebrow b{color:var(--ink);font-weight:800;}
.app-hero-title{
  font-size:clamp(48px,9vw,140px);
  font-weight:900;letter-spacing:-0.06em;line-height:.9;
  text-transform:uppercase;
}
.app-hero-title em{
  font-style:italic;color:var(--accent);font-weight:900;
}
.app-hero-foot{
  display:flex;flex-wrap:wrap;gap:16px;align-items:center;
  margin-top:8px;
}

/* ---------- card grid ---------- */
.card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1px;background:var(--line);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.card{
  background:var(--bg-card);color:var(--ink);
  padding:24px;display:flex;flex-direction:column;gap:14px;
  min-height:200px;cursor:pointer;
  transition:background .2s var(--ease);
}
.card:hover{background:var(--bg-card-hover);color:var(--ink);}
.card-top{
  display:flex;align-items:center;justify-content:space-between;
  font-size:11px;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:var(--mute);
}
.card-top .hot{color:var(--accent);}
.card-title{
  font-size:clamp(20px,2vw,26px);
  font-weight:900;letter-spacing:-0.03em;line-height:1.05;
  text-transform:none;
}
.card-meta{
  font-size:13px;color:var(--mute);font-weight:500;
  margin-top:auto;display:flex;gap:10px;flex-wrap:wrap;
}
.card-meta span{color:var(--ink);}
.card-cta{
  font-size:11px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);
  margin-top:auto;
}

/* ---------- day tabs ---------- */
.day-tabs{
  display:flex;gap:0;border-bottom:1px solid var(--line);
  max-width:var(--max);margin:0 auto;
}
.day-tab{
  flex:1;padding:18px 16px;text-align:left;
  border-right:1px solid var(--line);
  background:var(--bg);color:var(--ink);
  transition:background .15s var(--ease);
  display:flex;flex-direction:column;gap:6px;
  position:relative;
}
.day-tab:last-child{border-right:0;}
.day-tab:hover{background:var(--bg-card);}
.day-tab.is-active{background:var(--bg-card);}
.day-tab.is-active::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;
  height:3px;background:var(--accent);
}
.day-tab-num{font-size:11px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);}
.day-tab.is-active .day-tab-num{color:var(--accent);}
.day-tab-day{font-size:22px;font-weight:900;letter-spacing:-0.02em;color:var(--ink);}
.day-tab-date{font-size:13px;color:var(--mute);font-weight:600;}

/* ---------- schedule grid ---------- */
.schedule{
  display:grid;grid-template-columns:88px 1fr;gap:0;
  max-width:var(--max);margin:0 auto;
  align-items:stretch;
}
.schedule[hidden]{display:none;}
.schedule-time{
  padding:18px 14px 0;
  font-size:11px;font-weight:800;letter-spacing:.06em;
  color:var(--mute);
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.session{
  position:relative;
  padding:16px 20px 16px 28px;
  border-bottom:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
  background:var(--bg);cursor:pointer;
  transition:background .15s var(--ease);
  min-height:120px;
}
.session:hover{background:var(--bg-card);}
.session-strip{
  position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--mute-2);
}
.session.t-keynote .session-strip{background:var(--t-keynote);}
.session.t-panel .session-strip{background:var(--t-panel);}
.session.t-workshop .session-strip{background:var(--t-workshop);}
.session.t-social .session-strip{background:var(--t-social);}
.session.t-network .session-strip{background:var(--t-network);}
.session-top{
  display:flex;align-items:center;gap:10px;
  font-size:11px;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:var(--mute);
}
.session-track{color:var(--ink);}
.session.t-keynote .session-track{color:var(--t-keynote);}
.session.t-workshop .session-track{color:var(--t-workshop);}
.session-title{
  font-size:18px;font-weight:900;letter-spacing:-0.02em;
  line-height:1.15;color:var(--ink);text-transform:none;
}
.session-speakers{
  font-size:13px;color:var(--mute);font-weight:600;
}
.session-speakers b{color:var(--ink);font-weight:700;}
.session-meta{
  display:flex;gap:14px;font-size:11px;font-weight:700;
  color:var(--mute);text-transform:uppercase;letter-spacing:.08em;
  margin-top:auto;
}

/* ---------- drawer ---------- */
.drawer-scrim{
  position:fixed;inset:0;z-index:90;
  background:rgba(0,0,0,.7);
  opacity:0;pointer-events:none;
  transition:opacity .25s var(--ease);
}
.drawer-scrim.is-open{opacity:1;pointer-events:auto;}
.drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:91;
  width:min(560px,100vw);
  background:var(--bg-drawer);
  border-left:1px solid var(--line);
  transform:translateX(100%);
  transition:transform .3s var(--ease);
  overflow-y:auto;padding:32px var(--pad);
}
.drawer.is-open{transform:translateX(0);}
.drawer-close{
  position:absolute;top:20px;right:20px;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);font-size:16px;
}
.drawer-close:hover{border-color:var(--accent);color:var(--accent);}
.drawer-top{
  font-size:11px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);margin-bottom:12px;
}
.drawer-title{
  font-size:32px;font-weight:900;letter-spacing:-0.03em;
  line-height:1.05;margin-bottom:20px;text-transform:none;
}
.drawer-meta{
  display:grid;grid-template-columns:auto 1fr;gap:10px 18px;
  padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  margin-bottom:24px;font-size:13px;
}
.drawer-meta dt{font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  font-size:11px;color:var(--mute);}
.drawer-meta dd{margin:0;color:var(--ink);}
.drawer-body{font-size:15px;color:rgba(255,255,255,.86);line-height:1.6;}
.drawer-body p{margin:0 0 1em;}
.drawer-cta{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap;}

/* ---------- footer ---------- */
.app-footer{
  margin-top:80px;
  padding:48px var(--pad);
  border-top:1px solid var(--line);
  max-width:var(--max);margin-left:auto;margin-right:auto;
}
.app-footer-row{
  display:flex;flex-wrap:wrap;justify-content:space-between;
  gap:24px;align-items:flex-start;
}
.app-footer-brand{display:flex;align-items:center;gap:12px;}
.app-footer-brand img{height:40px;display:block;}
.app-footer-mark{font-weight:900;font-size:14px;letter-spacing:.04em;
  text-transform:uppercase;}
.app-footer-links{
  display:flex;flex-wrap:wrap;gap:24px;
  font-size:12px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--mute);
}
.app-footer-meta{
  margin-top:32px;padding-top:24px;border-top:1px solid var(--line);
  font-size:11px;color:var(--mute);font-weight:600;
  display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;
}

/* ---------- split-2 ---------- */
.split-2{
  display:grid;grid-template-columns:1.4fr 1fr;
  gap:48px;align-items:start;
  max-width:var(--max);margin:0 auto;padding:48px var(--pad);
}
.split-aside{border-left:1px solid var(--line);padding-left:32px;}
.split-aside-title{
  font-size:11px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);margin-bottom:14px;
}

/* ---------- horizontal strip ---------- */
.strip{
  display:flex;gap:1px;background:var(--line);
  overflow-x:auto;scrollbar-width:none;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.strip::-webkit-scrollbar{display:none;}
.strip-card{
  flex:0 0 320px;background:var(--bg-card);
  padding:22px;display:flex;flex-direction:column;gap:12px;
  min-height:200px;cursor:pointer;
  transition:background .15s var(--ease);
}
.strip-card:hover{background:var(--bg-card-hover);}

/* ---------- live indicator ---------- */
.live-pill{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:var(--accent-2);
  padding:4px 10px;border:1px solid currentColor;
}
.live-dot{
  width:6px;height:6px;background:currentColor;border-radius:50%;
  animation:pulse 1.6s infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;}
  50%{opacity:.3;}
}

/* ---------- section header ---------- */
.sec-h{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:20px;padding:48px var(--pad) 24px;
  max-width:var(--max);margin:0 auto;
}
.sec-h h2{font-size:clamp(24px,3vw,40px);font-weight:900;letter-spacing:-0.03em;}
.sec-h-link{
  font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);
}

/* ---------- compact countdown ---------- */
.countdown-inline{
  display:inline-flex;align-items:center;gap:12px;
  padding:8px 14px;border:1px solid var(--line);
  font-size:12px;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;
}
.countdown-inline b{color:var(--accent);font-weight:900;font-size:14px;}

/* =====================================================
   LANDING PAGE MODE · light + colorful (SXSW marketing site)
   Rounded cards, bright fills, black text. Same nav stays dark.
   ===================================================== */

.page-light{background:#FFFFFF;color:#0A0A0A;}
/* light-page hover, but never recolor anchors inside the dark nav/footer */
.page-light a:hover:not(.app-nav-link):not(.app-nav-pill):not(.app-nav-logo):not(.app-nav-toggle){color:#0A0A0A;}
.page-light .app-nav-link:hover{color:var(--accent);}
.page-light h1,.page-light h2,.page-light h3,.page-light h4{color:#0A0A0A;}

/* card color tokens — BRAND-PURE
   Only the actual MNG palette: navy, yellow, red, cream, white.
   No invented hues. Variety comes from light vs. dark contrast. */
.page-light{
  /* === The 3 brand colors at full saturation === */
  --card-yellow:#F5B71A;  /* MNG brand yellow · navy text */
  --card-red:#D32F3E;     /* MNG brand red · white text */
  --card-blue:#1A3B8B;    /* MNG brand navy · white text */

  /* === Brand reds + yellows mapped onto warm slots === */
  --card-pink:#D32F3E;    /* alias of brand red · white text */
  --card-orange:#F5B71A;  /* alias of brand yellow · navy text */

  /* === Brand navy mapped onto cool slots === */
  --card-cyan:#1A3B8B;    /* alias of brand navy · white text */
  --card-purple:#1A3B8B;  /* alias of brand navy · white text */

  /* === Neutrals as the mosaic variety === */
  --card-cream:#F4ECD8;   /* warm oat */
  --card-green:#F4ECD8;   /* cream (no green in brand) */
  --card-lilac:#FFFFFF;   /* white with subtle border */
}

/* promo bar (yellow strip across top) */
.promo-bar{
  background:var(--accent);color:#0A0A0A;
  text-align:center;padding:10px var(--pad);
  font-size:13px;font-weight:700;letter-spacing:.02em;
  border-bottom:1px solid #0A0A0A;
}
.promo-bar a{text-decoration:underline;font-weight:900;}

/* light hero, FULL BLEED edge-to-edge, square corners (matches SXSW pattern) */
.l-hero{
  width:100%;margin:0;padding:0;
}
.l-hero-photo{
  position:relative;
  aspect-ratio:16/8;
  background:#0A0A0A;
  border-radius:0;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  width:100%;
}
.l-hero-photo img{
  width:100%;height:100%;object-fit:cover;display:block;opacity:.78;
}
.l-hero-photo-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.75) 100%);
}
.l-hero-photo-content{
  position:absolute;left:0;bottom:0;right:0;
  padding:var(--pad);
  max-width:var(--max);margin:0 auto;
  color:#FFF;
}
.l-hero-photo-content .micro{color:#FFE500;}
.l-hero-photo-title,
.page-light .l-hero-photo-title{
  font-size:clamp(36px,5vw,72px);font-weight:900;
  letter-spacing:-0.045em;line-height:.95;margin-top:8px;
  color:#FFF;
}
/* By the numbers — 4-up stats strip directly under the hero photo */
.l-bynumbers{
  max-width:var(--max);margin:0 auto;
  padding:0 var(--pad);
}
.l-bynumbers-label{
  font-size:11px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:#5A5A5A;
  padding:28px 0 14px;
}
.l-bynumbers-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:#E5E5E5;
}
.l-bynumbers-cell{
  background:#FFFFFF;color:#0A0A0A;
  padding:28px 24px 28px 0;
  display:flex;flex-direction:column;gap:6px;
}
.l-bynumbers-cell:first-child{padding-left:0;}
.l-bynumbers-cell:not(:first-child){padding-left:24px;}
.l-bynumbers-num{
  font-size:clamp(48px,7vw,104px);
  font-weight:900;letter-spacing:-0.055em;line-height:.9;
  color:#0A0A0A;
}
.l-bynumbers-label-cell{
  font-size:11px;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:#5A5A5A;
}
.l-bynumbers-sub{
  font-size:11px;font-weight:600;color:#9A9A9A;
  letter-spacing:.04em;text-transform:none;
}

/* === Reasons strip (vertical-divider 3-up, same family as by-numbers) === */
.l-reasons{
  max-width:var(--max);margin:0 auto;
  padding:0 var(--pad) clamp(40px,5vw,80px);
}
/* Cream-backdrop variant — full viewport bleed, no radius, the inner grid stays centered to max-width */
.l-reasons--cream{
  width:100%;max-width:none;
  margin:0 0 clamp(40px,5vw,72px);
  padding:clamp(16px,2vw,28px) var(--pad) clamp(40px,5vw,72px);  /* tight top so it kisses the page-head above */
  background:var(--card-cream);
  border-radius:0;
}
.l-reasons--cream .l-reasons-grid{
  max-width:var(--max);margin:0 auto;
  background:rgba(0,0,0,.08);
}
.l-reasons--cream .l-reasons-cell{background:var(--card-cream);}
.l-reasons-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:#E5E5E5;
}
.l-reasons-cell{
  background:#FFFFFF;color:#0A0A0A;
  padding:32px 28px 32px 0;
  display:flex;flex-direction:column;gap:14px;
}
.l-reasons-cell:first-child{padding-left:0;}
.l-reasons-cell:not(:first-child){padding-left:28px;}
.l-reasons-cat{
  font-size:11px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:#1A3B8B;
}
.l-reasons-title{
  font-size:clamp(22px,2.6vw,32px);font-weight:900;
  letter-spacing:-0.02em;line-height:1;color:#0A0A0A;
  text-transform:uppercase;max-width:14ch;
}
.l-reasons-sub{
  font-size:14px;font-weight:500;color:#3A3A3A;line-height:1.5;
  margin-top:auto;
}
.l-reasons-sub b{color:#0A0A0A;font-weight:900;}
@media(max-width:760px){
  .l-reasons-grid{grid-template-columns:1fr;}
  .l-reasons-cell:not(:first-child){padding-left:0;padding-top:24px;}
}
@media(max-width:760px){
  .l-bynumbers-grid{grid-template-columns:1fr 1fr;}
  .l-bynumbers-cell:nth-child(3){padding-left:0;}
}
@media(max-width:480px){
  .l-bynumbers-grid{grid-template-columns:1fr;}
  .l-bynumbers-cell{padding-left:0;}
}
.l-hero-foot{
  max-width:var(--max);margin:0 auto;
  text-align:left;padding:40px var(--pad) 48px;
  display:flex;flex-direction:column;align-items:flex-start;gap:18px;
}
.l-hero-foot h2{
  font-size:clamp(22px,2.6vw,36px);font-weight:900;
  letter-spacing:-0.02em;
}

/* small announcement strip, 3 dark cards, full bleed */
.l-catchup{
  background:#1A1A1A;color:#FFF;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:#1A1A1A;
  margin:0;
}
.l-catchup-cell{
  background:#1A1A1A;padding:32px;
  display:flex;flex-direction:column;gap:14px;
}
.l-catchup-cell .micro{color:var(--accent);}
.l-catchup-cell h3{
  color:#FFF;font-size:22px;font-weight:900;
  letter-spacing:-0.02em;line-height:1.1;text-transform:uppercase;
}
.l-catchup-cell a{
  font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent);margin-top:auto;
}

/* "ALL TOGETHER NOW" banner */
.l-banner{
  display:flex;justify-content:space-between;align-items:center;
  padding:32px var(--pad);gap:16px;
  max-width:var(--max);margin:32px auto 0;
}
.l-banner h2{
  font-size:clamp(20px,2vw,28px);font-weight:900;
  letter-spacing:-0.02em;text-transform:uppercase;
}
.l-banner a{
  font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
}

/* TWO BIG FEATURE CARDS */
.l-twocard{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
  max-width:var(--max);margin:0 auto;padding:0 var(--pad);
}
.l-bigcard{
  position:relative;border-radius:24px;
  padding:36px;min-height:280px;
  display:flex;flex-direction:column;justify-content:space-between;gap:18px;
  background:var(--card-pink);color:#0A0A0A;
  overflow:hidden;
  transition:transform .25s var(--ease);
}
.l-bigcard:hover{transform:translateY(-3px);}
.l-bigcard h3{
  font-size:clamp(20px,2.2vw,30px);font-weight:900;
  letter-spacing:-0.02em;line-height:1.1;
  text-transform:uppercase;max-width:18ch;
}
.l-bigcard .btn{align-self:flex-start;}
.l-bigcard--cyan{background:var(--card-cyan);color:#FFFFFF;}
.l-bigcard--yellow{background:var(--card-yellow);color:#0A0A0A;}
.l-bigcard--green{background:var(--card-green);color:#0A0A0A;}
.l-bigcard--purple{background:var(--card-purple);color:#FFFFFF;}
.l-bigcard--orange{background:var(--card-orange);color:#0A0A0A;}
.l-bigcard--red{background:var(--card-red);color:#FFFFFF;}
.l-bigcard--blue{background:var(--card-blue);color:#FFFFFF;}
.l-bigcard--cyan h3, .l-bigcard--purple h3, .l-bigcard--red h3, .l-bigcard--blue h3{color:#FFFFFF;}
.l-bigcard-art{
  position:absolute;right:20px;bottom:20px;
  width:140px;height:140px;
  display:flex;align-items:center;justify-content:center;
  font-size:80px;line-height:1;
}

/* STATS BIG PARAGRAPH, left-aligned within page wrap */
.l-stats-wrap{
  max-width:var(--max);margin:96px auto;padding:0 var(--pad);
}
.l-stats{
  text-align:left;
  font-size:clamp(20px,2.2vw,28px);font-weight:600;
  line-height:1.4;color:#0A0A0A;
  letter-spacing:-0.01em;
  max-width:880px;
}
.l-stats b{font-weight:900;}
.l-stats em{color:#0A0A0A;font-style:normal;background:var(--card-yellow);padding:0 6px;}
.l-stats-cta-row{
  display:flex;flex-wrap:wrap;gap:12px;
  margin-top:clamp(20px,2.5vw,32px);
}

/* PHOTO BANNER (cutout treatment) */
.l-banner-photo{
  margin:48px 0;
  position:relative;overflow:hidden;
  background:var(--card-green);
  min-height:340px;
  display:flex;align-items:center;justify-content:center;
}
.l-banner-photo img{
  width:100%;height:100%;object-fit:cover;
  position:absolute;inset:0;mix-blend-mode:luminosity;opacity:.92;
}
.l-banner-photo-content{
  position:relative;z-index:1;text-align:center;color:#0A0A0A;
  padding:32px;background:#0A0A0A;color:#FFF;
}

/* OUR PROGRAMS, 3-col card grid with photos */
.l-programs-h{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:24px var(--pad) 16px;
  max-width:var(--max);margin:0 auto;
}
.l-programs-h h2{
  font-size:clamp(22px,2.4vw,32px);font-weight:900;letter-spacing:-0.02em;
  text-transform:uppercase;
}
.l-programs-h a{
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  background:#0A0A0A;color:#FFF;padding:8px 14px;border-radius:999px;
}
.l-programs{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  max-width:var(--max);margin:0 auto;padding:0 var(--pad);
}
.l-program{
  background:var(--card-purple);color:#0A0A0A;
  border-radius:24px;overflow:hidden;
  display:flex;flex-direction:column;
  min-height:380px;
  transition:transform .25s var(--ease);
}
.l-program:hover{transform:translateY(-3px);color:#0A0A0A;}
.l-program-photo{
  flex:1;
  background:#0A0A0A;
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.l-program-photo img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.l-program-body{padding:18px 24px 20px;min-height:0;display:flex;flex-direction:column;gap:6px;}
.l-program-cat{
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:#0A0A0A;margin-bottom:8px;
}
.l-program h3{
  font-size:24px;font-weight:900;letter-spacing:-0.02em;
  line-height:1;text-transform:uppercase;
}
.l-program--cyan{background:var(--card-cyan);color:#FFFFFF;}
.l-program--pink{background:var(--card-pink);color:#FFFFFF;}
.l-program--yellow{background:var(--card-yellow);color:#0A0A0A;}
.l-program--green{background:var(--card-green);color:#0A0A0A;}
.l-program--orange{background:var(--card-orange);color:#0A0A0A;}
.l-program--red{background:var(--card-red);color:#FFFFFF;}
.l-program--blue{background:var(--card-blue);color:#FFFFFF;}
/* Override base h3/cat color on dark program cards */
.l-program--cyan h3, .l-program--pink h3, .l-program--red h3, .l-program--blue h3,
.l-program--cyan .l-program-cat, .l-program--pink .l-program-cat, .l-program--red .l-program-cat, .l-program--blue .l-program-cat{
  color:#FFFFFF;
}
.l-program--cyan:hover, .l-program--pink:hover, .l-program--red:hover, .l-program--blue:hover{color:#FFFFFF;}

/* SEE YOU NEXT YEAR — big colored card with date callout + badge mockup */
.l-syn{
  padding:24px var(--pad) 48px;
  max-width:var(--max);margin:0 auto;
}
.l-syn-card{
  background:#0A0A0A;color:#FFFFFF;
  border-radius:24px;overflow:hidden;position:relative;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(40px,5vw,72px);
  min-height:560px;
  /* Background: NYC photo cover · dark gradient on left/bottom for text legibility · path is relative to css/site.css so we go up one dir */
  background-image:
    linear-gradient(to right, rgba(10,10,10,.85) 0%, rgba(10,10,10,.65) 35%, rgba(10,10,10,.2) 65%, rgba(10,10,10,0) 100%),
    url("../assets/photos/hero-nyc-skyline.jpg");
  background-size:cover, cover;
  background-position:center, center;
}
/* decorative wavy lines (top-right + bottom-left) */
.l-syn-card::before{
  content:"";position:absolute;top:0;right:0;width:55%;height:100%;
  opacity:.55;pointer-events:none;
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 600' fill='none' stroke='%235B47E0' stroke-width='2'%3E%3Cpath d='M50 50C100 100 60 180 120 220C180 260 140 340 200 380C260 420 220 500 280 540'/%3E%3Cpath d='M90 30C140 80 100 160 160 200C220 240 180 320 240 360C300 400 260 480 320 520'/%3E%3Cpath d='M130 10C180 60 140 140 200 180C260 220 220 300 280 340C340 380 300 460 360 500'/%3E%3Cpath d='M170 -10C220 40 180 120 240 160C300 200 260 280 320 320C380 360 340 440 400 480'/%3E%3Cpath d='M210 -30C260 20 220 100 280 140C340 180 300 260 360 300'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right top;
  background-size:contain;
}
.l-syn-body{position:relative;z-index:1;max-width:640px;}
.l-syn-eyebrow{
  font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#F5B71A;
  margin-bottom:20px;
}
.l-syn-title,
.page-light .l-syn-title{
  font-size:clamp(48px,6vw,84px);font-weight:900;
  letter-spacing:-0.04em;line-height:.95;color:#FFFFFF;
  margin-bottom:20px;text-transform:none;
}
.l-syn-date{
  font-size:clamp(24px,3vw,40px);font-weight:900;
  letter-spacing:-0.02em;line-height:1.2;color:#FFFFFF;
  text-transform:none;margin:0;
}
.l-syn-date-hl{
  background:#F5B71A;color:#0A0A0A;padding:4px 12px;display:inline-block;
}
/* Wavy lines + SVG overlay + photo overlay no longer needed since the photo IS the card */
.l-syn-card::before,
.l-syn-illust,
.l-syn-illust--photo,
.l-syn-illust-stamp{display:none !important;}
.l-syn-cta{
  display:inline-flex;align-items:center;gap:6px;
  background:#0A0A0A;color:#FFF;
  padding:16px 26px;border-radius:999px;
  font-size:12.5px;font-weight:900;letter-spacing:.08em;
  text-transform:uppercase;
  margin-top:40px;
  transition:background .15s var(--ease);
}
.l-syn-cta:hover{background:#FFE500;color:#0A0A0A;}

/* Lady Liberty in del + VR goggles illustration (playful inline SVG) */
.l-syn-illust{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:center;
  width:100%;
}
.l-syn-illust svg{
  width:100%;max-width:520px;height:auto;display:block;
  filter:drop-shadow(0 16px 30px rgba(0,0,0,.22));
}

/* PHOTO VARIANT — NYC skyline photo filling the right half of the SYN card, fades into the text area on its left edge */
.l-syn-illust--photo{
  position:absolute;
  top:0;right:0;bottom:0;
  width:60%;          /* roughly half + a touch, so it bleeds toward the center */
  z-index:1;          /* sits above the SVG fallback so it cleanly covers it when loaded */
  align-items:stretch;justify-content:flex-end;
  overflow:hidden;
  border-radius:0 24px 24px 0;
}
.l-syn-illust--photo img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:50% 40%;   /* keep the skyline horizon + Empire State in frame */
  display:block;
  /* feather the left edge so the photo melts into the card's cream background and text reads cleanly on top */
  -webkit-mask-image:linear-gradient(to right,
    transparent 0%,
    rgba(0,0,0,.15) 8%,
    rgba(0,0,0,.55) 22%,
    #000 42%,
    #000 100%);
          mask-image:linear-gradient(to right,
    transparent 0%,
    rgba(0,0,0,.15) 8%,
    rgba(0,0,0,.55) 22%,
    #000 42%,
    #000 100%);
}
.l-syn-illust-stamp{
  position:absolute;bottom:18px;right:22px;z-index:2;
  background:#0A0A0A;color:#F5B71A;
  padding:6px 14px;border-radius:999px;
  font-size:11px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;
}

@media(max-width:600px){
  .l-syn-illust{display:none;}
  .l-syn-illust--photo{display:none;}
}

/* Lanyard + badge mockup */
.l-syn-badge-wrap{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;
  transform:rotate(2deg);
}
.l-syn-lanyard{
  width:60px;background:var(--accent-2);
  color:#FFF;
  display:flex;align-items:center;justify-content:center;
  padding:80px 0 30px;
  font-size:13px;font-weight:900;letter-spacing:.18em;
  writing-mode:vertical-lr;
  position:relative;
}
.l-syn-lanyard::after{
  content:"";position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);
  width:30px;height:30px;border:4px solid #0A0A0A;border-radius:50%;
  background:#FFF;
}
.l-syn-badge-card{
  width:300px;background:#FFF;color:#0A0A0A;
  border-radius:10px;overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.22);
  margin-top:-8px;
}
.l-syn-badge-top{
  background:var(--accent);color:#0A0A0A;
  padding:14px 18px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:10px;font-weight:900;letter-spacing:.1em;
  text-transform:uppercase;
}
.l-syn-badge-logo{
  padding:18px;
  font-weight:900;font-size:20px;letter-spacing:-0.01em;
  text-transform:uppercase;
  border-bottom:1px solid #E5E5E5;
}
.l-syn-badge-photo{
  width:90px;height:90px;background:var(--card-cyan);
  border-radius:50%;
  margin:24px auto 14px;
  display:flex;align-items:center;justify-content:center;
  font-size:36px;font-weight:900;color:#0A0A0A;letter-spacing:-0.02em;
}
.l-syn-badge-name{
  font-size:24px;font-weight:900;text-align:center;
  letter-spacing:-0.02em;line-height:1;
  text-transform:uppercase;
}
.l-syn-badge-role{
  font-size:11px;font-weight:800;color:#5A5A5A;
  text-align:center;letter-spacing:.08em;
  text-transform:uppercase;
  margin-top:6px;padding-bottom:18px;
}
.l-syn-badge-meta{
  font-size:10px;font-weight:700;color:#5A5A5A;
  text-align:center;letter-spacing:.1em;
  text-transform:uppercase;border-top:1px solid #E5E5E5;
  padding:14px;
}

@media(max-width:760px){
  .l-syn-card{grid-template-columns:1fr;padding:32px;min-height:0;}
  .l-syn-badge-wrap{align-items:flex-start;transform:none;}
  .l-syn-card::before{display:none;}
}
@media(max-width:600px){
  .l-syn-badge-wrap{display:none;}
}

/* FROM THE ARCHIVE — past summit cards with year overlay */
.l-archive-strip{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  max-width:var(--max);margin:0 auto;padding:0 var(--pad) 48px;
}
.l-archive-card{
  background:var(--card-cream);color:#0A0A0A;
  border-radius:24px;overflow:hidden;
  display:flex;flex-direction:column;
  min-height:380px;
  transition:transform .25s var(--ease);
}
.l-archive-card:hover{transform:translateY(-3px);color:#0A0A0A;}
.l-archive-photo{
  position:relative;flex:1;
  background:#0A0A0A;overflow:hidden;
  min-height:220px;
}
.l-archive-photo img{width:100%;height:100%;object-fit:cover;}
.l-archive-year{
  position:absolute;bottom:16px;left:20px;
  font-size:clamp(40px,5vw,64px);font-weight:900;
  letter-spacing:-0.04em;line-height:1;
  color:#FFF;text-shadow:0 2px 24px rgba(0,0,0,.5);
}
.l-archive-body{padding:22px 24px 24px;min-height:148px;display:flex;flex-direction:column;justify-content:flex-start;gap:8px;}
.l-archive-where{
  font-size:11px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:#5A5A5A;margin-bottom:8px;
}
.l-archive-theme{
  font-size:22px;font-weight:900;letter-spacing:-0.02em;
  line-height:1.05;text-transform:uppercase;color:#0A0A0A;
}
.l-archive-note{
  font-size:13px;font-weight:500;color:#5A5A5A;
  margin-top:10px;line-height:1.45;
}

/* "Limited 2027 presale" pill float */
.l-presale-pill{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  background:#0A0A0A;color:#FFF;padding:8px 14px;border-radius:999px;
}

/* SEE YOU NEXT, big rounded card with badge */
.l-next{
  margin:64px auto 0;padding:0 var(--pad);max-width:var(--max);
}
.l-next-card{
  background:var(--card-pink);
  border-radius:24px;overflow:hidden;
  display:grid;grid-template-columns:1.4fr 1fr;gap:0;
  align-items:center;
  min-height:420px;
  position:relative;
}
.l-next-bg{
  position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(circle at 80% 30%,rgba(255,255,255,.4) 0%,transparent 50%),
                   radial-gradient(circle at 20% 80%,rgba(255,255,255,.3) 0%,transparent 60%);
  pointer-events:none;
}
.l-next-body{padding:48px;position:relative;z-index:1;}
.l-next-eyebrow{
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:#0A0A0A;margin-bottom:14px;
}
.l-next-body h2{
  font-size:clamp(28px,3.4vw,48px);font-weight:900;
  letter-spacing:-0.035em;line-height:1;text-transform:uppercase;
  margin-bottom:18px;
}
.l-next-cta{
  display:inline-flex;align-items:center;
  background:#0A0A0A;color:#FFF;
  padding:12px 18px;border-radius:999px;
  font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
}
.l-next-badge{
  position:relative;z-index:1;padding:48px;
  display:flex;align-items:center;justify-content:center;
}
.l-badge{
  background:#FFF;color:#0A0A0A;
  width:260px;padding:24px 20px;
  display:flex;flex-direction:column;gap:8px;
  border-radius:8px;
  box-shadow:0 18px 40px rgba(0,0,0,.18);
}
.l-badge-tag{
  font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  background:var(--accent);color:#0A0A0A;
  padding:4px 8px;align-self:flex-start;
}
.l-badge-name{
  font-size:22px;font-weight:900;letter-spacing:-0.02em;
  text-transform:uppercase;line-height:1;margin-top:10px;
}
.l-badge-role{
  font-size:11px;font-weight:700;letter-spacing:.06em;
  color:#0A0A0A;text-transform:uppercase;
}
.l-badge-meta{
  font-size:10px;font-weight:700;letter-spacing:.08em;
  color:#5A5A5A;text-transform:uppercase;
  border-top:1px solid #DADADA;padding-top:8px;margin-top:8px;
}

/* QUICK LINKS grid */
.l-quicklinks-h{
  padding:48px var(--pad) 16px;max-width:var(--max);margin:0 auto;
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#5A5A5A;
}
.l-quicklinks{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
  max-width:var(--max);margin:0 auto;padding:0 var(--pad);
}
.l-ql{
  background:var(--card-lilac);color:#0A0A0A;
  padding:24px;border-radius:16px;
  display:flex;flex-direction:column;gap:6px;
  transition:transform .25s var(--ease);
}
.l-ql:hover{transform:translateY(-2px);color:#0A0A0A;}
.l-ql-cat{font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;}
.l-ql-name{font-size:15px;font-weight:900;letter-spacing:-0.01em;text-transform:uppercase;line-height:1.1;}
.l-ql--pink{background:var(--card-pink);color:#FFFFFF;}
.l-ql--cyan{background:var(--card-cyan);color:#FFFFFF;}
.l-ql--yellow{background:var(--card-yellow);color:#0A0A0A;}
.l-ql--red{background:var(--card-red);color:#FFFFFF;}
.l-ql--blue{background:var(--card-blue);color:#FFFFFF;}
.l-ql--pink:hover, .l-ql--cyan:hover, .l-ql--red:hover, .l-ql--blue:hover{color:#FFFFFF;}

/* DRIVEN BY (sponsor strip), left-aligned */
.l-driven{
  text-align:left;padding:80px var(--pad) 32px;
  max-width:var(--max);margin:0 auto;
  font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#5A5A5A;
}
.l-driven-mark{
  font-size:clamp(13px,1.4vw,18px);font-weight:800;letter-spacing:.16em;color:#5A5A5A;
  margin-top:8px;text-transform:uppercase;line-height:1.4;
}

/* light footer (used only on light pages) */
.l-footer{
  background:#0A0A0A;color:#FFF;
  padding:48px var(--pad);
  margin-top:32px;
}
.l-footer-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;
}
.l-footer-brand-mark{
  font-size:24px;font-weight:900;letter-spacing:.02em;text-transform:uppercase;
}
.l-footer-newsletter{margin-top:24px;}
.l-footer-newsletter label{
  display:block;font-size:11px;font-weight:700;letter-spacing:.06em;color:#9A9A9A;margin-bottom:6px;text-transform:uppercase;
}
.l-footer-newsletter-row{display:flex;gap:8px;align-items:flex-end;}
.l-footer-newsletter input{
  flex:1;background:0;border:0;border-bottom:1px solid #FFF;color:#FFF;
  font-family:inherit;font-size:14px;padding:8px 0;width:100%;outline:0;
}
.l-footer-newsletter input::placeholder{color:#6A6A6A;}
.l-footer-newsletter-btn{
  flex-shrink:0;padding:8px 16px;border-radius:999px;border:0;cursor:pointer;
  font-family:inherit;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;
  background:#3A3A3A;color:#6A6A6A;transition:background .2s ease,color .2s ease,transform .15s ease;
}
.l-footer-newsletter-btn:not(:disabled){background:#F5B71A;color:#0A0A0A;}
.l-footer-newsletter-btn:not(:disabled):hover{transform:translateY(-1px);background:#FFCB3A;}
.l-footer-newsletter-alt{margin-top:10px;font-size:11px;color:#6A6A6A;}
.l-footer-newsletter-alt a{color:#9A9A9A;text-decoration:underline;}
.l-footer-newsletter-alt a:hover{color:#F5B71A;}
.l-footer-social{display:flex;gap:8px;margin-top:18px;}
.l-footer-social a{
  width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid #3A3A3A;background:transparent;color:#9A9A9A;font-size:11px;font-weight:900;letter-spacing:.04em;
  text-transform:uppercase;transition:border-color .2s ease,color .2s ease,background .2s ease,transform .15s ease;
}
.l-footer-social a:hover{border-color:#F5B71A;color:#F5B71A;transform:translateY(-1px);}
.l-footer-col h4{
  font-size:11px;font-weight:800;letter-spacing:.14em;color:#9A9A9A;
  text-transform:uppercase;margin-bottom:14px;
}
.l-footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;}
.l-footer-col a{
  font-size:13px;font-weight:600;color:#FFF;
}
.l-footer-bot{
  max-width:var(--max);margin:32px auto 0;padding-top:24px;
  border-top:1px solid #262626;
  font-size:11px;color:#9A9A9A;font-weight:600;
  display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;
}

/* light-page nav adjustments, nav stays dark, so no changes needed */

/* =====================================================
   SUMMIT 2026 entry landing (SXSW Schedule home style)
   - Big green rounded hero card with search + full schedule CTA
   - Grid of colorful entry cards (Program, Speakers, Tickets, etc.)
   ===================================================== */

/* big hero card, full-bleed wrapper, rounded card inside */
.l-event-hero{
  padding:24px var(--pad) 12px;
  max-width:var(--max);margin:0 auto;
}
.l-event-hero-card{
  background:var(--card-green);color:#0A0A0A;
  border-radius:28px;
  padding:clamp(32px,5vw,72px);
  display:flex;flex-direction:column;gap:24px;
  min-height:clamp(360px,48vw,520px);
  position:relative;overflow:hidden;
}
.l-event-hero-eyebrow{
  font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  color:#0A0A0A;
}
.l-event-hero-title{
  font-size:clamp(36px,5.6vw,72px);font-weight:900;
  letter-spacing:-0.045em;line-height:1;color:#0A0A0A;
  text-transform:none;max-width:18ch;
}
.l-event-hero-search{
  display:flex;align-items:center;gap:10px;
  background:#FFFFFF;border-radius:999px;
  padding:14px 22px;max-width:520px;
  box-shadow:0 2px 0 rgba(0,0,0,.06);
  margin-top:8px;
}
.l-event-hero-search-ico{
  font-size:18px;color:#5A5A5A;flex-shrink:0;
}
.l-event-hero-search input{
  background:0;border:0;outline:0;
  font-family:inherit;font-size:15px;font-weight:600;color:#0A0A0A;
  width:100%;
}
.l-event-hero-search input::placeholder{color:#9A9A9A;font-weight:500;}
.l-event-hero-cta{
  align-self:flex-start;
  display:inline-flex;align-items:center;gap:8px;
  background:#1A3B8B;color:#FFFFFF;
  padding:16px 26px;border-radius:999px;
  font-size:13px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;
  transition:background .15s var(--ease),transform .15s var(--ease);
}
.l-event-hero-cta:hover{background:#0A0A0A;color:#FFFFFF;transform:translateY(-2px);}
.l-event-hero-meta{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;
  font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:#0A0A0A;margin-top:auto;
}
.l-event-hero-meta .sep{opacity:.4;}

/* entry grid */
.l-entry{
  padding:12px var(--pad) 24px;
  max-width:var(--max);margin:0 auto;
}
.l-entry-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
  grid-auto-rows:minmax(180px,auto);
}
.l-entry-card{
  position:relative;overflow:hidden;
  background:var(--card-pink);color:#0A0A0A;
  border-radius:24px;
  padding:24px;
  display:flex;flex-direction:column;justify-content:space-between;gap:18px;
  min-height:200px;
  transition:transform .25s var(--ease);
}
.l-entry-card:hover{transform:translateY(-3px);color:#0A0A0A;}
.l-entry-card--xl{
  grid-column:span 2;grid-row:span 2;
  min-height:420px;
  padding:32px;
}
.l-entry-card--tall{
  grid-column:span 1;grid-row:span 2;
  min-height:420px;
  padding:28px;
}
.l-entry-card--wide{
  grid-column:span 2;grid-row:span 1;
  min-height:180px;
  padding:24px 28px;
}

/* Outlined / stroke variants — quiet, framed cards instead of solid color blocks */
.l-entry-card--outline-blue{
  background:#FFFFFF;
  border:2px solid #1A3B8B;
  color:#1A3B8B;
}
.l-entry-card--outline-blue .l-entry-cat,
.l-entry-card--outline-blue h3,
.l-entry-card--outline-blue .l-entry-sub,
.l-entry-card--outline-blue .l-entry-arrow{color:#1A3B8B;}
.l-entry-card--outline-blue:hover{background:#1A3B8B;color:#FFFFFF;}
.l-entry-card--outline-blue:hover .l-entry-cat,
.l-entry-card--outline-blue:hover h3,
.l-entry-card--outline-blue:hover .l-entry-sub,
.l-entry-card--outline-blue:hover .l-entry-arrow{color:#FFFFFF;}

.l-entry-card--outline-red{
  background:#FFFFFF;
  border:2px solid #D32F3E;
  color:#D32F3E;
}
.l-entry-card--outline-red .l-entry-cat,
.l-entry-card--outline-red h3,
.l-entry-card--outline-red .l-entry-sub,
.l-entry-card--outline-red .l-entry-arrow{color:#D32F3E;}
.l-entry-card--outline-red:hover{background:#D32F3E;color:#FFFFFF;}
.l-entry-card--outline-red:hover .l-entry-cat,
.l-entry-card--outline-red:hover h3,
.l-entry-card--outline-red:hover .l-entry-sub,
.l-entry-card--outline-red:hover .l-entry-arrow{color:#FFFFFF;}

/* =====================================================
   TICKET CARD — yellow XL entry card styled as a real event ticket
   ===================================================== */
.ticket-card{
  position:relative;
  display:grid;grid-template-columns:1fr 92px;gap:0;
  padding:0;overflow:hidden;
}
.ticket-card-main{
  padding:clamp(28px,3vw,40px);
  display:flex;flex-direction:column;gap:18px;
}
.ticket-card-top{
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#0A0A0A;
}
.ticket-card-eyebrow{}
.ticket-card-number{
  background:#0A0A0A;color:#F5B71A;padding:4px 10px;border-radius:999px;letter-spacing:.1em;
}
.ticket-card-title{
  font-family:inherit;font-size:clamp(48px,6vw,80px);font-weight:900;
  letter-spacing:-.025em;line-height:.95;margin:0;color:#0A0A0A;
}
.ticket-card-title em{font-style:italic;font-weight:900;}
.ticket-card-meta{
  display:flex;flex-direction:column;gap:6px;
  border-top:2px dashed rgba(0,0,0,.4);padding-top:14px;margin-top:auto;
}
.ticket-card-meta-row{
  display:flex;align-items:baseline;gap:12px;
  font-size:13px;font-weight:700;color:#0A0A0A;
}
.ticket-card-meta-label{
  font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#5A4400;
  min-width:50px;
}
.ticket-card-meta-value{font-weight:800;}
.ticket-card-cta{
  display:inline-block;background:#0A0A0A;color:#F5B71A;
  padding:12px 18px;border-radius:999px;
  font-size:12px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;
  align-self:flex-start;
  transition:transform .15s ease;
}
.ticket-card:hover .ticket-card-cta{transform:translateX(3px);}

/* The tear-off stub — vertical orientation on the right */
.ticket-card-stub{
  position:relative;
  background:rgba(0,0,0,.06);
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  padding:24px 0;
  border-left:2.5px dashed rgba(0,0,0,.42);
}
.ticket-card-stub-label{
  writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);
  font-size:10px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:#0A0A0A;
}
.ticket-card-barcode{
  width:36px;height:140px;
  background-image:repeating-linear-gradient(
    90deg,
    #0A0A0A 0, #0A0A0A 1.5px,
    transparent 1.5px, transparent 3px,
    #0A0A0A 3px, #0A0A0A 4px,
    transparent 4px, transparent 6px,
    #0A0A0A 6px, #0A0A0A 9px,
    transparent 9px, transparent 11px
  );
}

/* Perforation cut-outs — circles that punch through to the page background */
.ticket-card::before,
.ticket-card::after{
  content:'';position:absolute;
  width:22px;height:22px;border-radius:50%;
  background:#FFFFFF;
  right:81px;
  z-index:2;
}
.ticket-card::before{top:-11px;}
.ticket-card::after{bottom:-11px;}

@media(max-width:760px){
  .ticket-card{grid-template-columns:1fr 72px;}
  .ticket-card-barcode{width:28px;height:100px;}
  .ticket-card::before, .ticket-card::after{right:61px;}
}
.l-entry-cat{
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:#0A0A0A;
}
.l-entry-title{
  font-size:clamp(22px,2.4vw,32px);font-weight:900;
  letter-spacing:-0.02em;line-height:1;text-transform:uppercase;
  max-width:14ch;
}
.l-entry-card--xl .l-entry-title{
  font-size:clamp(36px,4.2vw,60px);letter-spacing:-0.04em;
}
.l-entry-card--tall .l-entry-title{
  font-size:clamp(22px,2.4vw,32px);letter-spacing:-0.03em;
  max-width:none;
}
.l-entry-title--giant{
  font-size:clamp(48px,7vw,108px)!important;letter-spacing:-0.05em;line-height:.92;
}
.l-entry-foot{
  display:flex;align-items:flex-end;justify-content:space-between;gap:12px;
}
.l-entry-sub{
  font-size:12px;font-weight:700;color:#0A0A0A;
  line-height:1.35;max-width:24ch;
}
.l-entry-arrow{
  font-size:22px;font-weight:900;color:#0A0A0A;flex-shrink:0;
}
.l-entry-art{
  position:absolute;right:24px;top:24px;
  width:56px;height:56px;opacity:.85;pointer-events:none;
}
.l-entry-card--xl .l-entry-art{
  right:32px;bottom:32px;top:auto;
  width:96px;height:96px;
}

/* big card with nested pills (Program → Hackathon / NHUB / Gala) */
.l-entry-card--has-pills{
  cursor:default;
  justify-content:flex-start;gap:14px;
}
.l-entry-card--has-pills:hover{transform:none;}
.l-entry-sub--lead{
  font-size:14px;font-weight:700;color:#0A0A0A;
  max-width:none;margin-bottom:6px;line-height:1.4;
}
.l-entry-sub-meta{
  font-size:11.5px;font-weight:600;letter-spacing:.04em;
  color:#0A0A0A;opacity:.7;
  text-transform:uppercase;
}
.l-entry-pills{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  margin-top:auto;
}
.l-entry-pill{
  background:rgba(255,255,255,.55);
  border-radius:14px;padding:14px 14px;
  display:flex;flex-direction:column;gap:4px;
  color:#0A0A0A;
  transition:background .15s var(--ease),transform .15s var(--ease);
}
.l-entry-pill:hover{
  background:#FFFFFF;
  transform:translateY(-2px);
  color:#0A0A0A;
}
.l-entry-pill-day{
  font-size:9.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:#5A5A5A;
}
.l-entry-pill-name{
  font-size:13.5px;font-weight:900;letter-spacing:-0.01em;line-height:1.1;
  color:#0A0A0A;
}
.l-entry-card-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:#0A0A0A;color:#FFFFFF;
  padding:12px 20px;border-radius:999px;
  font-size:11.5px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;
  align-self:flex-start;
  transition:background .15s var(--ease),color .15s var(--ease);
}
.l-entry-card-cta:hover{background:#1A3B8B;color:#FFFFFF;}
@media(max-width:560px){
  .l-entry-pills{grid-template-columns:1fr;}
}

/* color variants */
.l-entry-card--pink{background:var(--card-pink);}
.l-entry-card--cyan{background:var(--card-cyan);}
.l-entry-card--yellow{background:var(--card-yellow);}
.l-entry-card--green{background:var(--card-green);}
.l-entry-card--purple{background:var(--card-purple);}
.l-entry-card--orange{background:var(--card-orange);}
/* Yellow + Orange (aliased): brand-navy text on yellow (AAA contrast) */
.l-entry-card--yellow,
.l-entry-card--orange{color:#1A3B8B;}
.l-entry-card--yellow .l-entry-cat, .l-entry-card--orange .l-entry-cat,
.l-entry-card--yellow .l-entry-title, .l-entry-card--orange .l-entry-title,
.l-entry-card--yellow .l-entry-sub, .l-entry-card--orange .l-entry-sub,
.l-entry-card--yellow .l-entry-arrow, .l-entry-card--orange .l-entry-arrow{color:#1A3B8B;}

/* Red + Pink (aliased): white text on brand red */
.l-entry-card--red,
.l-entry-card--pink{background:var(--card-red);color:#FFFFFF;}
.l-entry-card--red .l-entry-cat, .l-entry-card--pink .l-entry-cat,
.l-entry-card--red .l-entry-title, .l-entry-card--pink .l-entry-title,
.l-entry-card--red .l-entry-sub, .l-entry-card--pink .l-entry-sub,
.l-entry-card--red .l-entry-arrow, .l-entry-card--pink .l-entry-arrow{color:#FFFFFF;}

/* Blue + Cyan + Purple (aliased): white text on brand navy */
.l-entry-card--blue,
.l-entry-card--cyan,
.l-entry-card--purple{background:var(--card-blue);color:#FFFFFF;}
.l-entry-card--blue .l-entry-cat, .l-entry-card--cyan .l-entry-cat, .l-entry-card--purple .l-entry-cat,
.l-entry-card--blue .l-entry-title, .l-entry-card--cyan .l-entry-title, .l-entry-card--purple .l-entry-title,
.l-entry-card--blue .l-entry-sub, .l-entry-card--cyan .l-entry-sub, .l-entry-card--purple .l-entry-sub,
.l-entry-card--blue .l-entry-arrow, .l-entry-card--cyan .l-entry-arrow, .l-entry-card--purple .l-entry-arrow{color:#FFFFFF;}

/* Cream + Green (aliased): black text on cream */
.l-entry-card--cream,
.l-entry-card--green{background:var(--card-cream);}

/* Lilac (white): subtle navy border so it doesn't disappear */
.l-entry-card--lilac{background:var(--card-lilac);border:1px solid #1A3B8B;}

/* =====================================================
   INTERIOR PAGE HEAD (programs, archive, about, sponsor, get-involved, program details)
   ===================================================== */
.page-head{
  padding:clamp(48px,7vw,96px) var(--pad) clamp(28px,3.5vw,48px);
  max-width:var(--max);margin:0 auto;
}
/* =====================================================
   YEAR NAVIGATOR · chip row right under the nav on summit-year pages
   ===================================================== */
.year-nav{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  max-width:var(--max);margin:24px auto 0;padding:0 var(--pad);
}
.year-nav-back{
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:#1A3B8B;text-decoration:none;
  padding:8px 0;
}
.year-nav-back:hover{text-decoration:underline;text-underline-offset:4px;}
.year-nav-pills{
  display:flex;gap:4px;flex-wrap:wrap;
}
.year-nav-pill{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:48px;height:30px;padding:0 10px;
  border-radius:999px;
  font-size:12px;font-weight:800;letter-spacing:.04em;
  color:#5A5A5A;background:transparent;text-decoration:none;
  transition:background .15s ease,color .15s ease;
}
.year-nav-pill:hover{background:#F4F4F4;color:#0A0A0A;}
.year-nav-pill.is-active{
  background:#F5B71A;color:#0A0A0A;cursor:default;
}

/* =====================================================
   HOSTED BY · who organized this year's summit, with links to the board directory
   ===================================================== */
.hosted-by{
  max-width:var(--max);margin:clamp(48px,6vw,80px) auto;padding:0 var(--pad);
}
.hosted-by-title,
.page-light .hosted-by-title{
  font-size:clamp(20px,2.2vw,28px);font-weight:900;letter-spacing:-.02em;
  margin:8px 0 18px;color:#0A0A0A;
}
.hosted-pills{
  display:flex;flex-wrap:wrap;gap:8px;
}
.hosted-pill{
  display:inline-flex;align-items:center;
  padding:8px 14px;border-radius:999px;
  background:var(--card-cream);color:#0A0A0A;
  font-size:13px;font-weight:700;letter-spacing:.01em;
  text-decoration:none;
  transition:background .15s ease,transform .15s ease;
}
.hosted-pill:hover{background:#F5B71A;transform:translateY(-2px);}
.hosted-pill--unlinked{
  background:transparent;border:1px solid #E5E5E5;color:#5A5A5A;
}
.hosted-pill--unlinked:hover{border-color:#0A0A0A;color:#0A0A0A;background:transparent;}
.hosted-note{
  font-size:13.5px;line-height:1.55;color:#5A5A5A;
  margin:14px 0 0;max-width:680px;
}

/* =====================================================
   PREV / NEXT SUMMIT PAGER · 2-up card grid before the footer
   ===================================================== */
.summit-nav{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
  max-width:var(--max);margin:clamp(48px,6vw,80px) auto;padding:0 var(--pad);
}
@media(max-width:680px){.summit-nav{grid-template-columns:1fr;}}
.summit-nav-card{
  display:flex;flex-direction:column;gap:8px;
  background:transparent;
  border-radius:20px;padding:clamp(24px,3vw,36px);
  text-decoration:none;color:#0A0A0A;
  transition:background .15s ease;
}
.summit-nav-card:hover{background:rgba(245,183,26,.18);}
.summit-nav-card--next{text-align:right;}
.summit-nav-meta{
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#1A3B8B;
}
.summit-nav-year,
.page-light .summit-nav-year{
  font-size:clamp(22px,2.6vw,32px);font-weight:900;letter-spacing:-.02em;line-height:1.1;
  margin:0;color:#0A0A0A;
}
.summit-nav-theme{
  font-size:14px;font-weight:600;color:#3A3A3A;
}

/* Linked stat cells — Speakers/Keynotes/Sessions cells become clickable to the filtered directory */
.l-bynumbers-cell--linked{
  text-decoration:none;color:inherit;cursor:pointer;
  transition:transform .15s ease;
}
.l-bynumbers-cell--linked .l-bynumbers-label-cell{
  color:#1A3B8B;
  transition:letter-spacing .15s ease;
}
.l-bynumbers-cell--linked:hover{transform:translateY(-2px);}
.l-bynumbers-cell--linked:hover .l-bynumbers-label-cell{letter-spacing:.04em;}
.l-bynumbers-cell--linked:hover .l-bynumbers-num{color:#1A3B8B;}

/* =====================================================
   THEME + BY-THE-NUMBERS · sits right under the hero on summit year pages
   Two-column layout: theme blurb on the left, stat band on the right
   ===================================================== */
.theme-band{
  max-width:var(--max);margin:clamp(32px,4vw,56px) auto;
  padding:0 var(--pad);
}
.theme-band-inner{
  display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(32px,4vw,56px);
  align-items:start;
}
@media(max-width:920px){
  .theme-band-inner{grid-template-columns:1fr;gap:24px;}
}
.theme-band-text{display:flex;flex-direction:column;gap:14px;}
.theme-band-title,
.page-light .theme-band-title{
  font-size:clamp(28px,3.4vw,44px);font-weight:900;letter-spacing:-.02em;line-height:1.1;
  margin:0;color:#0A0A0A;
}
.theme-band-blurb{
  font-size:15.5px;line-height:1.65;color:#3A3A3A;margin:0;
  max-width:540px;
}
.theme-band-stats{margin:0;max-width:none;padding:0;}
.theme-band-stats .l-bynumbers-label{padding-top:0;}


.recap{
  background:transparent;
  padding:clamp(32px,4vw,56px) var(--pad);
  margin:clamp(32px,4vw,56px) auto;
  max-width:var(--max);
}
.recap-inner{
  max-width:var(--max);margin:0;
  display:flex;flex-direction:column;gap:20px;
}
.recap-eyebrow{
  font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#1A3B8B;
}
.recap-title,
.page-light .recap-title{
  font-size:clamp(28px,3.4vw,44px);font-weight:900;letter-spacing:-.02em;line-height:1.1;
  margin:0;color:#0A0A0A;
}
.recap-body{
  display:flex;flex-direction:column;gap:18px;
  border-top:1px solid rgba(10,10,10,.15);padding-top:20px;
}
.recap-body p{
  font-size:16px;line-height:1.7;color:#3A3A3A;margin:0;
}
.recap-dateline{
  display:inline;
  font-size:11px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:#0A0A0A;
  margin-right:8px;
}
/* Inline speaker-link styling inside recap text — bold + subtle navy underline that pops on hover */
.speaker-link{
  color:#0A0A0A;
  font-weight:700;
  text-decoration:underline;
  text-decoration-color:rgba(26,59,139,.4);
  text-decoration-thickness:1.5px;
  text-underline-offset:3px;
  transition:text-decoration-color .15s ease, color .15s ease, background .15s ease;
  padding:0 1px;
}
.speaker-link:hover{
  color:#1A3B8B;
  text-decoration-color:#1A3B8B;
  text-decoration-thickness:2px;
  background:rgba(245,183,26,.25);
}
/* On yellow cards, switch the underline accent so it stays visible — no background tint on hover */
.recap-card:nth-child(3n+2) .speaker-link{
  text-decoration-color:rgba(10,10,10,.45);
}
.recap-card:nth-child(3n+2) .speaker-link:hover{
  background:transparent;
  text-decoration-color:#0A0A0A;
  text-decoration-thickness:2px;
}

/* When the directory is scrolled to a specific speaker via anchor link, briefly highlight the card */
.speaker-card{scroll-margin-top:120px;}
.speaker-card:target{
  outline:2px solid #1A3B8B;
  outline-offset:2px;
  animation:speakerCardFlash 2s ease-out;
}
@keyframes speakerCardFlash{
  0%{background:#FFF6CC;}
  100%{background:transparent;}
}

/* Theme blurb · sits between the recap title and the cards grid, replaces the old duplicated theme-band-blurb */
.theme-blurb{
  font-size:clamp(15.5px,1.5vw,17px);line-height:1.65;color:#3A3A3A;
  margin:6px 0 24px;
  max-width:780px;
}

/* Category-boxed recap variant — paragraphs broken into named cards so the recap is scannable.
   Matches the .speaker-card / .leadership-card / .l-entry-card family: uniform rounded corners, no asymmetric accents.
   Auto-numbered via CSS counters so each card gets a 01/02/03 chapter marker for visual guidance. */
.recap-cards{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:16px;
  margin-top:8px;
  counter-reset:recap-num;
}
.recap-card{
  background:var(--card-cream);
  border:0;
  border-radius:20px;
  padding:clamp(24px,2.6vw,32px);
  display:flex;flex-direction:column;gap:16px;
  counter-increment:recap-num;
  position:relative;
  overflow:hidden;
}
/* Rotating card backgrounds so the trio reads as a triptych instead of three identical cream boxes */
.recap-card:nth-child(3n+2){background:var(--card-yellow);}
.recap-card:nth-child(3n+3){background:#FFFFFF;border:1.5px solid #0A0A0A;}

/* Big bold number badge — solid navy chip with white text */
.recap-card::before{
  content:counter(recap-num, decimal-leading-zero);
  display:inline-flex;align-items:center;justify-content:center;
  align-self:flex-start;
  background:#1A3B8B;color:#FFFFFF;
  width:42px;height:42px;border-radius:50%;
  font-size:14px;font-weight:900;letter-spacing:.04em;line-height:1;
  margin-bottom:2px;
}
.recap-card:nth-child(3n+2)::before{background:#0A0A0A;color:#F5B71A;}
.recap-card:nth-child(3n+3)::before{background:#0A0A0A;color:#FFFFFF;}

.recap-card-label{
  font-size:11.5px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:#1A3B8B;
  margin:0;
  position:relative;display:inline-block;
}
/* Yellow underline accent on the label — gives the label a punchy visual hit */
.recap-card-label::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;
  height:3px;background:#F5B71A;
}
.recap-card:nth-child(3n+2) .recap-card-label{color:#0A0A0A;}
.recap-card:nth-child(3n+2) .recap-card-label::after{background:#0A0A0A;}
.recap-card:nth-child(3n+3) .recap-card-label{color:#1A3B8B;}
.recap-card:nth-child(3n+3) .recap-card-label::after{background:#1A3B8B;}
.recap-card p{
  font-size:14.5px;line-height:1.65;color:#3A3A3A;margin:0;
}
.recap-card ul{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:10px;
}
.recap-card ul li{
  font-size:14.5px;line-height:1.55;color:#3A3A3A;
  padding-left:18px;position:relative;
}
.recap-card ul li::before{
  content:"";position:absolute;left:0;top:9px;
  width:6px;height:6px;border-radius:50%;background:#1A3B8B;
}
.recap-card:nth-child(3n+2) ul li::before{background:#0A0A0A;}
.recap-card ul li b{color:#0A0A0A;}
.recap-card .recap-dateline{
  display:inline;font-size:10.5px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:#0A0A0A;margin-right:6px;
}
/* When recap uses cards, drop the inner-divider border on the parent block */
.recap-inner:has(.recap-cards){border-left:none;padding-left:0;}
@media(max-width:760px){
  .recap-cards{grid-template-columns:1fr;}
}

/* Cream-backdrop variant — full-bleed cream behind the page header, used when the next section is also cream so they read as one continuous block */
.page-head--cream{
  width:100%;max-width:none;
  background:var(--card-cream);
  padding:clamp(48px,7vw,96px) var(--pad) 0;  /* zero bottom padding · joins seamlessly with the next cream section */
}
.page-head--cream > *{
  max-width:var(--max);margin-left:0;margin-right:auto;text-align:left;
}
.page-head-eyebrow{
  font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  color:#1A3B8B;margin-bottom:14px;
}
.page-head-title{
  font-size:clamp(40px,6vw,84px);font-weight:900;
  letter-spacing:-0.05em;line-height:.95;color:#0A0A0A;
  text-transform:none;max-width:18ch;
}
.page-head-title em{
  font-style:italic;background:var(--card-yellow);
  padding:0 8px;color:#0A0A0A;font-weight:900;
}
.page-head-title .hot-2{
  background:var(--card-pink);padding:0 8px;
}
.page-head-lead{
  margin-top:24px;max-width:680px;
  font-size:clamp(15px,1.4vw,18px);font-weight:500;line-height:1.5;
  color:#3A3A3A;
}
.page-head-lead b{color:#0A0A0A;font-weight:900;}
.page-head-meta{
  display:flex;flex-wrap:wrap;gap:20px;
  margin-top:20px;font-size:12px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:#5A5A5A;
}
.page-head-meta b{color:#0A0A0A;font-weight:900;}

/* Body content blocks (used by detail pages) */
.page-body{
  max-width:var(--max);margin:0 auto;
  padding:0 var(--pad) clamp(40px,5vw,80px);
  display:grid;gap:32px;
}
.page-body h2{
  font-size:clamp(26px,3vw,38px);font-weight:900;
  letter-spacing:-0.035em;line-height:1.02;color:#0A0A0A;
  text-transform:none;max-width:18ch;
}
.page-body h2 em{
  font-style:italic;background:var(--card-yellow);padding:0 8px;
}
.page-body h3{
  font-size:clamp(18px,1.6vw,22px);font-weight:900;
  letter-spacing:-0.02em;color:#0A0A0A;text-transform:uppercase;
}
.page-body p{
  font-size:15px;font-weight:500;line-height:1.6;color:#3A3A3A;
  max-width:680px;
}
.page-body p b{color:#0A0A0A;font-weight:900;}
.page-body ul{
  margin:0;padding:0;list-style:none;
  font-size:15px;line-height:1.55;color:#3A3A3A;
  display:flex;flex-direction:column;gap:12px;
}
.page-body ul li{
  position:relative;padding-left:28px;
}
.page-body ul li::before{
  content:"";position:absolute;left:0;top:9px;
  width:12px;height:12px;border-radius:50%;
  background:#1A3B8B;
}
.page-body ul b{color:#0A0A0A;font-weight:900;}
.page-body-block{display:flex;flex-direction:column;gap:14px;}

/* "Two-up" body grid — each block becomes a colored panel for visual relief */
.page-body-2up{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.page-body-2up > .page-body-block{
  background:var(--card-cream);
  border-radius:24px;
  padding:clamp(28px,3vw,40px);
  gap:18px;
}
.page-body-2up > .page-body-block:nth-child(2){
  background:var(--card-lilac);
}
.page-body-2up > .page-body-block:nth-child(2) ul li::before{
  background:#E04E80;  /* pink dot on the lilac panel */
}
@media(max-width:760px){
  .page-body-2up{grid-template-columns:1fr;}
}

/* Inline "coming soon" pill — used inside list items, headings, or labels */
.soon-tag{
  display:inline-block;
  font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  padding:2px 8px;border-radius:999px;
  background:#F5B71A;color:#0A0A0A;
  vertical-align:1px;margin:0 2px;
}

/* Narrative variant — single flowing block at ~760px max for legibility */
.page-body-block--narrative{
  max-width:760px;background:transparent;padding:0;
  display:flex;flex-direction:column;gap:18px;
}
.page-body-block--narrative h2{font-size:clamp(28px,3.4vw,44px);line-height:1.1;}
.page-body-block--narrative p{font-size:16.5px;line-height:1.7;color:#3A3A3A;}

/* =====================================================
   LEADERSHIP — quiet typographic leadership block
   ===================================================== */
.leadership{
  width:calc(100% - 2 * var(--pad));max-width:calc(var(--max) - 2 * var(--pad));
  margin:clamp(48px,6vw,80px) auto;
  display:flex;flex-direction:column;gap:32px;
}
.leadership-head{display:flex;flex-direction:column;gap:14px;max-width:680px;}
.leadership-head h2{font-size:clamp(26px,3vw,40px);line-height:1.1;margin:0;}
.leadership-head p{font-size:15px;color:#3A3A3A;margin:0;}
.leadership-head p a{color:#0A0A0A;text-decoration:underline;text-underline-offset:3px;}
.leadership-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
}
.leadership-grid--3up{grid-template-columns:repeat(3,1fr);}
@media(max-width:960px){.leadership-grid--3up{grid-template-columns:repeat(2,1fr);}}
@media(max-width:760px){.leadership-grid,.leadership-grid--3up{grid-template-columns:1fr;}}
.leadership-card,
.leadership-featured{
  background:var(--card-cream);
  border-radius:20px;padding:clamp(24px,2.6vw,32px);
  display:flex;flex-direction:column;gap:8px;
}
.leadership-featured{
  background:#FFFFFF;border:2px solid #1A3B8B;
  padding:clamp(28px,3vw,40px);
}
.leadership-featured .leadership-role{color:#1A3B8B;}
.leadership-featured .leadership-name{font-size:clamp(26px,2.6vw,36px);color:#1A3B8B;}
.leadership-subhead{
  font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#0A0A0A;
  padding-bottom:8px;border-bottom:1.5px solid #0A0A0A;
}
.leadership-role{
  font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#5A5A5A;
}
.leadership-name{
  font-size:clamp(22px,2.3vw,30px);font-weight:900;letter-spacing:-.01em;line-height:1.15;color:#0A0A0A;
}
.leadership-sub{font-size:14px;line-height:1.5;color:#3A3A3A;}
.leadership-note{
  font-size:14.5px;line-height:1.6;color:#3A3A3A;max-width:760px;margin:0;
  padding-left:18px;border-left:3px solid #F5B71A;
}

/* =====================================================
   DIRECTORY STRIP — compact 2-up nav cards
   ===================================================== */
.dir-strip{
  width:calc(100% - 2 * var(--pad));max-width:calc(var(--max) - 2 * var(--pad));
  margin:clamp(24px,3vw,48px) auto clamp(40px,5vw,72px);
  display:grid;grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));gap:16px;
}
@media(max-width:760px){.dir-strip{grid-template-columns:1fr;}}
.dir-strip-card{
  background:#FFFFFF;border:1.5px solid #0A0A0A;border-radius:18px;
  padding:24px 28px;display:flex;flex-direction:column;gap:6px;
  color:#0A0A0A;text-decoration:none;transition:transform .15s ease,background .15s ease;
}
.dir-strip-card:hover{transform:translateY(-2px);background:var(--card-cream);}
.dir-strip-cat{
  font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#5A5A5A;
}
.dir-strip-title{
  font-size:clamp(20px,2vw,26px);font-weight:900;letter-spacing:-.01em;
}
.dir-strip-sub{font-size:14px;color:#3A3A3A;line-height:1.45;}

/* CTA band, big colored stripe with a button */
.page-cta{
  /* match the same gutter as .l-archive-strip / .page-head / .l-entry-grid */
  width:calc(100% - 2 * var(--pad));
  max-width:calc(var(--max) - 2 * var(--pad));
  margin:0 auto clamp(40px,5vw,80px);
  background:var(--card-pink);
  border-radius:24px;padding:clamp(40px,5vw,72px);
  display:flex;flex-direction:column;gap:24px;
}
.page-cta--yellow{background:var(--card-yellow);}
.page-cta--green{background:var(--card-green);}
.page-cta--cyan{background:var(--card-cyan);}
.page-cta--purple{background:var(--card-purple);}
.page-cta--cream{background:var(--card-cream);}
.page-cta--red{background:var(--card-red);}
.page-cta--blue{background:var(--card-blue);}

/* Flush variant — full-bleed, no background, gutter matches the rest of the page, kisses the footer with zero gap */
.page-cta--flush{
  width:100%;max-width:none;
  margin-left:0;margin-right:0;margin-bottom:0;
  border-radius:0;
  background:transparent;
  padding:clamp(32px,3.5vw,56px) var(--pad);
}
.page-cta--flush .page-cta-inner{
  max-width:var(--max);
  /* Left-aligned to the page gutter; auto-margin only on the right so wide screens don't drift centered */
  margin:0 auto 0 0;
  display:flex;flex-direction:column;align-items:flex-start;gap:18px;
  text-align:left;
}
.page-cta--flush .page-cta-inner > *{text-align:left;}

/* Stroke / outline variant — quiet, framed CTA instead of a solid block of color */
.page-cta--outline{
  background:#FFFFFF;
  border:2px solid #D32F3E;
  color:#0A0A0A;
}
.page-cta--outline h2,
.page-cta--outline p{color:#0A0A0A;}
.page-cta--outline em{
  background:rgba(211,47,62,.10);
  padding:0 .2em;border-radius:4px;font-style:normal;
}

/* === Accessibility: white text on dark page-cta variants === */
.page-cta--cyan h2, .page-cta--cyan p, .page-cta--cyan a:not(.l-event-hero-cta):not(.btn-pill-ghost),
.page-cta--purple h2, .page-cta--purple p, .page-cta--purple a:not(.l-event-hero-cta):not(.btn-pill-ghost),
.page-cta--red h2, .page-cta--red p, .page-cta--red a:not(.l-event-hero-cta):not(.btn-pill-ghost),
.page-cta--blue h2, .page-cta--blue p, .page-cta--blue a:not(.l-event-hero-cta):not(.btn-pill-ghost){
  color:#FFFFFF;
}
.page-cta--cyan b, .page-cta--purple b, .page-cta--red b, .page-cta--blue b{
  color:#FFFFFF;
}
/* Ghost button on dark CTAs needs white border */
.page-cta--cyan .btn-pill-ghost,
.page-cta--purple .btn-pill-ghost,
.page-cta--red .btn-pill-ghost,
.page-cta--blue .btn-pill-ghost{
  color:#FFFFFF;border-color:#FFFFFF;
}
.page-cta--cyan .btn-pill-ghost:hover,
.page-cta--purple .btn-pill-ghost:hover,
.page-cta--red .btn-pill-ghost:hover,
.page-cta--blue .btn-pill-ghost:hover{
  background:#FFFFFF;color:#0A0A0A;
}

/* === Accessibility: yellow card text → pure BLACK (11:1 AAA) === */
.page-cta--yellow h2, .page-cta--yellow p,
.page-cta--yellow .page-head-eyebrow{color:#0A0A0A;}
/* Override the entry-card yellow text from navy to black for AAA contrast on small body text */
.l-entry-card--yellow,
.l-entry-card--orange{color:#0A0A0A;}
.l-entry-card--yellow .l-entry-cat, .l-entry-card--orange .l-entry-cat,
.l-entry-card--yellow .l-entry-title, .l-entry-card--orange .l-entry-title,
.l-entry-card--yellow .l-entry-sub, .l-entry-card--orange .l-entry-sub,
.l-entry-card--yellow .l-entry-arrow, .l-entry-card--orange .l-entry-arrow{color:#0A0A0A;}

/* Full-bleed variant — banner that spans the whole viewport edge-to-edge */
.page-cta--full{
  width:100%;
  max-width:none;
  margin-left:0;margin-right:0;
  border-radius:0;
  padding-left:0;padding-right:0;
  padding-top:clamp(56px,7vw,96px);
  padding-bottom:clamp(56px,7vw,96px);
}
.page-cta--full .page-cta-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:flex;flex-direction:column;gap:24px;
}

/* Wide-text variant — headline spans the full card width (drops the 18ch cap) */
.page-cta--wide-text h2{
  max-width:none;
}

.page-cta h2{
  font-size:clamp(28px,3.6vw,48px);font-weight:900;
  letter-spacing:-0.04em;line-height:1;color:#0A0A0A;
  text-transform:none;max-width:18ch;
}
.page-cta p{
  font-size:15px;font-weight:500;line-height:1.55;color:#0A0A0A;max-width:560px;
}
.page-cta .l-event-hero-cta{align-self:flex-start;}

/* Pill ghost button (light pages) */
.btn-pill-ghost{
  display:inline-flex;align-items:center;
  padding:16px 26px;border-radius:999px;
  font-size:13px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;
  background:transparent;color:#0A0A0A;border:2px solid #0A0A0A;
  transition:background .15s var(--ease),color .15s var(--ease);
}
.btn-pill-ghost:hover{background:#0A0A0A;color:#FFFFFF;}

/* Luma calendar embed wrapper (chapter.html) */
.luma-embed{
  max-width:var(--max);margin:0 auto;
  padding:0 var(--pad) clamp(40px,5vw,72px);
}
.luma-embed iframe{
  width:100%;min-height:640px;display:block;
}
.luma-embed-fallback{
  margin-top:14px;font-size:12.5px;color:#5A5A5A;text-align:center;
}
.luma-embed-fallback a{color:#1A3B8B;font-weight:700;text-decoration:underline;}

/* =====================================================
   SPEAKER DIRECTORY (SXSW-style speakers grid)
   Compact cards, photo/initial placeholder, search + alphabet jump.
   ===================================================== */

/* sticky toolbar with search + filter chips */
.directory-toolbar{
  position:sticky;top:var(--nav-h);z-index:40;
  background:rgba(255,255,255,.95);backdrop-filter:saturate(140%) blur(6px);
  padding:18px var(--pad);
  max-width:var(--max);margin:0 auto;
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;
  border-bottom:1px solid #E5E5E5;
}
.directory-search{
  flex:1;min-width:240px;
  display:flex;align-items:center;gap:10px;
  background:#F5F5F5;border:1px solid #E5E5E5;border-radius:999px;
  padding:10px 18px;
}
.directory-search-ico{font-size:16px;color:#5A5A5A;}
.directory-search input{
  flex:1;background:0;border:0;outline:0;
  font-family:inherit;font-size:14px;font-weight:600;color:#0A0A0A;
}
.directory-search input::placeholder{color:#9A9A9A;font-weight:500;}
.directory-filters{display:flex;gap:6px;flex-wrap:wrap;}
.directory-filters .chip{
  background:#F4F4F4;color:#0A0A0A;border:1px solid #E5E5E5;
  border-radius:999px;height:32px;padding:0 14px;
  font-size:11.5px;font-weight:800;letter-spacing:.04em;
  cursor:pointer;text-transform:uppercase;
}
.directory-filters .chip:hover{border-color:#0A0A0A;}
.directory-filters .chip.is-on{
  background:#1A3B8B;color:#FFFFFF;border-color:#1A3B8B;
}

/* Year-dropdown · sits next to the role chips */
.directory-year-wrap{
  display:inline-flex;align-items:center;gap:8px;
  background:#F4F4F4;border:1px solid #E5E5E5;
  border-radius:999px;height:32px;padding:0 8px 0 14px;
  margin-left:6px;
}
.directory-year-wrap:hover{border-color:#0A0A0A;}
.directory-year-label{
  font-size:11.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#5A5A5A;
}
.directory-year-select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background:transparent;border:0;cursor:pointer;
  font-family:inherit;font-size:11.5px;font-weight:800;letter-spacing:.04em;
  text-transform:uppercase;color:#0A0A0A;
  padding-right:18px;height:30px;outline:0;
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%230A0A0A' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right center;background-size:10px 6px;
}
.directory-year-select:focus{outline:0;}

/* alphabet jump nav */
.directory-letters{
  display:flex;gap:4px;flex-wrap:wrap;justify-content:center;
  max-width:var(--max);margin:24px auto;padding:0 var(--pad);
}
.directory-letters a{
  width:32px;height:32px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:900;color:#0A0A0A;
  background:transparent;border:1px solid transparent;
  transition:background .15s var(--ease),border-color .15s var(--ease);
}
.directory-letters a:hover{
  background:var(--card-yellow);color:#0A0A0A;
}
.directory-letters a.is-disabled{
  color:#C5C5C5;pointer-events:none;
}

/* alphabet section heading */
.directory-letter-head{
  font-size:clamp(56px,8vw,96px);font-weight:900;
  letter-spacing:-0.06em;line-height:.9;color:#0A0A0A;
  padding:32px var(--pad) 8px;
  max-width:var(--max);margin:0 auto;
}

/* speaker grid */
.speaker-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:14px;
  max-width:var(--max);margin:0 auto;padding:clamp(20px,2.5vw,32px) var(--pad) 40px;
}
/* Open-seat recruitment card · dashed outline + plus-icon photo, distinguishes it from real members */
.speaker-card--open{
  border:2px dashed #1A3B8B !important;
  background:transparent !important;
  box-shadow:none !important;
  transition:background .2s ease,transform .15s ease;
}
.speaker-card--open:hover{
  background:rgba(26,59,139,.06) !important;
  transform:translateY(-2px);
}
.speaker-card--open .speaker-name{color:#1A3B8B;}
.speaker-card--open .speaker-role{color:#3A3A3A;}
.speaker-photo--plus{
  background:transparent !important;
  background-image:none !important;
  display:flex;align-items:center;justify-content:center;
  border:2px dashed #1A3B8B;
  color:#1A3B8B;font-size:30px;font-weight:300;line-height:1;
}

/* N-up overrides · used on about.html leadership where we want exactly N columns regardless of card count */
.leadership-grid-3up,
.leadership-grid-4up{
  /* Parent .leadership section already supplies the page gutter — kill the duplicate horizontal padding so cards sit flush with the eyebrow/text above */
  padding:0 0 clamp(24px,3vw,40px);
  max-width:none;
  margin:0;
}
.leadership-grid-3up{grid-template-columns:repeat(3,1fr);}
.leadership-grid-4up{grid-template-columns:repeat(4,1fr);}
@media(max-width:1100px){.leadership-grid-4up{grid-template-columns:repeat(2,1fr);}}
@media(max-width:960px){.leadership-grid-3up{grid-template-columns:repeat(2,1fr);}}
@media(max-width:680px){.leadership-grid-3up,.leadership-grid-4up{grid-template-columns:1fr;}}

/* Tight leadership variant · used when the head is a simple eyebrow only */
.leadership--tight{
  margin-top:clamp(8px,1vw,16px);
  margin-bottom:clamp(8px,1vw,16px);
  gap:12px;
}
.leadership-head--simple{
  gap:0;
}
.leadership-head--simple .page-head-eyebrow{
  color:#1A3B8B;font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  margin:0;
}

/* Board directory · section grouping (used on directory-board.html) */
.board-section{margin-top:clamp(32px,4vw,56px);}
.board-section:first-child{margin-top:0;}
.board-section-head{
  max-width:var(--max);margin:0 auto;padding:0 var(--pad);
  font-size:clamp(20px,2.4vw,30px);font-weight:900;letter-spacing:-.01em;
  color:#0A0A0A;
  display:flex;align-items:center;gap:14px;
}
.board-section-head::after{
  content:"";flex:1;height:2px;background:#0A0A0A;
}
.speaker-card{
  background:#FFFFFF;border:1px solid #E5E5E5;border-radius:18px;
  padding:22px 22px 20px;
  display:flex;flex-direction:column;gap:8px;
  transition:border-color .15s var(--ease),transform .15s var(--ease),box-shadow .15s var(--ease);
  cursor:pointer;color:#0A0A0A;
  min-height:230px;
}
.speaker-card:hover{
  border-color:#1A3B8B;transform:translateY(-3px);
  box-shadow:0 8px 20px rgba(26,59,139,.08);
  color:#0A0A0A;
}
.speaker-photo{
  width:64px;height:64px;border-radius:50%;
  position:relative;overflow:hidden;
  background:#E8E8E8;
  /* Generic person silhouette placeholder — gets hidden when an <img> is dropped inside */
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%230A0A0A' fill-opacity='0.32'%3E%3Cpath d='M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center 95%;background-size:78%;
  font-size:0;     /* hide initial letters until photos arrive */
  margin-bottom:6px;
}
/* When a real photo loads, the <img> covers the placeholder */
.speaker-photo img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;border-radius:inherit;
}
/* Color variants now act as a subtle tint behind the silhouette (uniform soft gray by default; tint kicks in only if the variant class is present) */
.speaker-photo--pink,
.speaker-photo--yellow,
.speaker-photo--cyan,
.speaker-photo--green,
.speaker-photo--orange,
.speaker-photo--lilac,
.speaker-photo--cream,
.speaker-photo--blue,
.speaker-photo--red,
.speaker-photo--purple{background-color:#E8E8E8;}

.speaker-name{
  font-size:16px;font-weight:900;letter-spacing:-0.01em;
  line-height:1.15;color:#0A0A0A;
}
.speaker-role{
  font-size:12.5px;font-weight:600;color:#3A3A3A;line-height:1.4;
}
.speaker-tags{
  display:flex;flex-wrap:wrap;gap:5px;margin-top:auto;padding-top:8px;
}
.speaker-tags span{
  font-size:9.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 8px;border-radius:999px;
  background:#F5F5F5;color:#3A3A3A;
}
.speaker-tags span.is-year{background:#F4ECD8;color:#0A0A0A;}
.speaker-tags span.is-track{background:#E8EEF8;color:#1A3B8B;}

/* empty state when search has no matches */
.directory-empty{
  text-align:center;padding:80px var(--pad);
  font-size:15px;color:#5A5A5A;
  display:none;
}
.directory-empty.is-visible{display:block;}

/* =====================================================
   MODAL POPUP (intake forms for get-involved, etc.)
   Opens in place wherever the user is scrolled.
   ===================================================== */
.modal-scrim{
  position:fixed;inset:0;z-index:90;
  background:rgba(10,10,10,.55);
  opacity:0;pointer-events:none;
  transition:opacity .25s var(--ease);
}
.modal-scrim.is-open{opacity:1;pointer-events:auto;}
.modal{
  position:fixed;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(.96);
  z-index:91;
  width:min(560px,calc(100vw - 32px));
  max-height:calc(100vh - 64px);
  background:#FFFFFF;color:#0A0A0A;
  border-radius:24px;
  padding:clamp(28px,4vw,40px);
  overflow-y:auto;
  opacity:0;pointer-events:none;
  transition:opacity .25s var(--ease), transform .25s var(--ease);
  box-shadow:0 24px 60px rgba(0,0,0,.28);
}
.modal.is-open{
  opacity:1;pointer-events:auto;
  transform:translate(-50%,-50%) scale(1);
}
.modal-close{
  position:absolute;top:16px;right:16px;
  width:36px;height:36px;border-radius:50%;
  border:1px solid #E5E5E5;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;color:#0A0A0A;font-family:inherit;
  cursor:pointer;background:#FFFFFF;
  transition:border-color .15s var(--ease),background .15s var(--ease);
}
.modal-close:hover{border-color:#0A0A0A;background:#0A0A0A;color:#FFFFFF;}
.modal-eyebrow{
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:#1A3B8B;margin-bottom:10px;
}
.modal h2{
  font-size:clamp(22px,3vw,32px);font-weight:900;
  letter-spacing:-0.03em;line-height:1.05;color:#0A0A0A;
  margin:0 0 10px;text-transform:none;
}
.modal-lead{
  font-size:14px;font-weight:500;color:#3A3A3A;line-height:1.5;
  margin:0 0 24px;
}
.modal-lead b{color:#0A0A0A;font-weight:900;}
.modal-form{display:flex;flex-direction:column;gap:14px;}
.modal-form label{
  display:flex;flex-direction:column;gap:6px;
  font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:#3A3A3A;
}
.modal-form input,
.modal-form select,
.modal-form textarea{
  padding:12px 14px;
  font-family:inherit;font-size:14px;font-weight:500;
  background:#F5F5F5;border:1px solid #E5E5E5;border-radius:10px;
  color:#0A0A0A;
  transition:border-color .15s var(--ease),background .15s var(--ease);
}
.modal-form input:focus,
.modal-form select:focus,
.modal-form textarea:focus{
  outline:none;border-color:#1A3B8B;background:#FFFFFF;
}
.modal-form textarea{resize:vertical;min-height:84px;}
.modal-submit{
  align-self:flex-start;margin-top:8px;
  display:inline-flex;align-items:center;gap:8px;
  background:#1A3B8B;color:#FFFFFF;
  padding:14px 26px;border-radius:999px;
  font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;
  border:0;cursor:pointer;font-family:inherit;
  transition:background .15s var(--ease);
}
.modal-submit:hover{background:#0A0A0A;color:#FFFFFF;}
.modal-foot{
  margin-top:18px;padding-top:18px;border-top:1px solid #E5E5E5;
  font-size:12px;color:#5A5A5A;
}

/* =====================================================
   SCHEDULE PAGE in light + colorful mode
   Keeps day-tabs/schedule grid/drawer layout, repaints surfaces.
   ===================================================== */

/* override page background so footer doesn't show body bg */
.page-schedule{background:#FFFFFF;color:#0A0A0A;}

/* page header (replaces inline styles) */
.page-schedule .schedule-head{
  padding:32px var(--pad) 16px;
  max-width:var(--max);margin:0 auto;
}
.page-schedule .schedule-head-eyebrow{
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:#1A3B8B;margin-bottom:10px;
}
.page-schedule .schedule-head-title{
  font-size:clamp(36px,5vw,68px);font-weight:900;
  letter-spacing:-0.045em;line-height:1;color:#0A0A0A;
}
.page-schedule .schedule-head-title em{
  font-style:italic;background:var(--card-yellow);
  padding:0 8px;color:#0A0A0A;font-weight:900;
}
.page-schedule .schedule-head-meta{
  display:flex;flex-wrap:wrap;gap:24px;
  margin-top:20px;font-size:13px;color:#5A5A5A;font-weight:600;
}
.page-schedule .schedule-head-meta b{color:#0A0A0A;font-weight:800;}
.page-schedule .schedule-head-status{
  background:var(--card-yellow);color:#0A0A0A;
  padding:2px 8px;font-weight:900;
}

/* filter bar */
.page-schedule .app-filterbar{
  background:#FFFFFF;border-bottom:1px solid #E5E5E5;
}
.page-schedule .app-filterbar-label{color:#5A5A5A;}
.page-schedule .chip{
  background:#F4F4F4;color:#0A0A0A;
  border:1px solid #E5E5E5;border-radius:999px;
}
.page-schedule .chip:hover{border-color:#0A0A0A;}
.page-schedule .chip.is-on{
  background:#0A0A0A;color:#FFFFFF;border-color:#0A0A0A;
}

/* day tabs */
.page-schedule .day-tabs{
  border-bottom:1px solid #E5E5E5;gap:12px;
  padding:0 var(--pad);
}
.page-schedule .day-tab{
  background:var(--card-cream);color:#0A0A0A;
  border:0;border-radius:20px 20px 0 0;
  padding:20px 24px;margin-bottom:0;
}
.page-schedule .day-tab:hover{background:var(--card-yellow);}
.page-schedule .day-tab.is-active{background:var(--card-green);}
.page-schedule .day-tab.is-active::after{
  background:#0A0A0A;height:4px;left:24px;right:24px;
}
.page-schedule .day-tab-num{color:#5A5A5A;}
.page-schedule .day-tab.is-active .day-tab-num{color:#0A0A0A;}
.page-schedule .day-tab-day{color:#0A0A0A;}
.page-schedule .day-tab-date{color:#3A3A3A;}

/* schedule grid */
.page-schedule .schedule{
  padding:0 var(--pad);max-width:var(--max);margin:0 auto;
  grid-template-columns:88px 1fr;
}
.page-schedule .schedule-time{
  color:#5A5A5A;
  border-right:1px solid #E5E5E5;
  border-bottom:1px solid #E5E5E5;
}
.page-schedule .session{
  background:#FFFFFF;color:#0A0A0A;
  border-bottom:1px solid #E5E5E5;
  border-radius:0;
}
.page-schedule .session:hover{background:#F8F8F8;}
.page-schedule .session-strip{background:#E5E5E5;width:4px;}
.page-schedule .session-top{color:#5A5A5A;}
.page-schedule .session-track{color:#0A0A0A;}
.page-schedule .session-title{color:#0A0A0A;}
.page-schedule .session-speakers{color:#5A5A5A;}
.page-schedule .session-speakers b{color:#0A0A0A;}
.page-schedule .session-meta{color:#5A5A5A;}

/* track colors — softer light-mode equivalents on the strip */
.page-schedule .session.t-keynote .session-strip{background:var(--card-yellow);}
.page-schedule .session.t-panel .session-strip{background:var(--card-purple);}
.page-schedule .session.t-workshop .session-strip{background:var(--card-pink);}
.page-schedule .session.t-social .session-strip{background:var(--card-cream);}
.page-schedule .session.t-network .session-strip{background:var(--card-cyan);}
.page-schedule .session.t-keynote .session-track{color:#A88A00;}
.page-schedule .session.t-workshop .session-track{color:#C73063;}
.page-schedule .session.t-network .session-track{color:#2A7060;}
.page-schedule .session.t-panel .session-track{color:#6B47C0;}

/* chip dots — recolor for light mode so they match the strip palette */
.page-schedule .chip[data-track="t-keynote"] .chip-dot{background:var(--card-yellow)!important;}
.page-schedule .chip[data-track="t-panel"] .chip-dot{background:var(--card-purple)!important;}
.page-schedule .chip[data-track="t-workshop"] .chip-dot{background:var(--card-pink)!important;}
.page-schedule .chip[data-track="t-social"] .chip-dot{background:#9A9A9A!important;}
.page-schedule .chip[data-track="t-network"] .chip-dot{background:var(--card-cyan)!important;}

/* speakers preview */
.page-schedule .sec-h{
  padding:48px var(--pad) 16px;
  max-width:var(--max);margin:0 auto;
  border-top:0;
}
.page-schedule .sec-h h2{color:#0A0A0A;}
.page-schedule .sec-h-link{
  background:#0A0A0A;color:#FFFFFF;padding:8px 14px;border-radius:999px;
  font-size:11px;font-weight:800;letter-spacing:.14em;
}
.page-schedule .card-grid{
  max-width:var(--max);margin:0 auto;
  padding:0 var(--pad) 48px;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:12px;background:transparent;
  border-top:0;border-bottom:0;
}
.page-schedule .card{
  background:var(--card-cream);color:#0A0A0A;
  border-radius:20px;
  padding:24px;min-height:180px;
}
.page-schedule .card:hover{background:var(--card-yellow);color:#0A0A0A;}
.page-schedule .card-top{color:#5A5A5A;}
.page-schedule .card-top .hot{color:#1A3B8B;}
.page-schedule .card-title{color:#0A0A0A;}
.page-schedule .card-cta{color:#1A3B8B;}
.page-schedule .card-meta{color:#5A5A5A;}
.page-schedule .card-meta span{color:#0A0A0A;}

/* drawer in light mode */
.page-schedule .drawer{
  background:#FFFFFF;
  border-left:1px solid #E5E5E5;
}
.page-schedule .drawer-close{
  border:1px solid #E5E5E5;color:#0A0A0A;
  border-radius:999px;
}
.page-schedule .drawer-close:hover{border-color:#0A0A0A;color:#0A0A0A;}
.page-schedule .drawer-top{color:#1A3B8B;}
.page-schedule .drawer-title{color:#0A0A0A;}
.page-schedule .drawer-meta{
  border-top:1px solid #E5E5E5;border-bottom:1px solid #E5E5E5;
  color:#0A0A0A;
}
.page-schedule .drawer-meta dt{color:#5A5A5A;}
.page-schedule .drawer-body{color:#3A3A3A;}
.page-schedule .drawer .btn{
  background:#0A0A0A;color:#FFFFFF;border-color:#0A0A0A;
  border-radius:999px;
}
.page-schedule .drawer .btn--hot{background:#1A3B8B;color:#FFFFFF;border-color:#1A3B8B;}
.page-schedule .drawer .btn--hot:hover{background:#0A0A0A;border-color:#0A0A0A;}
.page-schedule .drawer .btn--ghost{
  background:transparent;color:#0A0A0A;border-color:#E5E5E5;
}
.page-schedule .drawer .btn--ghost:hover{border-color:#0A0A0A;color:#0A0A0A;}

@media(max-width:560px){
  .page-schedule .day-tabs{gap:6px;padding:0 12px;}
  .page-schedule .day-tab{padding:14px 12px;}
  .page-schedule .schedule{grid-template-columns:64px 1fr;}
}

/* ---------- light page responsive ---------- */
@media(max-width:1100px){
  .l-entry-grid{grid-template-columns:repeat(3,1fr);}
  .l-entry-card--xl{grid-column:span 2;grid-row:span 2;}
  .l-entry-card--tall{grid-row:span 2;min-height:380px;}
  .l-entry-card--wide{grid-column:span 3;}
}
@media(max-width:900px){
  .l-catchup{grid-template-columns:1fr;}
  .l-twocard{grid-template-columns:1fr;}
  .l-programs{grid-template-columns:1fr 1fr;}
  .l-archive-strip{grid-template-columns:1fr 1fr;}
  .l-quicklinks{grid-template-columns:1fr 1fr;}
  .l-next-card{grid-template-columns:1fr;}
  .l-next-badge{padding:0 48px 48px;}
  .l-footer-grid{grid-template-columns:1fr 1fr;}
  .l-entry-grid{grid-template-columns:repeat(2,1fr);}
  .l-entry-card--xl{min-height:320px;}
  .l-entry-card--tall{grid-row:span 1;min-height:200px;}
  .l-entry-card--wide{grid-column:span 2;min-height:160px;}
}
@media(max-width:560px){
  .l-programs{grid-template-columns:1fr;}
  .l-archive-strip{grid-template-columns:1fr;}
  .l-quicklinks{grid-template-columns:1fr;}
  .l-footer-grid{grid-template-columns:1fr;}
  .l-entry-grid{grid-template-columns:1fr;}
  .l-entry-card--xl{grid-column:span 1;grid-row:auto;min-height:280px;}
  .l-entry-card--tall{grid-column:span 1;grid-row:auto;min-height:200px;}
  .l-entry-card--wide{grid-column:span 1;}
  .l-event-hero-title{font-size:clamp(32px,9vw,48px);}
}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .app-nav-sponsor{display:none;}
  .app-nav-link{padding:0 12px;font-size:12px;}
  .schedule{grid-template-columns:64px 1fr;}
  .schedule-time{font-size:10px;padding:6px 8px 0;}
  .split-2{grid-template-columns:1fr;}
  .split-aside{border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:24px;}
}
@media(max-width:720px){
  :root{--nav-h:64px;}
  .app-nav-tier2{display:none;}
  .app-nav-pill--ghost{display:none;}
  .app-nav-toggle{
    display:flex;align-items:center;justify-content:center;
    width:38px;height:38px;border-radius:50%;
    background:#3A3A3A;color:#FFF;font-size:16px;font-weight:800;
  }
}
@media(max-width:600px){
  :root{--pad:16px;}
  .day-tab{padding:14px 12px;}
  .day-tab-day{font-size:18px;}
  .strip-card{flex:0 0 270px;}
  .app-hero-foot{flex-direction:column;align-items:flex-start;}
  .app-hero-foot .btn{width:100%;justify-content:center;}
}
