/* ============================================================
   SheetMetalCON '26 — main.css
   The unified stylesheet. v1.337.

   3.. 2.. 1.. let's bend.
   RIP Forum DC30, DC31 — they took our home, but we forge on.
   The Forum is sacred.
   ============================================================ */

:root {
  --navy:        #15243f;
  --navy-deep:   #0d1729;
  --navy-soft:   #243653;
  --steel:       #4a5568;
  --steel-soft:  #8a96a8;
  --steel-pale:  #e2e8ee;
  --bone:        #f6f3ec;
  --paper:       #ffffff;
  --forge:       #c94a1f;
  --forge-deep:  #9a3614;
  --gold:        #b48529;
  --ink:         #14181f;

  /* Track palette */
  --t100: #c94a1f;
  --t200: #2e6ca5;
  --t300: #b48529;
  --t400: #4a8a7b;
  --t500: #6e4a8a;
  --t000: #14181f;
  --plen: #15243f;

  /* Sponsor tier palette */
  --tier-titanium: #0d1729;
  --tier-platinum: #6e7790;
  --tier-gold:     #b48529;
  --tier-silver:   #8a96a8;
  --tier-forge:    #c94a1f;

  /* Type */
  --display: 'Barlow Condensed', 'Arial Narrow', sans-serif;
  --body:    'IBM Plex Sans', 'Helvetica Neue', sans-serif;

  /* Layout */
  --max-w: 1240px;
}

/* ============================================================
   GLOBAL RESET & BASE
   ============================================================ */
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
}
img, svg { display: block; max-width: 100%; }
a { color: var(--forge); text-decoration: none; }
a:hover { text-decoration: underline; }

.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 28px;
}

/* hidden Skytalks-style content holder (off-the-record) */
.skytalks { display: none; }

/* ============================================================
   UTILITY BAR
   ============================================================ */
.utility-bar {
  background: var(--navy-deep);
  color: var(--steel-pale);
  font-size: 13px;
  letter-spacing: 0.02em;
  padding: 8px 0;
  border-bottom: 1px solid #00000044;
}
.utility-bar .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.utility-bar .contact a,
.utility-bar .links a {
  color: var(--steel-pale);
  margin-right: 18px;
}
.utility-bar .contact a:hover,
.utility-bar .links a:hover {
  color: var(--forge);
  text-decoration: none;
}
.utility-bar .links a:last-child { margin-right: 0; }

/* ============================================================
   MAIN NAV
   I Am The Cavalry of the metal forming industry.
   ============================================================ */
.main-nav {
  background: var(--paper);
  border-bottom: 1px solid var(--steel-pale);
  position: sticky;
  top: 0;
  z-index: 50;
}
.main-nav .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 78px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}
.brand-mark {
  width: 38px;
  height: 38px;
}
.brand-text {
  font-family: var(--display);
  font-weight: 800;
  font-size: 22px;
  color: var(--navy);
  letter-spacing: 0.02em;
  line-height: 1;
}
.brand-text .yr {
  color: var(--forge);
  margin-left: 2px;
}
.brand-tag {
  font-family: var(--body);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--steel);
  text-transform: uppercase;
  display: block;
  margin-top: 3px;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 28px;
  list-style: none;
}
.nav-links a {
  color: var(--navy);
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-family: var(--display);
  font-size: 17px;
}
.nav-links a:hover {
  color: var(--forge);
  text-decoration: none;
}
.nav-links a.active { color: var(--forge); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-block;
  padding: 12px 24px;
  font-family: var(--display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 2px solid transparent;
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
}
.btn-primary {
  background: var(--forge);
  color: var(--paper);
  border-color: var(--forge);
}
.btn-primary:hover {
  background: var(--forge-deep);
  border-color: var(--forge-deep);
  text-decoration: none;
  color: var(--paper);
}
.btn-secondary {
  background: transparent;
  color: var(--paper);
  border-color: var(--paper);
}
.btn-secondary:hover {
  background: var(--paper);
  color: var(--navy);
  text-decoration: none;
}
.btn-ghost {
  background: transparent;
  color: var(--navy);
  border-color: var(--navy);
}
.btn-ghost:hover {
  background: var(--navy);
  color: var(--paper);
  text-decoration: none;
}

/* ============================================================
   HERO (homepage)
   ============================================================ */
.hero {
  background:
    linear-gradient(135deg, rgba(13,23,41,0.92) 0%, rgba(36,54,83,0.88) 100%),
    repeating-linear-gradient(
      115deg,
      #1a2b48 0px, #1a2b48 2px,
      #15243f 2px,  #15243f 22px,
      #1c2e4d 22px, #1c2e4d 24px,
      #15243f 24px, #15243f 60px
    );
  color: var(--paper);
  padding: 88px 0 96px;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 30%, rgba(201,74,31,0.18) 0%, transparent 45%),
    radial-gradient(circle at 82% 78%, rgba(180,133,41,0.10) 0%, transparent 50%);
  pointer-events: none;
}
.hero .container { position: relative; z-index: 1; }

.hero-eyebrow {
  font-family: var(--display);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.32em;
  color: var(--forge);
  text-transform: uppercase;
  margin-bottom: 18px;
}
.hero-eyebrow::before {
  content: "▲ ";
  font-size: 12px;
  margin-right: 4px;
}
.hero h1 {
  font-family: var(--display);
  font-size: clamp(56px, 9vw, 132px);
  font-weight: 800;
  line-height: 0.92;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin-bottom: 22px;
}
.hero h1 .yr { color: var(--forge); }
.hero-tagline {
  font-family: var(--display);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--steel-pale);
  text-transform: uppercase;
  max-width: 720px;
  margin-bottom: 36px;
}
.hero-meta {
  display: flex;
  gap: 48px;
  margin-bottom: 44px;
  flex-wrap: wrap;
}
.hero-meta .meta-item {
  border-left: 3px solid var(--forge);
  padding-left: 16px;
}
.hero-meta .meta-label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--steel-soft);
  margin-bottom: 4px;
}
.hero-meta .meta-value {
  font-family: var(--display);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--paper);
}
.hero-ctas {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

/* ============================================================
   PAGE HERO (interior pages)
   ============================================================ */
.page-hero {
  background:
    linear-gradient(135deg, rgba(13,23,41,0.94) 0%, rgba(36,54,83,0.90) 100%),
    repeating-linear-gradient(
      115deg,
      #1a2b48 0px, #1a2b48 2px,
      #15243f 2px,  #15243f 22px,
      #1c2e4d 22px, #1c2e4d 24px,
      #15243f 24px, #15243f 60px
    );
  color: var(--paper);
  padding: 64px 0 56px;
}
.page-hero .eyebrow {
  font-family: var(--display);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.3em;
  color: var(--forge);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.page-hero h1 {
  font-family: var(--display);
  font-size: clamp(48px, 7vw, 96px);
  font-weight: 800;
  line-height: 0.95;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.page-hero p {
  font-size: 18px;
  max-width: 720px;
  color: var(--steel-pale);
}

/* ============================================================
   STATS STRIP (homepage + speakers sub-strip)
   ============================================================ */
.stats {
  background: var(--navy);
  color: var(--paper);
  padding: 56px 0;
  border-top: 1px solid #ffffff14;
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.stat {
  text-align: center;
  padding: 8px 12px;
  border-right: 1px solid #ffffff1a;
}
.stat:last-child { border-right: none; }
.stat-num {
  font-family: var(--display);
  font-size: clamp(48px, 5.5vw, 72px);
  font-weight: 800;
  color: var(--forge);
  line-height: 1;
  letter-spacing: -0.01em;
}
.stat-label {
  font-size: 12px;
  letter-spacing: 0.22em;
  font-weight: 500;
  text-transform: uppercase;
  color: var(--steel-pale);
  margin-top: 14px;
}

/* speakers page mini stats */
.stats-sub {
  background: var(--bone);
  padding: 28px 0;
  border-bottom: 1px solid var(--steel-pale);
}
.stats-sub .container {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
}
.stat-mini { text-align: center; padding: 4px; }
.stat-mini .num {
  font-family: var(--display);
  font-size: 38px;
  font-weight: 800;
  color: var(--forge);
  line-height: 1;
}
.stat-mini .lbl {
  font-size: 11px;
  letter-spacing: 0.2em;
  font-weight: 500;
  text-transform: uppercase;
  color: var(--steel);
  margin-top: 6px;
}

/* ============================================================
   GENERIC SECTIONS
   ============================================================ */
.section { padding: 96px 0; }
.section-tight { padding: 80px 0; }
.section.bg-bone { background: var(--bone); }
.section-tight.bg-bone { background: var(--bone); }

.section-eyebrow {
  font-family: var(--display);
  font-size: 14px;
  letter-spacing: 0.3em;
  font-weight: 600;
  color: var(--forge);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.section h2,
.section-tight h2 {
  font-family: var(--display);
  font-size: clamp(40px, 5.2vw, 64px);
  font-weight: 800;
  line-height: 1;
  color: var(--navy);
  letter-spacing: -0.01em;
  text-transform: uppercase;
  max-width: 820px;
  margin-bottom: 24px;
}
.section .lead,
.section-tight .lead {
  max-width: 720px;
  font-size: 18px;
  color: var(--steel);
  line-height: 1.65;
  margin-bottom: 56px;
}
.section-header { margin-bottom: 36px; }

/* ============================================================
   CARDS — "Why Attend" 3-up
   ============================================================ */
.cards-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.card {
  background: var(--paper);
  padding: 34px 30px 32px;
  border-top: 4px solid var(--forge);
  box-shadow: 0 1px 0 rgba(20,24,31,0.04), 0 8px 24px rgba(20,24,31,0.06);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.card:hover {
  transform: translateY(-3px);
  box-shadow: 0 1px 0 rgba(20,24,31,0.04), 0 14px 38px rgba(20,24,31,0.10);
}
.card .ico {
  width: 44px;
  height: 44px;
  margin-bottom: 18px;
  color: var(--forge);
}
.card h3 {
  font-family: var(--display);
  font-size: 26px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.01em;
}
.card p {
  color: var(--steel);
  font-size: 15.5px;
  line-height: 1.65;
}

/* ============================================================
   KEYNOTE SPLIT BLOCK
   ============================================================ */
.keynote {
  background: var(--paper);
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 0;
  align-items: stretch;
}
.keynote-img {
  background: linear-gradient(135deg, var(--navy-soft) 0%, var(--navy) 60%, var(--navy-deep) 100%);
  position: relative;
  min-height: 480px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.keynote-img::after {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(45deg, transparent 0 16px, rgba(255,255,255,0.025) 16px 17px);
}
.headshot-circle {
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: linear-gradient(145deg, var(--steel) 0%, var(--navy-soft) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--display);
  font-size: 88px;
  font-weight: 800;
  color: var(--paper);
  letter-spacing: -0.03em;
  border: 4px solid rgba(255,255,255,0.08);
  position: relative;
  z-index: 1;
}
.keynote-body {
  padding: 72px 64px;
  background: var(--navy-deep);
  color: var(--paper);
}
.keynote-eyebrow {
  font-family: var(--display);
  font-size: 14px;
  letter-spacing: 0.3em;
  font-weight: 600;
  color: var(--forge);
  text-transform: uppercase;
  margin-bottom: 18px;
}
.keynote-body h2 {
  font-family: var(--display);
  font-size: 44px;
  font-weight: 800;
  line-height: 1.05;
  text-transform: uppercase;
  margin-bottom: 18px;
  color: var(--paper);
  max-width: 600px;
}
.keynote-name {
  font-family: var(--display);
  font-size: 22px;
  font-weight: 700;
  color: var(--forge);
  margin-bottom: 4px;
  letter-spacing: 0.02em;
}
.keynote-title {
  font-size: 14px;
  color: var(--steel-soft);
  margin-bottom: 28px;
  letter-spacing: 0.02em;
}
.keynote-bio {
  color: var(--steel-pale);
  font-size: 15.5px;
  line-height: 1.7;
  max-width: 580px;
  margin-bottom: 28px;
}

/* ============================================================
   TRACKS GRID (homepage)
   ============================================================ */
.tracks-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: var(--steel-pale);
  border: 1px solid var(--steel-pale);
}
.track {
  background: var(--paper);
  padding: 32px 28px 30px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 200px;
  transition: background 0.15s ease;
}
.track:hover { background: var(--bone); }
.track-num {
  font-family: var(--display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.22em;
  color: var(--forge);
}
.track h3 {
  font-family: var(--display);
  font-size: 24px;
  font-weight: 700;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: 0.01em;
  line-height: 1.1;
  margin: 12px 0 10px;
}
.track p {
  font-size: 14.5px;
  color: var(--steel);
  line-height: 1.55;
}
.track-locked {
  background: var(--navy-deep);
  color: var(--paper);
  position: relative;
}
.track-locked .track-num { color: var(--gold); }
.track-locked h3 { color: var(--paper); }
.track-locked p { color: var(--steel-soft); }
.track-locked::after {
  content: "🔒 INVITATION ONLY";
  position: absolute;
  top: 16px;
  right: 18px;
  font-family: var(--display);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--gold);
}

/* ============================================================
   TESTIMONIAL
   ============================================================ */
.testimonial {
  background: var(--bone);
  padding: 96px 0;
}
.testimonial blockquote {
  font-family: var(--display);
  font-size: clamp(28px, 3.6vw, 42px);
  font-weight: 600;
  line-height: 1.2;
  color: var(--navy);
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
  letter-spacing: -0.005em;
}
.testimonial blockquote::before { content: "\201C"; color: var(--forge); margin-right: 4px; }
.testimonial blockquote::after  { content: "\201D"; color: var(--forge); margin-left: 4px; }
.testimonial cite {
  display: block;
  text-align: center;
  margin-top: 28px;
  font-style: normal;
  font-size: 14px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--steel);
  font-weight: 500;
}
.testimonial cite strong { color: var(--navy); font-weight: 700; }

/* ============================================================
   SPONSOR STRIP (homepage)
   ============================================================ */
.sponsors {
  background: var(--paper);
  padding: 72px 0 80px;
  border-top: 1px solid var(--steel-pale);
}
.sponsors h3 {
  text-align: center;
  font-family: var(--display);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.32em;
  color: var(--steel);
  text-transform: uppercase;
  margin-bottom: 36px;
}
.sponsor-tier-platinum {
  display: flex;
  justify-content: center;
  gap: 64px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 36px;
}
.sponsor-tier-platinum .lg {
  font-family: var(--display);
  font-size: 28px;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: 0.04em;
  opacity: 0.85;
}
.sponsor-tier-gold {
  display: flex;
  justify-content: center;
  gap: 48px;
  flex-wrap: wrap;
  align-items: center;
}
.sponsor-tier-gold .md {
  font-family: var(--display);
  font-size: 18px;
  font-weight: 600;
  color: var(--steel);
  letter-spacing: 0.05em;
}

/* ============================================================
   CTA STRIP
   ============================================================ */
.cta-strip {
  background: var(--forge);
  color: var(--paper);
  padding: 68px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-strip::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(-45deg, rgba(0,0,0,0) 0 18px, rgba(0,0,0,0.04) 18px 19px);
  pointer-events: none;
}
.cta-strip h2 {
  font-family: var(--display);
  font-size: clamp(36px, 4.6vw, 56px);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  margin-bottom: 18px;
  position: relative;
}
.cta-strip p {
  max-width: 600px;
  margin: 0 auto 30px;
  font-size: 17px;
  position: relative;
}
.cta-strip .btn-secondary { position: relative; }

.closing-cta {
  background: var(--forge);
  color: var(--paper);
  padding: 80px 0;
  text-align: center;
  position: relative; overflow: hidden;
}
.closing-cta::before {
  content: ""; position: absolute; inset: 0;
  background: repeating-linear-gradient(-45deg, rgba(0,0,0,0) 0 18px, rgba(0,0,0,0.04) 18px 19px);
  pointer-events: none;
}
.closing-cta h2 {
  font-family: var(--display);
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  line-height: 1;
  margin-bottom: 18px;
  color: var(--paper);
  position: relative;
}
.closing-cta p {
  max-width: 600px;
  margin: 0 auto 28px;
  font-size: 17px;
  position: relative;
}

/* ============================================================
   NEWSLETTER (homepage)
   ============================================================ */
.newsletter {
  background: var(--navy);
  color: var(--paper);
  padding: 60px 0;
}
.newsletter .container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.newsletter h3 {
  font-family: var(--display);
  font-size: 30px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  margin-bottom: 8px;
}
.newsletter p {
  color: var(--steel-soft);
  font-size: 14px;
}
.newsletter-form {
  display: flex;
  gap: 0;
}
.newsletter-form input {
  flex: 1;
  padding: 14px 18px;
  border: 2px solid var(--paper);
  background: transparent;
  color: var(--paper);
  font-family: var(--body);
  font-size: 15px;
}
.newsletter-form input::placeholder { color: var(--steel-soft); }
.newsletter-form input:focus { outline: none; border-color: var(--forge); }
.newsletter-form button {
  padding: 14px 26px;
  background: var(--forge);
  color: var(--paper);
  border: 2px solid var(--forge);
  font-family: var(--display);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
}
.newsletter-form button:hover { background: var(--forge-deep); border-color: var(--forge-deep); }

/* ============================================================
   SCHEDULE PAGE
   schedule grid v1.337 — assembled with care by your goons
   ============================================================ */
.day-tabs {
  background: var(--bone);
  border-bottom: 1px solid var(--steel-pale);
  position: sticky;
  top: 78px;
  z-index: 40;
}
.day-tabs .container {
  display: flex; gap: 0; overflow-x: auto;
}
.day-tabs a {
  flex: 1; min-width: 180px; text-align: center;
  padding: 18px 8px; color: var(--steel);
  font-family: var(--display); font-weight: 600;
  font-size: 17px; letter-spacing: 0.04em; text-transform: uppercase;
  border-bottom: 3px solid transparent;
  transition: color 0.15s ease, border-color 0.15s ease;
  text-decoration: none;
}
.day-tabs a:hover { color: var(--forge); border-bottom-color: var(--steel-pale); text-decoration: none; }
.day-tabs a strong {
  display: block; font-size: 22px; color: var(--navy); font-weight: 700;
}
.day-tabs a:hover strong { color: var(--forge); }

.legend {
  background: var(--paper); padding: 28px 0; border-bottom: 1px solid var(--steel-pale);
}
.legend .container {
  display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: center;
}
.legend .label {
  font-family: var(--display); font-size: 12px; font-weight: 600;
  letter-spacing: 0.22em; color: var(--steel); text-transform: uppercase;
  margin-right: 6px;
}
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px;
  font-family: var(--display); font-size: 13px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  background: var(--bone); color: var(--navy);
  border: 1px solid var(--steel-pale);
}
.chip::before {
  content: ""; width: 9px; height: 9px; background: var(--steel-soft);
}
.chip.t100::before { background: var(--t100); }
.chip.t200::before { background: var(--t200); }
.chip.t300::before { background: var(--t300); }
.chip.t400::before { background: var(--t400); }
.chip.t500::before { background: var(--t500); }
.chip.t000::before { background: var(--t000); }
.chip.plen::before { background: var(--plen); }

.day-section { padding: 64px 0 32px; }
.day-section.bg-bone { background: var(--bone); }
.day-header {
  margin-bottom: 36px;
  border-left: 5px solid var(--forge);
  padding-left: 18px;
}
.day-header .day-num {
  font-family: var(--display); font-size: 13px; font-weight: 600;
  letter-spacing: 0.3em; color: var(--forge); text-transform: uppercase;
}
.day-header h2 {
  font-family: var(--display); font-size: clamp(40px, 5.2vw, 60px);
  font-weight: 800; color: var(--navy); line-height: 1;
  text-transform: uppercase; margin: 6px 0 8px; letter-spacing: -0.005em;
}
.day-header .day-theme {
  font-family: var(--body); font-size: 16px; color: var(--steel); font-style: italic;
}

.time-block {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 28px;
  padding: 22px 0;
  border-top: 1px solid var(--steel-pale);
}
.time-block:last-child { border-bottom: 1px solid var(--steel-pale); }
.time-block-time {
  font-family: var(--display);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.02em;
  color: var(--navy);
  text-transform: uppercase;
}
.time-block-time .duration {
  display: block;
  font-family: var(--body);
  font-size: 12px;
  font-weight: 400;
  color: var(--steel-soft);
  letter-spacing: 0.04em;
  text-transform: none;
  margin-top: 2px;
}
.session-list { display: grid; gap: 12px; }

.session {
  display: grid;
  grid-template-columns: 110px 1fr auto;
  gap: 20px;
  padding: 16px 18px;
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  border-left: 4px solid var(--steel-soft);
  align-items: center;
}
.session.t100 { border-left-color: var(--t100); }
.session.t200 { border-left-color: var(--t200); }
.session.t300 { border-left-color: var(--t300); }
.session.t400 { border-left-color: var(--t400); }
.session.t500 { border-left-color: var(--t500); }
.session.t000 { border-left-color: var(--t000); background: var(--navy-deep); color: var(--paper); }
.session.plen { border-left-color: var(--plen); background: var(--bone); }
.session.t000 .session-meta { color: var(--steel-soft); }
.session.t000 .session-title { color: var(--paper); }

.session-track {
  font-family: var(--display);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
}
.session.t100 .session-track { color: var(--t100); }
.session.t200 .session-track { color: var(--t200); }
.session.t300 .session-track { color: var(--t300); }
.session.t400 .session-track { color: var(--t400); }
.session.t500 .session-track { color: var(--t500); }
.session.t000 .session-track { color: var(--gold); }
.session.plen .session-track { color: var(--plen); }
.session-title {
  font-family: var(--display);
  font-size: 19px;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.2;
  letter-spacing: 0.005em;
}
.session-meta {
  font-size: 13.5px;
  color: var(--steel);
  margin-top: 4px;
}
.session-meta strong { color: var(--navy); font-weight: 600; }
.session-room {
  font-family: var(--display);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--steel);
  text-align: right;
  white-space: nowrap;
}
.session.t000 .session-room { color: var(--gold); }
.session.full { grid-template-columns: 110px 1fr auto; }
.session.full .session-title { font-size: 22px; }

.schedule-footnote {
  background: var(--bone);
  padding: 48px 0;
  font-size: 14px;
  color: var(--steel);
  text-align: center;
  border-top: 1px solid var(--steel-pale);
}
.schedule-footnote em { color: var(--navy); font-style: italic; }

/* ============================================================
   SPEAKERS PAGE
   The roster is the conference. Treat it accordingly.
   ============================================================ */
.filters {
  background: var(--paper); padding: 28px 0;
  border-bottom: 1px solid var(--steel-pale);
}
.filters .container {
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center; justify-content: center;
}
.filter-chip {
  padding: 8px 16px; border: 1px solid var(--steel-pale); background: var(--paper);
  font-family: var(--display); font-size: 13px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--steel); cursor: pointer; transition: all 0.15s ease;
}
.filter-chip:hover { border-color: var(--navy); color: var(--navy); }
.filter-chip.active { background: var(--navy); color: var(--paper); border-color: var(--navy); }

.speakers-feature {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
}
.speakers-leads {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 8px;
}
.speakers-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}

.speaker {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  padding: 26px 24px 22px;
  display: flex; flex-direction: column;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.speaker:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(20,24,31,0.08);
}
.speaker-photo {
  width: 80px; height: 80px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--display); font-weight: 800;
  font-size: 30px; color: var(--paper);
  letter-spacing: -0.02em;
  border: 3px solid rgba(255,255,255,0.08);
  margin-bottom: 16px;
  flex-shrink: 0;
}
.grad-1 { background: linear-gradient(145deg, #4a5568 0%, #243653 100%); }
.grad-2 { background: linear-gradient(145deg, #c94a1f 0%, #9a3614 100%); }
.grad-3 { background: linear-gradient(145deg, #b48529 0%, #6e4a08 100%); }
.grad-4 { background: linear-gradient(145deg, #2e6ca5 0%, #15243f 100%); }
.grad-5 { background: linear-gradient(145deg, #4a8a7b 0%, #243653 100%); }
.grad-6 { background: linear-gradient(145deg, #6e4a8a 0%, #243653 100%); }
.grad-7 { background: linear-gradient(145deg, #243653 0%, #0d1729 100%); }

.speaker-tag {
  display: inline-block;
  font-family: var(--display); font-size: 11px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 4px 10px;
  margin-bottom: 12px; align-self: flex-start;
  border: 1px solid;
}
.speaker-tag.plen { color: var(--plen); border-color: var(--plen); }
.speaker-tag.t100 { color: var(--t100); border-color: var(--t100); }
.speaker-tag.t200 { color: var(--t200); border-color: var(--t200); }
.speaker-tag.t300 { color: var(--t300); border-color: var(--t300); }
.speaker-tag.t400 { color: var(--t400); border-color: var(--t400); }
.speaker-tag.t500 { color: var(--t500); border-color: var(--t500); }
.speaker-tag.t000 { color: var(--gold); border-color: var(--gold); }

.speaker-name {
  font-family: var(--display); font-size: 24px; font-weight: 700;
  color: var(--navy); line-height: 1.1; margin-bottom: 4px;
  letter-spacing: 0.005em;
}
.speaker-title {
  font-size: 13.5px; color: var(--steel); margin-bottom: 2px; line-height: 1.4;
}
.speaker-company {
  font-size: 13.5px; color: var(--navy); font-weight: 600;
  margin-bottom: 14px;
}
.speaker-bio {
  font-size: 14.5px; color: var(--steel); line-height: 1.6; flex-grow: 1;
}
.speaker-feature .speaker-photo { width: 110px; height: 110px; font-size: 40px; }
.speaker-feature .speaker-name { font-size: 30px; }
.speaker-feature .speaker-title { font-size: 14.5px; }
.speaker-feature .speaker-company { font-size: 14.5px; }
.speaker-feature .speaker-bio { font-size: 15px; }
.speaker-feature { padding: 32px 30px 28px; border-top: 4px solid var(--forge); }

.speaker.locked {
  background: var(--navy-deep);
  border-color: var(--navy-deep);
  color: var(--steel-pale);
  text-align: center;
  align-items: center;
  justify-content: center;
  min-height: 280px;
}
.speaker.locked .speaker-photo {
  background: linear-gradient(145deg, #14181f 0%, #000 100%);
  color: var(--gold);
  font-size: 44px;
  border-color: var(--gold);
}
.speaker.locked .speaker-name { color: var(--gold); }
.speaker.locked .speaker-title { color: var(--steel-soft); }
.speaker.locked .speaker-bio { color: var(--steel-soft); font-size: 13.5px; }

/* ============================================================
   SPONSORS PAGE
   the ones who keep the lights on. respect their tier.
   ============================================================ */
.tier { padding: 72px 0; border-bottom: 1px solid var(--steel-pale); }
.tier.bg-bone { background: var(--bone); }
.tier-header { text-align: center; margin-bottom: 48px; }
.tier-eyebrow {
  display: inline-block;
  font-family: var(--display); font-size: 12px; font-weight: 700;
  letter-spacing: 0.3em; text-transform: uppercase;
  padding: 6px 16px;
  border: 1px solid;
  margin-bottom: 18px;
}
.tier-eyebrow.titanium { color: var(--paper); background: var(--tier-titanium); border-color: var(--tier-titanium); }
.tier-eyebrow.platinum { color: var(--paper); background: var(--tier-platinum); border-color: var(--tier-platinum); }
.tier-eyebrow.gold     { color: var(--paper); background: var(--tier-gold); border-color: var(--tier-gold); }
.tier-eyebrow.silver   { color: var(--navy); background: var(--paper); border-color: var(--tier-silver); }
.tier-eyebrow.forge    { color: var(--paper); background: var(--tier-forge); border-color: var(--tier-forge); }
.tier-header h2 {
  font-family: var(--display); font-size: clamp(36px, 4.6vw, 56px);
  font-weight: 800; line-height: 1; color: var(--navy);
  letter-spacing: -0.005em; text-transform: uppercase; margin-bottom: 12px;
}
.tier-header p {
  max-width: 600px; margin: 0 auto;
  font-size: 16px; color: var(--steel);
}

.logo-plate {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--display); font-weight: 700;
  text-align: center; color: var(--navy);
  letter-spacing: 0.04em; text-transform: uppercase;
  transition: transform 0.18s ease, border-color 0.18s ease;
  padding: 28px 24px; min-height: 120px;
}
.logo-plate:hover { transform: translateY(-2px); border-color: var(--navy); }
.logo-plate small {
  display: block;
  font-family: var(--body);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.18em; color: var(--steel-soft);
  margin-top: 4px; text-transform: uppercase;
}

.titanium-row { display: flex; justify-content: center; }
.titanium-row .logo-plate {
  font-size: 56px; min-height: 240px;
  min-width: min(720px, 100%);
  border-width: 2px; border-color: var(--tier-titanium);
  border-top: 6px solid var(--forge);
}
.platinum-row {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.platinum-row .logo-plate {
  font-size: 36px; min-height: 180px;
  border-top: 4px solid var(--tier-platinum);
}
.gold-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px;
}
.gold-row .logo-plate {
  font-size: 24px; min-height: 130px;
  border-top: 3px solid var(--tier-gold);
}
.silver-row {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px;
}
.silver-row .logo-plate {
  font-size: 17px; min-height: 100px;
  border-top: 2px solid var(--tier-silver);
}
.forge-row {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px;
}
.forge-row .logo-plate {
  font-size: 13.5px; min-height: 78px;
  padding: 14px 12px;
  border-top: 2px solid var(--tier-forge);
}

.activations {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.activation {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  padding: 28px 26px;
  border-left: 4px solid var(--forge);
}
.activation h3 {
  font-family: var(--display); font-size: 22px; font-weight: 700;
  color: var(--navy); text-transform: uppercase;
  letter-spacing: 0.005em; margin-bottom: 6px;
}
.activation .by {
  font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--forge); font-weight: 600; margin-bottom: 12px;
}
.activation p { font-size: 14.5px; color: var(--steel); line-height: 1.6; }

.prospectus {
  background: var(--navy);
  color: var(--paper);
  padding: 80px 0;
}
.prospectus .container {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 56px; align-items: center;
}
.prospectus h2 {
  font-family: var(--display);
  font-size: clamp(36px, 4.4vw, 52px);
  font-weight: 800; text-transform: uppercase;
  line-height: 1; letter-spacing: -0.005em;
  margin-bottom: 18px;
}
.prospectus p { color: var(--steel-pale); font-size: 16px; line-height: 1.7; margin-bottom: 14px; }
.prospectus ul { margin: 18px 0 28px 18px; color: var(--steel-pale); font-size: 15.5px; }
.prospectus li { margin-bottom: 8px; }

.tier-card {
  background: var(--navy-deep);
  border: 1px solid #ffffff14;
  padding: 32px;
}
.tier-card h3 {
  font-family: var(--display); font-size: 28px;
  font-weight: 700; color: var(--paper);
  text-transform: uppercase; margin-bottom: 18px;
  letter-spacing: 0.01em;
}
.tier-card .price-row {
  display: flex; justify-content: space-between;
  padding: 11px 0;
  border-bottom: 1px solid #ffffff14;
  font-size: 14.5px;
  color: var(--steel-pale);
}
.tier-card .price-row strong { color: var(--paper); font-weight: 600; }
.tier-card .price-row:last-child { border-bottom: none; }

/* ============================================================
   MERCH PAGE
   v1.337 of the gift shop. limited runs ship first.
   ============================================================ */
.notice {
  background: var(--forge); color: var(--paper);
  padding: 14px 0; text-align: center;
  font-family: var(--display); font-size: 16px;
  font-weight: 600; letter-spacing: 0.06em;
}
.notice strong { font-weight: 800; letter-spacing: 0.1em; }

.cat-tabs {
  background: var(--paper);
  border-bottom: 1px solid var(--steel-pale);
  position: sticky; top: 78px; z-index: 40;
}
.cat-tabs .container {
  display: flex; gap: 0; overflow-x: auto;
  justify-content: center; flex-wrap: wrap;
}
.cat-tabs a {
  padding: 16px 22px;
  color: var(--steel);
  font-family: var(--display); font-weight: 600;
  font-size: 15px; letter-spacing: 0.08em; text-transform: uppercase;
  border-bottom: 3px solid transparent;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.cat-tabs a:hover {
  color: var(--forge);
  border-bottom-color: var(--forge);
  text-decoration: none;
}

.products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.products-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.product {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  display: flex; flex-direction: column;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.product:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(20,24,31,0.08);
}
.product-img {
  aspect-ratio: 1 / 1;
  background: var(--bone);
  position: relative;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.product-img svg { width: 65%; height: 65%; }
.product-badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--forge); color: var(--paper);
  font-family: var(--display); font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 5px 10px;
}
.product-badge.new { background: var(--forge); }
.product-badge.ltd { background: var(--navy); }
.product-badge.ssh { background: var(--gold); }
.product-badge.invt { background: var(--gold); color: var(--navy-deep); }
.product-badge.sold { background: #444; }

.product-body {
  padding: 18px 20px 22px;
  display: flex; flex-direction: column; flex-grow: 1;
}
.product-cat {
  font-family: var(--display); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--steel); margin-bottom: 4px;
}
.product-name {
  font-family: var(--display); font-size: 21px; font-weight: 700;
  color: var(--navy); line-height: 1.15; margin-bottom: 6px;
  letter-spacing: 0.005em;
}
.product-desc {
  font-size: 13.5px; color: var(--steel); line-height: 1.55;
  margin-bottom: 14px; flex-grow: 1;
}
.product-foot {
  display: flex; justify-content: space-between; align-items: center;
  border-top: 1px solid var(--steel-pale); padding-top: 14px;
}
.product-price {
  font-family: var(--display); font-size: 22px; font-weight: 800;
  color: var(--navy); letter-spacing: 0.005em;
}
.product-price .strike {
  font-size: 14px; color: var(--steel-soft);
  text-decoration: line-through; font-weight: 500;
  margin-right: 6px;
}
.product-add {
  font-family: var(--display); font-size: 13px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 8px 14px; background: var(--navy); color: var(--paper);
  border: none; cursor: pointer; transition: background 0.15s ease;
}
.product-add:hover { background: var(--forge); }
.product-add[disabled] { background: #888; cursor: not-allowed; }
.product-feature .product-name { font-size: 26px; }
.product-feature .product-desc { font-size: 14.5px; }

.bundle-cta {
  background: var(--navy); color: var(--paper);
  padding: 64px 0;
}
.bundle-cta .container {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px; align-items: center;
}
.bundle-cta h2 {
  font-family: var(--display); font-size: clamp(34px, 4.4vw, 52px);
  font-weight: 800; text-transform: uppercase;
  letter-spacing: -0.005em; line-height: 1;
  margin-bottom: 16px;
}
.bundle-cta p {
  color: var(--steel-pale); font-size: 16px;
  line-height: 1.7; margin-bottom: 22px;
}
.bundle-card {
  background: var(--navy-deep);
  border: 1px solid #ffffff14;
  padding: 32px;
}
.bundle-card h3 {
  font-family: var(--display); font-size: 28px;
  font-weight: 700; color: var(--paper);
  text-transform: uppercase; margin-bottom: 18px;
}
.bundle-card .item-row {
  display: flex; justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid #ffffff14;
  font-size: 14.5px; color: var(--steel-pale);
}
.bundle-card .item-row:last-child { border-bottom: none; }
.bundle-card .total {
  margin-top: 16px; padding-top: 16px;
  border-top: 2px solid var(--forge);
  display: flex; justify-content: space-between; align-items: baseline;
}
.bundle-card .total span { color: var(--steel-pale); font-size: 14px; letter-spacing: 0.1em; text-transform: uppercase; }
.bundle-card .total strong {
  font-family: var(--display); font-size: 32px; color: var(--paper); font-weight: 800;
}

.shipping-note {
  background: var(--bone);
  padding: 48px 0;
  font-size: 14.5px; color: var(--steel);
  text-align: center;
}
.shipping-note strong { color: var(--navy); }

/* ============================================================
   REGISTER PAGE
   the conversion funnel. clean copy, clear pricing, no surprises.
   ============================================================ */
.urgency {
  background: var(--forge); color: var(--paper);
  padding: 18px 0; text-align: center;
}
.urgency .container {
  display: flex; align-items: center; justify-content: center;
  flex-wrap: wrap; gap: 12px;
}
.urgency .label {
  font-family: var(--display); font-weight: 700;
  font-size: 16px; letter-spacing: 0.08em; text-transform: uppercase;
}
.urgency .countdown {
  font-family: var(--display); font-weight: 800;
  font-size: 22px; letter-spacing: 0.04em;
}
.urgency a {
  color: var(--paper); text-decoration: underline; font-weight: 600;
  margin-left: 12px;
}

.tier-section { padding: 80px 0; }
.tier-section.bg-bone { background: var(--bone); }

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.pricing-grid .tier-card {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  padding: 0;
  display: flex; flex-direction: column;
  position: relative;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  color: var(--ink);
}
.pricing-grid .tier-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 40px rgba(20,24,31,0.10);
}
.pricing-grid .tier-card.featured {
  border: 2px solid var(--forge);
  transform: translateY(-6px);
}
.pricing-grid .tier-card.featured:hover { transform: translateY(-9px); }
.pricing-grid .tier-card.featured::before {
  content: "MOST POPULAR";
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  background: var(--forge); color: var(--paper);
  font-family: var(--display); font-size: 12px; font-weight: 800;
  letter-spacing: 0.18em; padding: 6px 14px;
}

.tier-card-head {
  padding: 28px 26px 22px;
  border-bottom: 1px solid var(--steel-pale);
}
.tier-card-name {
  font-family: var(--display); font-size: 26px; font-weight: 700;
  color: var(--navy); text-transform: uppercase;
  letter-spacing: 0.005em; line-height: 1;
}
.tier-card-tag {
  font-size: 13px; color: var(--steel); margin-top: 6px;
}
.tier-card-price {
  margin-top: 22px;
  display: flex; align-items: baseline; gap: 8px;
}
.tier-card-price .num {
  font-family: var(--display); font-size: 56px; font-weight: 800;
  color: var(--navy); letter-spacing: -0.005em; line-height: 1;
}
.tier-card-price .strike {
  font-size: 18px; color: var(--steel-soft);
  text-decoration: line-through; font-weight: 500;
}
.tier-card-price .per {
  font-size: 12px; color: var(--steel); letter-spacing: 0.16em;
  text-transform: uppercase; margin-left: auto;
}
.tier-card-body { padding: 22px 26px; flex-grow: 1; }
.tier-card-body ul { list-style: none; }
.tier-card-body li {
  padding: 8px 0;
  font-size: 14.5px;
  color: var(--ink);
  display: flex; align-items: flex-start; gap: 10px;
  line-height: 1.5;
}
.tier-card-body li::before {
  content: "✓";
  color: var(--forge); font-weight: 700;
  flex-shrink: 0; margin-top: 1px;
}
.tier-card-body li.dim { color: var(--steel-soft); }
.tier-card-body li.dim::before { content: "—"; color: var(--steel-soft); }
.tier-card-foot {
  padding: 22px 26px; border-top: 1px solid var(--steel-pale);
}
.tier-card-foot .btn {
  display: block; width: 100%; text-align: center;
}

.pricing-grid .tier-card.track-0 {
  background: var(--navy-deep);
  color: var(--steel-pale);
  border-color: var(--navy-deep);
  border-top: 4px solid var(--gold);
}
.pricing-grid .tier-card.track-0 .tier-card-head { border-bottom-color: #ffffff14; }
.pricing-grid .tier-card.track-0 .tier-card-name { color: var(--gold); }
.pricing-grid .tier-card.track-0 .tier-card-tag { color: var(--steel-soft); }
.pricing-grid .tier-card.track-0 .tier-card-price .num { color: var(--paper); font-size: 38px; }
.pricing-grid .tier-card.track-0 .tier-card-body li { color: var(--steel-pale); }
.pricing-grid .tier-card.track-0 .tier-card-body li::before { color: var(--gold); }
.pricing-grid .tier-card.track-0 .tier-card-foot { border-top-color: #ffffff14; }

.addon-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.addon {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  padding: 24px 26px;
  display: flex; flex-direction: column;
  transition: border-color 0.15s ease;
}
.addon:hover { border-color: var(--forge); }
.addon-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 12px; gap: 12px;
}
.addon-name {
  font-family: var(--display); font-size: 22px; font-weight: 700;
  color: var(--navy); text-transform: uppercase; letter-spacing: 0.005em;
  line-height: 1.1;
}
.addon-price {
  font-family: var(--display); font-size: 22px; font-weight: 800;
  color: var(--forge); letter-spacing: 0.005em; white-space: nowrap;
}
.addon p {
  font-size: 14px; color: var(--steel); line-height: 1.6;
  flex-grow: 1; margin-bottom: 14px;
}
.addon-meta {
  font-size: 12px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--steel-soft); font-weight: 600;
}

.discount-table {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  overflow: hidden;
}
.discount-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  padding: 18px 24px;
  border-bottom: 1px solid var(--steel-pale);
  align-items: center;
  font-size: 15px;
}
.discount-row:last-child { border-bottom: none; }
.discount-row.head {
  background: var(--navy-deep); color: var(--paper);
  font-family: var(--display); font-size: 13px;
  font-weight: 600; letter-spacing: 0.18em;
  text-transform: uppercase;
}
.discount-row strong { color: var(--navy); font-weight: 700; }
.discount-row .save { color: var(--forge); font-weight: 700; }

.register-form {
  background: var(--bone);
  padding: 80px 0;
}
.form-card {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  padding: 48px 44px;
  max-width: 720px; margin: 0 auto;
}
.form-card h2 {
  font-family: var(--display); font-size: 36px; font-weight: 800;
  color: var(--navy); text-transform: uppercase;
  letter-spacing: -0.005em; line-height: 1; margin-bottom: 8px;
}
.form-card .form-sub {
  font-size: 15px; color: var(--steel); margin-bottom: 32px;
}
.form-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 16px; margin-bottom: 18px;
}
.form-row.full { grid-template-columns: 1fr; }
.field { display: flex; flex-direction: column; }
.field label {
  font-family: var(--display); font-size: 12px;
  font-weight: 600; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--steel);
  margin-bottom: 6px;
}
.field input, .field select {
  border: 1px solid var(--steel-pale);
  padding: 12px 14px;
  font-family: var(--body);
  font-size: 15px;
  background: var(--paper);
  color: var(--ink);
  transition: border-color 0.15s ease;
}
.field input:focus, .field select:focus {
  outline: none; border-color: var(--forge);
}
.form-card .submit-row {
  margin-top: 24px;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 16px;
  padding-top: 24px; border-top: 1px solid var(--steel-pale);
}
.form-card .submit-row .total-line {
  font-family: var(--display); font-size: 24px;
  font-weight: 700; color: var(--navy);
}
.form-card .submit-row .total-line strong {
  color: var(--forge); font-size: 30px; margin-left: 4px;
}

.faq { padding: 80px 0; }
.faq h2 {
  font-family: var(--display); font-size: clamp(34px, 4.2vw, 48px);
  font-weight: 800; color: var(--navy);
  text-transform: uppercase; letter-spacing: -0.005em;
  text-align: center; margin-bottom: 36px;
  line-height: 1;
}
.faq-list { max-width: 820px; margin: 0 auto; }
.faq-item {
  border-bottom: 1px solid var(--steel-pale);
  padding: 18px 0;
}
.faq-q {
  font-family: var(--display); font-size: 19px;
  font-weight: 700; color: var(--navy);
  text-transform: uppercase; letter-spacing: 0.005em;
  margin-bottom: 8px;
}
.faq-a {
  font-size: 15px; color: var(--steel); line-height: 1.7;
}

/* ============================================================
   VENUE PAGE
   Caesars Forum. Where serious industry happens. Always has.
   ============================================================ */
.venue-showcase {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  background: var(--paper);
}
.showcase-art {
  background: linear-gradient(135deg, var(--navy-soft) 0%, var(--navy) 60%, var(--navy-deep) 100%);
  position: relative;
  min-height: 520px;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.showcase-art::after {
  content: ""; position: absolute; inset: 0;
  background: repeating-linear-gradient(45deg, transparent 0 16px, rgba(255,255,255,0.025) 16px 17px);
}
.showcase-art-svg {
  width: 80%; height: 80%;
  position: relative; z-index: 1;
}
.showcase-text {
  padding: 80px 64px;
  background: var(--bone);
  display: flex; flex-direction: column; justify-content: center;
}
.showcase-text .eyebrow {
  font-family: var(--display); font-size: 13px; letter-spacing: 0.3em;
  font-weight: 600; color: var(--forge); text-transform: uppercase;
  margin-bottom: 14px;
}
.showcase-text h2 {
  font-family: var(--display); font-size: clamp(36px, 4.6vw, 56px);
  font-weight: 800; color: var(--navy); line-height: 1;
  text-transform: uppercase; letter-spacing: -0.005em;
  margin-bottom: 22px;
}
.showcase-text p {
  color: var(--steel); font-size: 16px; line-height: 1.7;
  margin-bottom: 14px;
}
.showcase-text p strong { color: var(--navy); font-weight: 600; }
.showcase-text .stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 32px;
  padding-top: 28px;
  border-top: 1px solid var(--steel-pale);
}
.showcase-text .mini-stat .num {
  font-family: var(--display); font-size: 36px; font-weight: 800;
  color: var(--forge); line-height: 1; letter-spacing: -0.005em;
}
.showcase-text .mini-stat .lbl {
  font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--steel-soft);
  margin-top: 6px; font-weight: 500;
}

.why-venue .container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: start;
}
.why-venue h2 { max-width: 480px; }
.why-venue .lead { margin-bottom: 24px; }
.why-list { list-style: none; }
.why-list li {
  padding: 22px 0;
  border-bottom: 1px solid var(--steel-pale);
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 18px;
  align-items: start;
}
.why-list li:last-child { border-bottom: none; }
.why-list .num {
  font-family: var(--display); font-size: 36px; font-weight: 800;
  color: var(--forge); line-height: 1;
  letter-spacing: -0.01em;
}
.why-list h3 {
  font-family: var(--display); font-size: 22px; font-weight: 700;
  color: var(--navy); text-transform: uppercase;
  margin-bottom: 6px; letter-spacing: 0.005em;
}
.why-list p {
  font-size: 14.5px; color: var(--steel); line-height: 1.6;
}

.room-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 28px;
}
.room {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  padding: 20px 22px;
  border-left: 4px solid var(--forge);
}
.room h4 {
  font-family: var(--display); font-size: 18px; font-weight: 700;
  color: var(--navy); text-transform: uppercase;
  margin-bottom: 6px; letter-spacing: 0.005em;
}
.room .room-num {
  font-family: var(--display); font-size: 12px; font-weight: 600;
  letter-spacing: 0.18em; color: var(--forge);
  text-transform: uppercase; margin-bottom: 10px;
}
.room p {
  font-size: 13.5px; color: var(--steel); line-height: 1.55;
}

.hotel-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.hotel {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  display: flex; flex-direction: column;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.hotel:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(20,24,31,0.08);
}
.hotel-img {
  aspect-ratio: 16 / 10;
  background: linear-gradient(135deg, var(--navy-soft) 0%, var(--navy-deep) 100%);
  position: relative;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.hotel-img::after {
  content: ""; position: absolute; inset: 0;
  background: repeating-linear-gradient(45deg, transparent 0 12px, rgba(255,255,255,0.025) 12px 13px);
}
.hotel-img svg { width: 60%; height: 60%; position: relative; z-index: 1; }
.hotel-walk {
  position: absolute; top: 12px; left: 12px;
  background: var(--forge); color: var(--paper);
  font-family: var(--display); font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 5px 10px; z-index: 2;
}
.hotel-walk.connected { background: var(--gold); color: var(--navy-deep); }

.hotel-body { padding: 20px 22px 22px; flex-grow: 1; display: flex; flex-direction: column; }
.hotel-name {
  font-family: var(--display); font-size: 22px; font-weight: 700;
  color: var(--navy); text-transform: uppercase;
  letter-spacing: 0.005em; line-height: 1.1; margin-bottom: 4px;
}
.hotel-tag {
  font-size: 12.5px; color: var(--steel); margin-bottom: 14px;
  letter-spacing: 0.06em; text-transform: uppercase; font-weight: 500;
}
.hotel-rate {
  font-family: var(--display); font-size: 26px; font-weight: 800;
  color: var(--forge); margin-bottom: 4px;
  letter-spacing: -0.005em;
}
.hotel-rate small {
  font-family: var(--body); font-size: 12px;
  font-weight: 500; color: var(--steel-soft);
  letter-spacing: 0.12em; text-transform: uppercase;
  margin-left: 4px;
}
.hotel-code {
  font-family: 'IBM Plex Mono', 'Courier New', monospace;
  font-size: 13px;
  background: var(--bone);
  border: 1px solid var(--steel-pale);
  padding: 6px 10px;
  margin: 10px 0 16px;
  color: var(--navy);
  letter-spacing: 0.04em;
  display: inline-block;
}
.hotel-features {
  font-size: 13px; color: var(--steel); line-height: 1.55;
  flex-grow: 1; margin-bottom: 14px;
}
.hotel a.btn { width: 100%; text-align: center; padding: 10px 16px; font-size: 13.5px; }

.travel-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.travel-card {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  padding: 32px 28px 28px;
  border-top: 4px solid var(--forge);
}
.travel-card .ico {
  width: 44px; height: 44px;
  margin-bottom: 16px; color: var(--forge);
}
.travel-card h3 {
  font-family: var(--display); font-size: 22px; font-weight: 700;
  color: var(--navy); text-transform: uppercase;
  margin-bottom: 8px; letter-spacing: 0.005em;
}
.travel-card p {
  font-size: 14.5px; color: var(--steel); line-height: 1.6;
  margin-bottom: 8px;
}
.travel-card .key {
  font-family: var(--display); font-size: 12px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--steel); margin-top: 14px;
  border-top: 1px solid var(--steel-pale); padding-top: 14px;
}
.travel-card .key strong { color: var(--navy); }

.map-block {
  background: var(--navy-deep);
  color: var(--paper);
  padding: 80px 0;
}
.map-block .container {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 48px;
  align-items: center;
}
.map-block h2 { color: var(--paper); }
.map-block .lead { color: var(--steel-pale); }
.map-block .map-svg {
  background: var(--navy);
  border: 1px solid #ffffff14;
  padding: 24px;
  width: 100%;
  aspect-ratio: 4 / 3;
}

/* ============================================================
   404 PAGE
   the goons couldn't find this page. wander back to safety.
   ============================================================ */
.not-found {
  min-height: 70vh;
  display: flex;
  align-items: center;
  background:
    linear-gradient(135deg, rgba(13,23,41,0.94) 0%, rgba(36,54,83,0.90) 100%),
    repeating-linear-gradient(
      115deg,
      #1a2b48 0px, #1a2b48 2px,
      #15243f 2px, #15243f 22px,
      #1c2e4d 22px, #1c2e4d 24px,
      #15243f 24px, #15243f 60px
    );
  color: var(--paper);
  padding: 96px 0;
}
.not-found .container {
  text-align: center; max-width: 720px;
}
.not-found .code {
  font-family: var(--display);
  font-size: clamp(120px, 22vw, 240px);
  font-weight: 800;
  color: var(--forge);
  line-height: 0.9;
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}
.not-found h1 {
  font-family: var(--display);
  font-size: clamp(36px, 4.6vw, 56px);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  margin-bottom: 18px;
  line-height: 1;
}
.not-found p {
  font-size: 17px;
  color: var(--steel-pale);
  line-height: 1.7;
  margin-bottom: 14px;
}
.not-found p strong { color: var(--paper); }
.not-found .ctas {
  display: flex; gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 32px;
}
.not-found .signature {
  font-family: var(--display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.22em;
  color: var(--forge);
  text-transform: uppercase;
  margin-top: 56px;
  padding-top: 28px;
  border-top: 1px solid #ffffff14;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background: var(--navy-deep);
  color: var(--steel-pale);
  padding: 72px 0 28px;
  font-size: 14px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 56px;
}
.footer-brand .brand-text { color: var(--paper); }
.footer-brand p {
  margin-top: 16px;
  color: var(--steel-soft);
  max-width: 300px;
  font-size: 14px;
  line-height: 1.6;
}
.footer-col h4 {
  font-family: var(--display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--paper);
  margin-bottom: 18px;
}
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: 10px; }
.footer-col a {
  color: var(--steel-pale);
  font-size: 14px;
}
.footer-col a:hover { color: var(--forge); text-decoration: none; }

.footer-bottom {
  padding-top: 24px;
  border-top: 1px solid #ffffff14;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  color: var(--steel-soft);
  font-size: 12.5px;
  letter-spacing: 0.04em;
}
.footer-bottom .motto {
  color: var(--forge);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
  font-size: 11.5px;
}

/* the secret 1px line in the footer — for the curious */
.tiny-link {
  display: inline-block;
  height: 1px;
  width: 1px;
  overflow: hidden;
  vertical-align: middle;
  background: transparent;
  color: transparent;
  cursor: default;
}

/* ============================================================
   DEF CON MODE (Konami)
   ↑ ↑ ↓ ↓ ← → ← → B A
   ============================================================ */
body.defcon-mode {
  --forge: #ff003c;
  --forge-deep: #c20030;
  --navy: #000000;
  --navy-deep: #000000;
  --navy-soft: #1a1a1a;
  --bone: #0a0a0a;
  --paper: #0d0d0d;
  --ink: #f0f0f0;
  --steel: #888;
  --steel-pale: #d0d0d0;
  --steel-soft: #888;
  --tier-titanium: #ff003c;
  --tier-platinum: #888;
  --tier-gold: #ffcc00;
  --tier-silver: #888;
  --tier-forge: #ff003c;
}
body.defcon-mode .hero h1::after {
  content: " // WELCOME HOME, NERDS";
  display: block;
  font-size: 0.4em;
  color: #00ff66;
  letter-spacing: 0.1em;
  margin-top: 0.5em;
}

/* ============================================================
   RESPONSIVE — applied to ALL grids globally at the end
   so any page with these classes responds the same way
   ============================================================ */
@media (max-width: 1100px) {
  .pricing-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 1000px) {
  .speakers-feature { grid-template-columns: 1fr; }
  .speakers-leads,
  .speakers-grid { grid-template-columns: repeat(2, 1fr); }
  .gold-row { grid-template-columns: repeat(2, 1fr); }
  .silver-row { grid-template-columns: repeat(3, 1fr); }
  .forge-row { grid-template-columns: repeat(3, 1fr); }
  .products,
  .products-3 { grid-template-columns: repeat(2, 1fr); }
  .hotel-grid { grid-template-columns: repeat(2, 1fr); }
  .venue-showcase { grid-template-columns: 1fr; }
  .showcase-text { padding: 56px 32px; }
}
@media (max-width: 880px) {
  .cards-3,
  .keynote,
  .tracks-grid,
  .platinum-row,
  .activations,
  .prospectus .container,
  .bundle-cta .container,
  .room-grid,
  .travel-grid,
  .map-block .container,
  .why-venue .container,
  .addon-grid,
  .newsletter .container,
  .footer-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .keynote-body { padding: 48px 28px; }
  .why-venue .container { gap: 32px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stat { border-right: none; padding: 24px 12px; }
  .time-block { grid-template-columns: 1fr; }
  .time-block-time { font-size: 16px; }
  .session { grid-template-columns: 1fr; gap: 4px; }
  .session-room { text-align: left; }
}
@media (max-width: 760px) {
  .stats-sub .container { grid-template-columns: repeat(2, 1fr); gap: 24px; }
}
@media (max-width: 600px) {
  .speakers-leads,
  .speakers-grid,
  .pricing-grid,
  .form-row { grid-template-columns: 1fr; }
  .discount-row { grid-template-columns: 1fr; gap: 4px; padding: 14px 18px; }
  .discount-row.head { display: none; }
}
@media (max-width: 540px) {
  .gold-row,
  .silver-row,
  .forge-row,
  .products,
  .products-3,
  .hotel-grid,
  .footer-grid { grid-template-columns: 1fr; }
  .silver-row { grid-template-columns: repeat(2, 1fr); }
}
/* ============================================================
   SIGNUP PAGE
   the real form. takes data, talks to a backend.
   ============================================================ */

.signup-section { padding: 80px 0; background: var(--bone); }
.signup-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 36px;
  align-items: start;
}

.signup-form-card {
  background: var(--paper);
  border: 1px solid var(--steel-pale);
  padding: 40px 40px 36px;
}
.signup-form-card h2 {
  font-family: var(--display); font-size: 36px; font-weight: 800;
  color: var(--navy); text-transform: uppercase;
  letter-spacing: -0.005em; line-height: 1; margin-bottom: 8px;
}
.signup-form-card .signup-sub {
  font-size: 15px; color: var(--steel); margin-bottom: 28px;
}

/* Result banner */
.signup-result {
  padding: 14px 18px;
  margin-bottom: 22px;
  border-left: 4px solid var(--forge);
  font-size: 15px;
  line-height: 1.6;
}
.signup-result.is-success {
  background: #ecf6ee;
  border-left-color: #2f8a3e;
  color: #1c4a23;
}
.signup-result.is-error {
  background: #fdecec;
  border-left-color: #c1271f;
  color: #7a1610;
}

/* Honeypot — completely hidden from real users; bots will fill it */
.honeypot {
  position: absolute !important;
  left: -10000px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

/* Field tweaks specific to the signup form */
.signup-form-card .field label .req { color: var(--forge); }
.signup-form-card .field input.has-error,
.signup-form-card .field select.has-error {
  border-color: #c1271f;
  background: #fdf3f2;
}
.field-error {
  font-size: 12.5px;
  color: #c1271f;
  margin-top: 5px;
  min-height: 0;
  transition: opacity 0.15s ease;
  opacity: 0;
}
.field-error.is-visible { opacity: 1; }

/* Checkbox grid (interests) */
.checkbox-fieldset {
  border: 1px solid var(--steel-pale);
  padding: 18px 22px 14px;
}
.checkbox-fieldset legend {
  font-family: var(--display); font-size: 12px;
  font-weight: 600; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--steel);
  padding: 0 8px;
}
.checkbox-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 18px;
  margin-top: 6px;
}
.checkbox-item {
  display: flex; align-items: center; gap: 9px;
  font-size: 14px; color: var(--ink);
  cursor: pointer; padding: 4px 0;
}
.checkbox-item input { width: 16px; height: 16px; flex-shrink: 0; cursor: pointer; }
.checkbox-item:hover span { color: var(--forge); }

/* Consent row */
.consent-row {
  background: var(--bone);
  border: 1px solid var(--steel-pale);
  padding: 14px 18px;
  margin-top: 4px;
}
.consent-label {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 14.5px; color: var(--ink); cursor: pointer;
}
.consent-label input { width: 18px; height: 18px; flex-shrink: 0; cursor: pointer; margin-top: 2px; }

/* Submit row */
.submit-row {
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid var(--steel-pale);
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.submit-row .submit-note {
  font-size: 12.5px;
  color: var(--steel-soft);
  flex: 1; min-width: 220px;
  line-height: 1.5;
}
.submit-row .submit-note a { color: var(--forge); }

/* Submit button with spinner */
#submit-btn {
  position: relative;
  min-width: 200px;
}
#submit-btn .btn-spinner {
  display: none;
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: var(--paper);
  border-radius: 50%;
  margin-left: 8px;
  vertical-align: middle;
  animation: spin 0.8s linear infinite;
}
#submit-btn.is-loading .btn-spinner { display: inline-block; }
#submit-btn.is-loading .btn-label { opacity: 0.7; }
#submit-btn[disabled] { cursor: not-allowed; opacity: 0.85; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Aside / "what to expect" */
.signup-aside {
  background: var(--navy);
  color: var(--paper);
  padding: 36px 32px 32px;
  border-top: 4px solid var(--forge);
}
.signup-aside h3 {
  font-family: var(--display); font-size: 24px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.005em;
  margin-bottom: 18px;
}
.expect-list { list-style: none; }
.expect-list li {
  border-bottom: 1px solid #ffffff14;
  padding: 14px 0;
  font-size: 14px;
  color: var(--steel-pale);
  line-height: 1.55;
}
.expect-list li:last-child { border-bottom: none; }
.expect-list strong {
  display: block;
  font-family: var(--display);
  font-size: 16px;
  font-weight: 700;
  color: var(--paper);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 4px;
}
.expect-stats {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid #ffffff14;
}
.ex-stat-num {
  font-family: var(--display); font-size: 28px;
  font-weight: 800; color: var(--forge);
  letter-spacing: -0.005em; line-height: 1;
}
.ex-stat-lbl {
  font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--steel-soft);
  margin-top: 6px; font-weight: 500;
}

/* Privacy section */
.privacy-section {
  background: var(--paper);
  padding: 64px 0 80px;
  border-top: 1px solid var(--steel-pale);
}
.privacy-section h3 {
  font-family: var(--display); font-size: 22px; font-weight: 700;
  color: var(--navy); text-transform: uppercase;
  letter-spacing: 0.005em; margin-bottom: 14px;
}
.privacy-section p {
  font-size: 14.5px; color: var(--steel);
  line-height: 1.7; max-width: 760px;
  margin-bottom: 10px;
}
.privacy-section p:last-child { margin-bottom: 0; }

@media (max-width: 1000px) {
  .signup-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .signup-form-card { padding: 28px 24px; }
  .checkbox-grid { grid-template-columns: 1fr; }
  .submit-row { flex-direction: column; align-items: stretch; }
  #submit-btn { width: 100%; }
  .submit-row .submit-note { text-align: center; }
}
/* ============================================================
   Additional styles for the unified register.html signup form.
   Append to css/main.css.

   The .signup-section, .signup-form-card, .field-error, .honeypot,
   .checkbox-fieldset, .consent-row, .submit-row, .submit-note,
   .privacy-section etc. are all already in main.css from the
   earlier signup.html work. The only new thing here is .field-help.
   ============================================================ */

/* Helper text under a form field (e.g. "no payment now — we'll use this to...") */
.field-help {
  font-size: 12.5px;
  color: var(--steel-soft);
  margin-top: 6px;
  line-height: 1.5;
  font-style: italic;
}

/* ============================================================
   Success card — replaces the form on successful submission.
   Append to css/main.css.
   ============================================================ */

/* The forge-tier green: dark enough to feel industrial, bright enough
   to read as a clear success affirmation. Stays in the navy/forge palette
   family of the rest of the site. */
:root {
  --success-green:      #2f8a3e;
  --success-green-deep: #226729;
}

.success-card {
  background: var(--success-green);
  color: var(--paper);
  padding: 64px 40px;
  text-align: center;
  border-top: 4px solid var(--success-green-deep);
  position: relative;
  overflow: hidden;
  /* Match the diagonal hatch pattern used elsewhere on the site */
}
.success-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -45deg,
    rgba(0,0,0,0) 0 18px,
    rgba(0,0,0,0.05) 18px 19px
  );
  pointer-events: none;
}

.success-card > * {
  position: relative;
  z-index: 1;
}

.success-icon {
  width: 72px;
  height: 72px;
  margin: 0 auto 22px;
  color: var(--paper);
}
.success-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.success-title {
  font-family: var(--display);
  font-size: clamp(28px, 3.6vw, 38px);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: var(--paper);
  margin-bottom: 14px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.success-tagline {
  font-family: var(--display);
  font-size: clamp(20px, 2.4vw, 26px);
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--paper);
  text-transform: uppercase;
}

/* DEF CON Mode override — green doesn't fit the black/red theme,
   so flip to a brighter terminal-green that does. */
body.defcon-mode .success-card {
  background: #001a0c;
  border-top-color: #00ff66;
}
body.defcon-mode .success-icon,
body.defcon-mode .success-title,
body.defcon-mode .success-tagline {
  color: #00ff66;
}
