/* ============================================================================
   EDUCATIONALSESSION.COM — PREMIUM ENTERPRISE DESIGN SYSTEM (2026)
   Loaded last; overrides editorial.css / main.css for .es-home & .es-conf.
   Namespace: es-  ·  Headings: Plus Jakarta Sans  ·  Body: Inter
   ========================================================================== */

:root {
  /* Brand */
  --es-ink: #0f172a;
  --es-blue-900: #0f172a;
  --es-blue-700: #1e40af;
  --es-blue-500: #3b82f6;
  --es-cyan: #06b6d4;
  --es-green: #10b981;
  --es-night: #020617;

  /* Surfaces */
  --es-bg: #f8fafc;
  --es-surface: #ffffff;
  --es-surface-2: #f1f5f9;
  --es-text: #111827;
  --es-text-2: #64748b;
  --es-text-3: #94a3b8;
  --es-border: rgba(15, 23, 42, 0.08);
  --es-border-2: rgba(15, 23, 42, 0.12);

  /* Gradients */
  --es-grad: linear-gradient(135deg, #0f172a 0%, #1e40af 50%, #06b6d4 100%);
  --es-grad-soft: linear-gradient(135deg, #1e40af 0%, #06b6d4 100%);
  --es-grad-text: linear-gradient(120deg, #1e40af 0%, #06b6d4 100%);
  --es-grad-night: linear-gradient(
    160deg,
    #020617 0%,
    #0f172a 55%,
    #0b2a6b 130%
  );

  /* Glass */
  --es-glass: rgba(255, 255, 255, 0.72);
  --es-glass-brd: rgba(255, 255, 255, 0.55);
  --es-glass-dk: rgba(255, 255, 255, 0.06);
  --es-glass-dkbr: rgba(255, 255, 255, 0.12);

  /* Shadows — soft, layered */
  --es-sh-xs: 0 1px 2px rgba(15, 23, 42, 0.04);
  --es-sh-sm: 0 2px 8px rgba(15, 23, 42, 0.06);
  --es-sh-md: 0 10px 30px -12px rgba(15, 23, 42, 0.18);
  --es-sh-lg: 0 24px 60px -20px rgba(15, 23, 42, 0.28);
  --es-sh-xl: 0 40px 90px -30px rgba(15, 23, 42, 0.4);
  --es-sh-blue: 0 24px 60px -22px rgba(30, 64, 175, 0.55);
  --es-sh-cyan: 0 18px 50px -18px rgba(6, 182, 212, 0.45);

  /* Radii */
  --es-r-sm: 10px;
  --es-r-md: 16px;
  --es-r-lg: 24px;
  --es-r-xl: 32px;
  --es-r-pill: 999px;

  /* Type */
  --es-font-head: "Plus Jakarta Sans", "Inter", system-ui, sans-serif;
  --es-font-body: "Inter", system-ui, -apple-system, sans-serif;

  /* Layout */
  --es-max: 1240px;
  --es-ease: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ---------- Scoped base ---------------------------------------------------- */
.es-home,
.es-conf {
  background: var(--es-bg) !important;
  font-family: var(--es-font-body) !important;
  color: var(--es-text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
}
.es-home .container,
.es-conf .container {
  max-width: var(--es-max);
  width: 100%;
  margin-inline: auto;
  padding-inline: 24px;
}
.es-home *,
.es-conf * {
  box-sizing: border-box;
}

.es-home h1,
.es-home h2,
.es-home h3,
.es-home h4,
.es-home h5,
.es-conf h1,
.es-conf h2,
.es-conf h3,
.es-conf h4,
.es-conf h5 {
  font-family: var(--es-font-head) !important;
  color: var(--es-ink);
  letter-spacing: -0.02em;
  margin: 0;
}
.es-home p,
.es-conf p {
  margin: 0;
}
.es-home a,
.es-conf a {
  text-decoration: none;
}
.es-home img,
.es-conf img {
  max-width: 100%;
}

/* ---------- Section scaffolding ------------------------------------------- */
.es-section {
  padding: clamp(64px, 9vw, 120px) 0;
  position: relative;
}
.es-section--tight {
  padding: clamp(48px, 6vw, 80px) 0;
}
.es-section--dark {
  background: var(--es-grad-night);
  color: #e2e8f0;
}
.es-section--dark h1,
.es-section--dark h2,
.es-section--dark h3,
.es-section--dark h4 {
  color: #fff !important;
}

.es-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--es-font-head);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--es-blue-700);
}
.es-eyebrow::before {
  content: "";
  width: 22px;
  height: 2px;
  border-radius: 2px;
  background: var(--es-grad-soft);
}
.es-section--dark .es-eyebrow {
  color: var(--es-cyan);
}

.es-head {
  max-width: 720px;
  margin-bottom: clamp(36px, 5vw, 56px);
}
.es-head--center {
  margin-inline: auto;
  text-align: center;
}
.es-head__title {
  font-size: clamp(30px, 4.2vw, 48px);
  font-weight: 800;
  line-height: 1.08;
  margin: 16px 0 0;
}
.es-head__sub {
  margin-top: 16px;
  font-size: clamp(16px, 1.4vw, 18px);
  line-height: 1.6;
  color: var(--es-text-2);
}
.es-section--dark .es-head__sub {
  color: #94a3b8;
}
.es-gradient-text {
  background: var(--es-grad-text);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.es-head-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
  margin-bottom: clamp(32px, 4vw, 48px);
}
.es-head-row .es-head {
  margin-bottom: 0;
}
.es-viewall {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 14px;
  color: var(--es-blue-700);
  white-space: nowrap;
  transition:
    gap 0.25s var(--es-ease),
    color 0.25s;
}
.es-viewall:hover {
  gap: 14px;
  color: var(--es-cyan);
}
.es-viewall svg {
  width: 16px;
  height: 16px;
}

/* ---------- Buttons -------------------------------------------------------- */
.es-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 15px;
  padding: 15px 28px;
  border-radius: var(--es-r-pill);
  border: 1px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  line-height: 1;
  transition:
    transform 0.3s var(--es-ease),
    box-shadow 0.3s var(--es-ease),
    background 0.3s,
    color 0.3s;
}
.es-btn svg {
  width: 18px;
  height: 18px;
}
.es-btn--primary {
  background: var(--es-grad-soft);
  color: #fff;
  box-shadow: var(--es-sh-blue);
}
.es-btn--primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 30px 70px -20px rgba(30, 64, 175, 0.7);
  color: #fff;
}
.es-btn--ghost {
  background: var(--es-surface);
  color: var(--es-ink);
  border-color: var(--es-border-2);
  box-shadow: var(--es-sh-sm);
}
.es-btn--ghost:hover {
  transform: translateY(-3px);
  box-shadow: var(--es-sh-md);
  border-color: var(--es-blue-500);
  color: var(--es-blue-700);
}
.es-btn--light {
  background: #fff;
  color: var(--es-ink);
}
.es-btn--light:hover {
  transform: translateY(-3px);
  box-shadow: var(--es-sh-lg);
  color: var(--es-blue-700);
}
.es-btn--glass {
  background: var(--es-glass-dk);
  color: #fff;
  border-color: var(--es-glass-dkbr);
  backdrop-filter: blur(12px);
}
.es-btn--glass:hover {
  background: rgba(255, 255, 255, 0.14);
  transform: translateY(-3px);
  color: #fff;
}
.es-btn--lg {
  padding: 18px 36px;
  font-size: 16px;
}

/* ---------- Pills / badges ------------------------------------------------- */
.es-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--es-font-head);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 7px 14px;
  border-radius: var(--es-r-pill);
}
.es-pill--live {
  background: rgba(16, 185, 129, 0.12);
  color: #047857;
}
.es-pill--rec {
  background: rgba(59, 130, 246, 0.12);
  color: var(--es-blue-700);
}
.es-pill--cyan {
  background: rgba(6, 182, 212, 0.12);
  color: #0e7490;
}
.es-pill--soft {
  background: var(--es-surface-2);
  color: var(--es-text-2);
}
.es-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--es-green);
  position: relative;
}
.es-dot--live {
  animation: es-pulse 1.8s infinite;
}
@keyframes es-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.5);
  }
  70% {
    box-shadow: 0 0 0 7px rgba(16, 185, 129, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(16, 185, 129, 0);
  }
}

/* ============================================================================
   HEADER (global override — premium glass)
   ========================================================================== */
.ce-header,
.ce-header {
  background: rgba(255, 255, 255, 0.78) !important;
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-bottom: 1px solid var(--es-border);
  box-shadow: none;
  transition:
    box-shadow 0.35s,
    background 0.35s;
}
.ce-header.is-scrolled,
.ce-header.is-scrolled {
  box-shadow: var(--es-sh-md);
  background: rgba(255, 255, 255, 0.92) !important;
  border-color: transparent;
}
.ce-header__inner, .ce-header__inner { min-height: 74px; gap: 20px; }
.ce-header__brand { display: inline-flex; align-items: center; }
.ce-header__brand img { max-height: 34px !important; width: auto !important; max-width: 210px; object-fit: contain; }
@media (max-width: 600px) { .ce-header__brand img { max-height: 28px !important; max-width: 150px; } }

/* nav links — animated underline */
.ce-header__nav, .ce-header__nav { gap: 4px; }
.ce-nav-link, .ce-nav-link {
  font-family: var(--es-font-head); font-weight: 600; font-size: 15px; color: var(--es-text) !important;
  padding: 9px 16px; border-radius: var(--es-r-pill); position: relative;
  transition: color .25s, background .25s; display: inline-flex; align-items: center; gap: 6px;
}
.ce-nav-link:hover, .ce-nav-link:hover { color: var(--es-blue-700) !important; background: rgba(59,130,246,.07); }
.ce-nav-link.active, .ce-nav-link.active { color: var(--es-blue-700) !important; }
.ce-nav-link.active::after, .ce-nav-link.active::after {
  content: ''; position: absolute; left: 16px; right: 16px; bottom: 3px; height: 2px; border-radius: 2px; background: var(--es-grad-soft);
}
.ce-nav-link svg, .ce-nav-link svg { transition: transform .3s var(--es-ease); }
.ce-nav-dropdown.is-open .ce-nav-link--dropdown svg,
.ce-nav-dropdown.is-open .ce-nav-link--dropdown svg { transform: rotate(180deg); }

/* dropdown — premium glass card */
.ce-dropdown-menu, .ce-dropdown-menu {
  border: 1px solid var(--es-border) !important; border-radius: var(--es-r-lg) !important;
  box-shadow: var(--es-sh-lg) !important; padding: 10px !important; background: rgba(255,255,255,.96) !important;
  backdrop-filter: blur(16px); margin-top: 10px !important; min-width: 268px;
}
.ce-dropdown-item, .ce-dropdown-item {
  border-radius: var(--es-r-md) !important; padding: 12px 14px !important; gap: 13px; transition: background .25s, transform .2s;
}
.ce-dropdown-item:hover, .ce-dropdown-item:hover { background: var(--es-surface-2) !important; transform: translateX(2px); }
.ce-dropdown-item strong, .ce-dropdown-item strong { font-family: var(--es-font-head); font-size: 14px; color: var(--es-ink); }
.ce-dropdown-item small, .ce-dropdown-item small { color: var(--es-text-2); }
.ce-dropdown-icon, .ce-dropdown-icon { border-radius: 12px !important; }
.ce-dropdown-icon--live, .ce-dropdown-icon--live { background: rgba(16,185,129,.12) !important; color: #047857 !important; }
.ce-dropdown-icon--rec, .ce-dropdown-icon--rec { background: rgba(59,130,246,.12) !important; color: var(--es-blue-700) !important; }

/* search — pill field */
.ce-search, .ce-search {
  background: var(--es-surface-2) !important; border: 1px solid var(--es-border) !important;
  border-radius: var(--es-r-pill) !important; padding: 4px 4px 4px 16px !important; transition: border-color .25s, box-shadow .25s, background .25s;
}
.ce-search:focus-within, .ce-search:focus-within { background: #fff !important; border-color: var(--es-blue-500) !important; box-shadow: 0 0 0 4px rgba(59,130,246,.12) !important; }
.ce-search__input, .ce-search__input { font-family: var(--es-font-body); font-size: 14px; color: var(--es-ink); }
.ce-search__btn, .ce-search__btn {
  background: var(--es-grad-soft) !important; color: #fff !important; border-radius: 50% !important;
  width: 36px; height: 36px; display: grid; place-items: center; box-shadow: var(--es-sh-blue); transition: transform .25s;
}
.ce-search__btn:hover, .ce-search__btn:hover { transform: scale(1.06); }

/* cart icon */
.ce-header__icon, .ce-header__icon {
  width: 44px; height: 44px; border-radius: var(--es-r-md) !important; display: grid; place-items: center;
  color: var(--es-ink) !important; background: var(--es-surface-2); border: 1px solid var(--es-border); transition: all .25s; position: relative;
}
.ce-header__icon:hover, .ce-header__icon:hover { color: var(--es-blue-700) !important; border-color: var(--es-blue-500); transform: translateY(-2px); }
.ce-header__badge, .ce-header__badge {
  background: var(--es-grad-soft) !important; color: #fff !important; font-family: var(--es-font-head); font-weight: 700;
  box-shadow: var(--es-sh-sm); border: 2px solid #fff;
}

/* login — gradient pill */
.ce-header__login, .ce-header__login {
  background: var(--es-grad-soft) !important; color: #fff !important; border-radius: var(--es-r-pill) !important;
  padding: 11px 20px !important; font-family: var(--es-font-head); font-weight: 700; box-shadow: var(--es-sh-blue);
  transition: transform .25s var(--es-ease), box-shadow .25s;
}
.ce-header__login:hover, .ce-header__login:hover { transform: translateY(-2px); box-shadow: 0 24px 50px -18px rgba(30,64,175,.7); }

/* mobile toggle + drawer */
.ce-header__toggle, .ce-header__toggle {
  width: 44px; height: 44px; border-radius: var(--es-r-md) !important; color: var(--es-ink) !important;
  background: var(--es-surface-2); border: 1px solid var(--es-border); display: grid; place-items: center;
}
.ce-mobile-nav, .ce-mobile-nav { background: rgba(255,255,255,.98) !important; backdrop-filter: blur(16px); border-top: 1px solid var(--es-border); }
.ce-mobile-link, .ce-mobile-link { font-family: var(--es-font-head); font-weight: 600; border-radius: var(--es-r-md); color: var(--es-text) !important; }
.ce-mobile-link:hover, .ce-mobile-link:hover { background: var(--es-surface-2); color: var(--es-blue-700) !important; }
.ce-mobile-link--cta, .ce-mobile-link--cta { background: var(--es-grad-soft) !important; color: #fff !important; text-align: center; box-shadow: var(--es-sh-blue); }
.ce-mobile-search, .ce-mobile-search { background: var(--es-surface-2); border: 1px solid var(--es-border); border-radius: var(--es-r-pill); }
.ce-mobile-search__btn, .ce-mobile-search__btn { background: var(--es-grad-soft) !important; color: #fff !important; border-radius: 50% !important; }

/* ============================================================================
   SECTION 1 — PREMIUM HERO
   ========================================================================== */
.es-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(80px, 8vw, 116px) 0 clamp(64px, 7vw, 104px);
  background: var(--es-bg);
}
.es-hero__mesh {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.es-hero__blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  opacity: 0.5;
  will-change: transform;
}
.es-hero__blob--1 {
  width: 560px;
  height: 560px;
  top: -180px;
  right: -120px;
  background: radial-gradient(circle, rgba(6, 182, 212, 0.55), transparent 65%);
  animation: es-float1 16s ease-in-out infinite;
}
.es-hero__blob--2 {
  width: 620px;
  height: 620px;
  bottom: -260px;
  left: -160px;
  background: radial-gradient(
    circle,
    rgba(59, 130, 246, 0.45),
    transparent 65%
  );
  animation: es-float2 20s ease-in-out infinite;
}
.es-hero__blob--3 {
  width: 400px;
  height: 400px;
  top: 40%;
  left: 45%;
  background: radial-gradient(circle, rgba(30, 64, 175, 0.3), transparent 65%);
  animation: es-float1 22s ease-in-out infinite reverse;
}
.es-hero__grid-lines {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--es-border) 1px, transparent 1px),
    linear-gradient(90deg, var(--es-border) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(
    ellipse 80% 60% at 50% 30%,
    #000 30%,
    transparent 75%
  );
  -webkit-mask-image: radial-gradient(
    ellipse 80% 60% at 50% 30%,
    #000 30%,
    transparent 75%
  );
  opacity: 0.6;
}
@keyframes es-float1 {
  0%,
  100% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(-32px, 28px);
  }
}
@keyframes es-float2 {
  0%,
  100% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(36px, -30px);
  }
}

.es-hero__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: stretch;
}
.es-hero__lead {
  align-self: center;
}
.es-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 26px;
  background: var(--es-surface);
  border: 1px solid var(--es-border);
  padding: 8px 16px 8px 10px;
  border-radius: var(--es-r-pill);
  font-size: 13px;
  font-weight: 600;
  color: var(--es-text-2);
  box-shadow: var(--es-sh-sm);
}
.es-hero__badge b {
  color: var(--es-ink);
  font-family: var(--es-font-head);
}
.es-hero__badge .es-dot {
  width: 8px;
  height: 8px;
}
.es-hero__h1 {
  font-size: clamp(38px, 4.8vw, 60px);
  font-weight: 800;
  line-height: 1.06;
  letter-spacing: -0.03em;
  color: var(--es-ink);
}
.es-hero__lede {
  margin-top: 26px;
  font-size: clamp(17px, 1.5vw, 20px);
  line-height: 1.6;
  color: var(--es-text-2);
  max-width: 520px;
}
.es-hero__actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 36px;
}
.es-hero__trust {
  display: flex;
  gap: clamp(20px, 3vw, 40px);
  margin-top: 44px;
  flex-wrap: wrap;
  padding-top: 30px;
  border-top: 1px solid var(--es-border);
}
.es-hero__trust-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.es-hero__trust-num {
  font-family: var(--es-font-head);
  font-size: clamp(24px, 2.6vw, 30px);
  font-weight: 800;
  color: var(--es-ink);
  line-height: 1;
}
.es-hero__trust-lbl {
  font-size: 13px;
  color: var(--es-text-2);
  font-weight: 500;
}

/* Hero visual — floating glass cards */
.es-hero__visual {
  position: relative;
  min-height: 480px;
}
.es-hero__orbit {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: var(--es-grad);
  filter: blur(8px);
  opacity: 0.14;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.es-hero__panel {
  position: absolute;
  border-radius: var(--es-r-lg);
  background: var(--es-glass);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--es-glass-brd);
  box-shadow: var(--es-sh-lg);
  padding: 18px;
  will-change: transform;
}
.es-hero__panel--main {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(330px, 78%);
  padding: 22px;
  animation: es-bob 7s ease-in-out infinite;
}
.es-hero__panel--card2 {
  top: 6%;
  right: -2%;
  width: 230px;
  animation: es-bob 6s ease-in-out infinite 0.6s;
}
.es-hero__panel--card3 {
  bottom: 2%;
  left: -4%;
  width: 250px;
  animation: es-bob 8s ease-in-out infinite 1.2s;
}
.es-hero__panel--badge {
  bottom: 16%;
  right: 2%;
  display: flex;
  align-items: center;
  gap: 12px;
  animation: es-bob 6.5s ease-in-out infinite 0.3s;
}
@keyframes es-bob {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-14px);
  }
}
.es-hero__panel--main {
  animation-name: es-bob-main;
}
@keyframes es-bob-main {
  0%,
  100% {
    transform: translate(-50%, -50%);
  }
  50% {
    transform: translate(-50%, calc(-50% - 12px));
  }
}

.es-hp-row {
  display: flex;
  align-items: center;
  gap: 12px;
}
.es-hp-av {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  object-fit: cover;
  flex-shrink: 0;
  box-shadow: var(--es-sh-sm);
  background: var(--es-surface-2);
}
.es-hp-av--grad {
  background: var(--es-grad-soft);
  display: grid;
  place-items: center;
  color: #fff;
  font-family: var(--es-font-head);
  font-weight: 800;
}
.es-hp-name {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 14px;
  color: var(--es-ink);
}
.es-hp-sub {
  font-size: 12px;
  color: var(--es-text-2);
}
.es-hp-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  color: #047857;
  background: rgba(16, 185, 129, 0.12);
  padding: 5px 10px;
  border-radius: var(--es-r-pill);
  margin-bottom: 14px;
}
.es-hp-title {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 16px;
  line-height: 1.3;
  color: var(--es-ink);
  margin: 12px 0;
}
.es-hp-meta {
  display: flex;
  gap: 14px;
  font-size: 12px;
  color: var(--es-text-2);
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--es-border);
}
.es-hp-meta span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

/* mini bar chart */
.es-hp-chart {
  display: flex;
  align-items: flex-end;
  gap: 7px;
  height: 56px;
  margin-top: 10px;
}
.es-hp-bar {
  flex: 1;
  border-radius: 5px 5px 2px 2px;
  background: var(--es-grad-soft);
  opacity: 0.85;
  animation: es-grow 1.2s var(--es-ease) backwards;
}
@keyframes es-grow {
  from {
    height: 4px !important;
    opacity: 0;
  }
}
.es-hp-cert {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: var(--es-grad-soft);
  display: grid;
  place-items: center;
  color: #fff;
  flex-shrink: 0;
}
.es-hp-cert svg {
  width: 22px;
  height: 22px;
}

/* ============================================================================
   SECTION 2 — LOGO WALL / TRUSTED BY
   ========================================================================== */
.es-trusted {
  padding: clamp(40px, 5vw, 56px) 0;
  border-block: 1px solid var(--es-border);
  background: var(--es-surface);
}
.es-trusted__label {
  text-align: center;
  font-family: var(--es-font-head);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--es-text-3);
  margin-bottom: 30px;
}
.es-marquee {
  position: relative;
  overflow: hidden;
  mask-image: linear-gradient(
    90deg,
    transparent,
    #000 12%,
    #000 88%,
    transparent
  );
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent,
    #000 12%,
    #000 88%,
    transparent
  );
}
.es-marquee__track {
  display: flex;
  gap: clamp(40px, 6vw, 80px);
  width: max-content;
  animation: es-scroll 38s linear infinite;
}
.es-marquee:hover .es-marquee__track {
  animation-play-state: paused;
}
@keyframes es-scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
.es-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  font-family: var(--es-font-head);
  font-weight: 800;
  font-size: 19px;
  color: var(--es-text-3);
  letter-spacing: -0.02em;
  opacity: 0.75;
  transition:
    color 0.3s,
    opacity 0.3s;
  white-space: nowrap;
}
.es-logo:hover {
  color: var(--es-blue-700);
  opacity: 1;
}
.es-logo svg {
  width: 24px;
  height: 24px;
}

/* ============================================================================
   SECTION 3 — BENTO CATEGORIES
   ========================================================================== */
.es-bento {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(236px, 1fr));
  gap: 18px;
}
.es-bento__card {
  position: relative;
  overflow: hidden;
  min-height: 186px;
  border-radius: var(--es-r-lg);
  background: var(--es-surface);
  border: 1px solid var(--es-border);
  padding: 26px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  box-shadow: var(--es-sh-sm);
  transition:
    transform 0.4s var(--es-ease),
    box-shadow 0.4s,
    border-color 0.4s;
}
/* hover accent bar */
.es-bento__card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 3px;
  background: var(--es-grad-soft);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.45s var(--es-ease);
  z-index: 2;
}
.es-bento__card::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.4s;
  background: radial-gradient(
    circle at 85% 0%,
    rgba(6, 182, 212, 0.1),
    transparent 55%
  );
}
.es-bento__card:hover {
  transform: translateY(-6px);
  box-shadow: var(--es-sh-lg);
  border-color: transparent;
}
.es-bento__card:hover::before {
  transform: scaleX(1);
}
.es-bento__card:hover::after {
  opacity: 1;
}

/* full-width premium feature banner */
.es-bento__card--feature {
  grid-column: 1 / -1;
  flex-direction: row;
  align-items: center;
  gap: 28px;
  min-height: 168px;
  padding: 36px clamp(28px, 4vw, 48px);
  color: #fff;
  background: var(--es-grad);
  border: none;
}
.es-bento__card--feature::before {
  display: none;
}
.es-bento__card--feature::after {
  background:
    radial-gradient(circle at 88% 10%, rgba(255, 255, 255, 0.2), transparent 45%),
    radial-gradient(circle at 10% 120%, rgba(6, 182, 212, 0.4), transparent 55%);
  opacity: 1;
}
.es-bento__card--feature .es-bento__body {
  flex: 1;
}
.es-bento__card--feature .es-bento__ico {
  background: rgba(255, 255, 255, 0.16);
  border: 1px solid rgba(255, 255, 255, 0.22);
  color: #fff;
  width: 64px;
  height: 64px;
  flex-shrink: 0;
}
.es-bento__card--feature .es-bento__ico svg {
  width: 30px;
  height: 30px;
}

.es-bento__ico {
  width: 50px;
  height: 50px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  background: var(--es-surface-2);
  color: var(--es-blue-700);
  position: relative;
  z-index: 1;
  transition: transform 0.4s var(--es-ease);
}
.es-bento__card:hover .es-bento__ico {
  transform: scale(1.08) rotate(-5deg);
}
.es-bento__ico svg {
  width: 25px;
  height: 25px;
}
/* category-tinted icons */
.es-bento__card[data-cat="hr"] .es-bento__ico { background: rgba(99,102,241,.12); color: #4f46e5; }
.es-bento__card[data-cat="health"] .es-bento__ico { background: rgba(16,185,129,.12); color: #059669; }
.es-bento__card[data-cat="finance"] .es-bento__ico { background: rgba(5,150,105,.12); color: #047857; }
.es-bento__card[data-cat="pharma"] .es-bento__ico { background: rgba(139,92,246,.13); color: #7c3aed; }
.es-bento__card[data-cat="estate"] .es-bento__ico { background: rgba(245,158,11,.15); color: #d97706; }
.es-bento__card[data-cat="edu"] .es-bento__ico { background: rgba(59,130,246,.12); color: #2563eb; }
.es-bento__card[data-cat="legal"] .es-bento__ico { background: rgba(100,116,139,.15); color: #475569; }
.es-bento__card[data-cat="tech"] .es-bento__ico { background: rgba(6,182,212,.15); color: #0891b2; }

.es-bento__body {
  position: relative;
  z-index: 1;
}
.es-bento__name {
  font-family: var(--es-font-head);
  font-weight: 800;
  font-size: 18px;
  color: var(--es-ink);
  line-height: 1.25;
}
.es-bento__card--feature .es-bento__name {
  color: #fff;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.12;
}
.es-bento__desc {
  font-size: 13px;
  color: var(--es-text-2);
  margin-top: 5px;
}
.es-bento__card--feature .es-bento__desc {
  color: rgba(255, 255, 255, 0.85);
  font-size: 15px;
  margin-top: 10px;
  max-width: 460px;
  line-height: 1.55;
}
.es-bento__count {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  color: var(--es-cyan);
  font-family: var(--es-font-head);
  letter-spacing: .02em;
}
.es-bento__count::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.es-bento__card--feature .es-bento__count {
  color: #fff;
}
.es-bento__arrow {
  position: absolute;
  top: 24px;
  right: 24px;
  color: var(--es-text-3);
  opacity: 0;
  transform: translate(-6px, 6px);
  transition: all 0.35s var(--es-ease);
  z-index: 1;
}
.es-bento__card:hover .es-bento__arrow {
  opacity: 1;
  transform: translate(0, 0);
  color: var(--es-blue-700);
}
.es-bento__card--feature .es-bento__arrow {
  position: static;
  opacity: 1;
  transform: none;
  color: #fff;
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.16);
  border: 1px solid rgba(255, 255, 255, 0.22);
  display: grid;
  place-items: center;
  transition: background 0.3s, transform 0.3s var(--es-ease);
}
.es-bento__card--feature:hover .es-bento__arrow {
  background: rgba(255, 255, 255, 0.28);
  transform: translateX(4px);
}

/* ============================================================================
   SECTIONS 4 & 5 — RAILS (conferences + webinars horizontal scroll)
   ========================================================================== */
.es-rail-wrap {
  position: relative;
}
/* right-edge fade where cards overflow the viewport */
.es-rail-wrap::after {
  content: ''; position: absolute; top: 0; right: -4px; bottom: 28px; width: 72px;
  background: linear-gradient(90deg, transparent, var(--es-bg));
  pointer-events: none; z-index: 2;
}
.es-section[style*="surface"] .es-rail-wrap::after {
  background: linear-gradient(90deg, transparent, var(--es-surface));
}
.es-rail {
  display: flex;
  gap: 22px;
  overflow-x: auto;
  scroll-behavior: smooth;
  padding: 8px 4px 28px;
  margin: 0 -4px;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}
.es-rail::-webkit-scrollbar {
  display: none;
}
.es-rail__nav {
  display: flex;
  gap: 10px;
}
.es-rail-btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: var(--es-surface);
  border: 1px solid var(--es-border-2);
  color: var(--es-ink);
  cursor: pointer;
  box-shadow: var(--es-sh-sm);
  transition: all 0.25s var(--es-ease);
}
.es-rail-btn:hover {
  background: var(--es-grad-soft);
  color: #fff;
  border-color: transparent;
  transform: scale(1.06);
  box-shadow: var(--es-sh-blue);
}
.es-rail-btn svg {
  width: 18px;
  height: 18px;
}
.es-rail-btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  transform: none;
}

/* Event / conference card — glass + gradient border */
.es-ecard {
  scroll-snap-align: start;
  flex: 0 0 360px;
  max-width: 360px;
  position: relative;
  border-radius: var(--es-r-lg);
  background: var(--es-surface);
  border: 1px solid var(--es-border);
  box-shadow: var(--es-sh-sm);
  display: flex;
  flex-direction: column;
  transition:
    transform 0.4s var(--es-ease),
    box-shadow 0.4s;
}
.es-ecard:hover {
  transform: translateY(-8px);
  box-shadow: var(--es-sh-lg);
}
.es-ecard__media {
  position: relative;
  height: 158px;
  background: var(--es-grad);
}
.es-ecard__media::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 20% 20%,
    rgba(255, 255, 255, 0.22),
    transparent 50%
  );
}
.es-ecard__pattern {
  position: absolute;
  inset: 0;
  opacity: 0.5;
  background-image: radial-gradient(
    rgba(255, 255, 255, 0.25) 1px,
    transparent 1px
  );
  background-size: 18px 18px;
}
/* real imagery (Unsplash) behind brand veil */
.es-ecard__media--photo { background: #0F172A; }
.es-ecard__photo {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; z-index: 0;
  transition: transform 0.7s var(--es-ease);
}
.es-ecard:hover .es-ecard__photo { transform: scale(1.07); }
.es-ecard__veil {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(150deg, rgba(15,23,42,.82), rgba(30,64,175,.5) 55%, rgba(6,182,212,.42));
}
.es-ecard__media--photo .es-ecard__pattern { z-index: 1; opacity: 0.35; }
.es-ecard__date {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 2;
  text-align: center;
  background: rgba(255, 255, 255, 0.92);
  border-radius: var(--es-r-sm);
  padding: 8px 12px;
  box-shadow: var(--es-sh-sm);
  min-width: 58px;
}
.es-ecard__date b {
  display: block;
  font-family: var(--es-font-head);
  font-size: 22px;
  font-weight: 800;
  color: var(--es-ink);
  line-height: 1;
}
.es-ecard__date span {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--es-blue-700);
}
.es-ecard__live {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 2;
}
.es-ecard__credits {
  position: absolute;
  bottom: -16px;
  right: 18px;
  z-index: 3;
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: #fff;
  box-shadow: var(--es-sh-md);
  display: grid;
  place-items: center;
  text-align: center;
  border: 1px solid var(--es-border);
}
.es-ecard__credits b {
  font-family: var(--es-font-head);
  font-size: 17px;
  font-weight: 800;
  color: var(--es-blue-700);
  line-height: 1;
}
.es-ecard__credits span {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--es-text-3);
}
.es-ecard__body {
  padding: 24px 22px 22px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.es-ecard__title {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 18px;
  line-height: 1.32;
  color: var(--es-ink);
  margin-bottom: 14px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.6em;
}
.es-ecard__title:hover {
  color: var(--es-blue-700);
}
.es-ecard__rows {
  display: flex;
  flex-direction: column;
  gap: 9px;
  margin-bottom: 18px;
}
.es-ecard__row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  color: var(--es-text-2);
}
.es-ecard__row svg {
  width: 16px;
  height: 16px;
  color: var(--es-cyan);
  flex-shrink: 0;
}
.es-ecard__speaker {
  display: flex;
  align-items: center;
  gap: 10px;
}
.es-ecard__speaker img {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--es-surface-2);
}
.es-ecard__foot {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--es-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.es-ecard__price b {
  font-family: var(--es-font-head);
  font-size: 20px;
  font-weight: 800;
  color: var(--es-ink);
}
.es-ecard__price span {
  font-size: 12px;
  color: var(--es-text-3);
}
.es-ecard__reg {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 13px;
  color: #fff;
  background: var(--es-grad-soft);
  padding: 10px 18px;
  border-radius: var(--es-r-pill);
  transition:
    gap 0.25s,
    box-shadow 0.3s;
}
.es-ecard:hover .es-ecard__reg {
  box-shadow: var(--es-sh-blue);
}
.es-ecard__reg svg {
  width: 15px;
  height: 15px;
}

/* Webinar card variant (rich speaker focus) */
.es-wcard {
  flex: 0 0 320px;
  max-width: 320px;
}
.es-wcard__top {
  padding: 22px 22px 0;
  display: flex;
  align-items: center;
  gap: 14px;
}
.es-wcard__av {
  width: 60px;
  height: 60px;
  border-radius: 18px;
  object-fit: cover;
  background: var(--es-surface-2);
  box-shadow: var(--es-sh-sm);
}
.es-wcard__sp-name {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 15px;
  color: var(--es-ink);
}
.es-wcard__sp-role {
  font-size: 12.5px;
  color: var(--es-text-2);
}
.es-wcard__reviews {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--es-text-2);
  margin-top: 4px;
}
.es-wcard__reviews svg {
  width: 13px;
  height: 13px;
  color: #f59e0b;
}

/* ============================================================================
   SECTION 6 — WHY CHOOSE US (feature cards)
   ========================================================================== */
.es-feats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.es-feat {
  background: var(--es-surface);
  border: 1px solid var(--es-border);
  border-radius: var(--es-r-lg);
  padding: 30px 26px;
  box-shadow: var(--es-sh-sm);
  position: relative;
  overflow: hidden;
  transition:
    transform 0.4s var(--es-ease),
    box-shadow 0.4s;
}
.es-feat::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 3px;
  width: 100%;
  background: var(--es-grad-soft);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s var(--es-ease);
}
.es-feat:hover {
  transform: translateY(-6px);
  box-shadow: var(--es-sh-lg);
}
.es-feat:hover::before {
  transform: scaleX(1);
}
.es-feat__ico {
  width: 54px;
  height: 54px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: linear-gradient(
    135deg,
    rgba(30, 64, 175, 0.1),
    rgba(6, 182, 212, 0.12)
  );
  color: var(--es-blue-700);
  margin-bottom: 20px;
}
.es-feat__ico svg {
  width: 26px;
  height: 26px;
}
.es-feat__title {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 18px;
  color: var(--es-ink);
  margin-bottom: 9px;
}
.es-feat__desc {
  font-size: 14px;
  line-height: 1.6;
  color: var(--es-text-2);
}

/* ============================================================================
   SECTION 7 — SPEAKERS SHOWCASE
   ========================================================================== */
.es-speakers {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.es-spk {
  position: relative;
  border-radius: var(--es-r-lg);
  overflow: hidden;
  display: block;
  background: var(--es-ink);
  box-shadow: var(--es-sh-sm);
  aspect-ratio: 3/4;
  transition:
    transform 0.4s var(--es-ease),
    box-shadow 0.4s;
}
.es-spk:hover {
  transform: translateY(-6px);
  box-shadow: var(--es-sh-lg);
}
.es-spk img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--es-ease);
}
.es-spk:hover img {
  transform: scale(1.06);
}
.es-spk__veil {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(2, 6, 23, 0.92) 6%,
    rgba(2, 6, 23, 0.3) 46%,
    transparent 70%
  );
}
.es-spk__info {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 20px;
  z-index: 2;
}
.es-spk__name {
  font-family: var(--es-font-head);
  font-weight: 800;
  font-size: 18px;
  color: #fff;
}
.es-spk__role {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.78);
  margin-top: 2px;
}
.es-spk__ln {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 2;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(8px);
  display: grid;
  place-items: center;
  color: #fff;
  opacity: 0;
  transform: translateY(-6px);
  transition: all 0.35s var(--es-ease);
}
.es-spk:hover .es-spk__ln {
  opacity: 1;
  transform: translateY(0);
}
.es-spk__ln svg {
  width: 18px;
  height: 18px;
}

/* ============================================================================
   SECTION 8 — LEARNING JOURNEY TIMELINE
   ========================================================================== */
.es-journey {
  position: relative;
}
.es-journey__line {
  position: absolute;
  top: 38px;
  left: 8%;
  right: 8%;
  height: 2px;
  background: linear-gradient(
    90deg,
    var(--es-border),
    var(--es-blue-500),
    var(--es-cyan),
    var(--es-border)
  );
  z-index: 0;
}
.es-journey__steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
  position: relative;
  z-index: 1;
}
.es-jstep {
  text-align: center;
}
.es-jstep__dot {
  width: 76px;
  height: 76px;
  border-radius: 22px;
  margin: 0 auto 22px;
  display: grid;
  place-items: center;
  background: var(--es-surface);
  border: 1px solid var(--es-border);
  box-shadow: var(--es-sh-md);
  color: var(--es-blue-700);
  position: relative;
  transition: transform 0.4s var(--es-ease);
}
.es-jstep:hover .es-jstep__dot {
  transform: translateY(-6px) scale(1.05);
}
.es-jstep__dot svg {
  width: 30px;
  height: 30px;
}
.es-jstep__num {
  position: absolute;
  top: -8px;
  right: -8px;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--es-grad-soft);
  color: #fff;
  font-family: var(--es-font-head);
  font-weight: 800;
  font-size: 12px;
  display: grid;
  place-items: center;
  box-shadow: var(--es-sh-sm);
}
.es-jstep__title {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 16px;
  color: var(--es-ink);
}
.es-jstep__desc {
  font-size: 13px;
  color: var(--es-text-2);
  margin-top: 6px;
}

/* ============================================================================
   SECTION 9 — CERTIFICATION SHOWCASE
   ========================================================================== */
.es-cert-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: center;
}
.es-cert-points {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 30px;
}
.es-cert-point {
  display: flex;
  gap: 16px;
}
.es-cert-point__ico {
  width: 44px;
  height: 44px;
  border-radius: 13px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  background: rgba(16, 185, 129, 0.12);
  color: var(--es-green);
}
.es-cert-point__ico svg {
  width: 22px;
  height: 22px;
}
.es-cert-point h4 {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 16px;
  color: var(--es-ink);
}
.es-cert-point p {
  font-size: 14px;
  color: var(--es-text-2);
  margin-top: 3px;
  line-height: 1.55;
}
.es-cert-visual {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 380px;
}
.es-cert-doc {
  position: relative;
  z-index: 2;
  width: min(380px, 90%);
  background: #fff;
  border-radius: var(--es-r-lg);
  box-shadow: var(--es-sh-xl);
  border: 1px solid var(--es-border);
  padding: 30px;
  transform: rotate(-3deg);
  transition: transform 0.5s var(--es-ease);
}
.es-cert-visual:hover .es-cert-doc {
  transform: rotate(0);
}
.es-cert-doc__seal {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  margin: 0 auto 16px;
  background: var(--es-grad);
  display: grid;
  place-items: center;
  color: #fff;
  box-shadow: var(--es-sh-cyan);
}
.es-cert-doc__seal svg {
  width: 32px;
  height: 32px;
}
.es-cert-doc__t1 {
  text-align: center;
  font-family: var(--es-font-head);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--es-text-3);
}
.es-cert-doc__t2 {
  text-align: center;
  font-family: var(--es-font-head);
  font-weight: 800;
  font-size: 22px;
  color: var(--es-ink);
  margin: 6px 0 14px;
}
.es-cert-doc__line {
  height: 9px;
  border-radius: 5px;
  background: var(--es-surface-2);
  margin: 9px 0;
}
.es-cert-doc__line.w-70 {
  width: 70%;
  margin-inline: auto;
}
.es-cert-doc__line.w-40 {
  width: 40%;
  margin-inline: auto;
}
.es-cert-doc__sign {
  display: flex;
  justify-content: space-between;
  margin-top: 22px;
}
.es-cert-doc__sign div {
  height: 30px;
  width: 38%;
  border-top: 1.5px solid var(--es-border-2);
  font-size: 9px;
  color: var(--es-text-3);
  padding-top: 5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.es-cert-badge2 {
  position: absolute;
  z-index: 3;
  background: #fff;
  border-radius: var(--es-r-md);
  box-shadow: var(--es-sh-lg);
  border: 1px solid var(--es-border);
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.es-cert-badge2--a {
  top: 8%;
  right: 2%;
  animation: es-bob 6s ease-in-out infinite;
}
.es-cert-badge2--b {
  bottom: 6%;
  left: 0;
  animation: es-bob 7s ease-in-out infinite 0.8s;
}
.es-cert-badge2 svg {
  width: 26px;
  height: 26px;
  color: var(--es-blue-700);
}
.es-cert-badge2 b {
  font-family: var(--es-font-head);
  font-size: 13px;
  color: var(--es-ink);
  display: block;
}
.es-cert-badge2 span {
  font-size: 11px;
  color: var(--es-text-2);
}

/* ============================================================================
   SECTION 10 — TESTIMONIALS (glass cards)
   ========================================================================== */
.es-testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.es-testi {
  border-radius: var(--es-r-lg);
  padding: 30px;
  border: 1px solid var(--es-glass-dkbr);
  background: var(--es-glass-dk);
  backdrop-filter: blur(16px);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.es-testi__stars {
  display: flex;
  gap: 3px;
  margin-bottom: 16px;
}
.es-testi__stars svg {
  width: 16px;
  height: 16px;
  color: #fbbf24;
}
.es-testi__quote {
  font-size: 15px;
  line-height: 1.65;
  color: #e2e8f0;
  flex: 1;
}
.es-testi__cite {
  display: flex;
  align-items: center;
  gap: 13px;
  margin-top: 22px;
  padding-top: 20px;
  border-top: 1px solid var(--es-glass-dkbr);
}
.es-testi__av {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--es-grad-soft);
  display: grid;
  place-items: center;
  color: #fff;
  font-family: var(--es-font-head);
  font-weight: 800;
  flex-shrink: 0;
}
.es-testi__name {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 15px;
  color: #fff;
}
.es-testi__role {
  font-size: 13px;
  color: #94a3b8;
}
.es-testi__playicon {
  position: absolute;
  top: 26px;
  right: 26px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  display: grid;
  place-items: center;
  color: #fff;
}
.es-testi__playicon svg {
  width: 16px;
  height: 16px;
}

/* ============================================================================
   SECTION 11 — STATS COUNTERS
   ========================================================================== */
.es-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.es-stat {
  text-align: center;
  padding: 30px 16px;
  border-radius: var(--es-r-lg);
  background: var(--es-glass-dk);
  border: 1px solid var(--es-glass-dkbr);
}
.es-stat__num {
  font-family: var(--es-font-head);
  font-size: clamp(38px, 5vw, 56px);
  font-weight: 800;
  line-height: 1;
  background: linear-gradient(120deg, #fff, #67e8f9);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.es-stat__lbl {
  font-size: 14px;
  color: #94a3b8;
  margin-top: 12px;
  font-weight: 500;
}

/* ============================================================================
   SECTION 12 — FAQ ACCORDION
   ========================================================================== */
.es-faq-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: start;
}
.es-faq {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.es-faq__item {
  border: 1px solid var(--es-border);
  border-radius: var(--es-r-md);
  background: var(--es-surface);
  overflow: hidden;
  transition:
    border-color 0.3s,
    box-shadow 0.3s;
}
.es-faq__item.is-open {
  border-color: var(--es-blue-500);
  box-shadow: var(--es-sh-md);
}
.es-faq__q {
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  cursor: pointer;
  padding: 22px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 16px;
  color: var(--es-ink);
}
.es-faq__icon {
  width: 30px;
  height: 30px;
  border-radius: 9px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  background: var(--es-surface-2);
  color: var(--es-blue-700);
  transition:
    transform 0.35s var(--es-ease),
    background 0.3s,
    color 0.3s;
}
.es-faq__item.is-open .es-faq__icon {
  transform: rotate(135deg);
  background: var(--es-grad-soft);
  color: #fff;
}
.es-faq__a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s var(--es-ease);
}
.es-faq__a-inner {
  padding: 0 24px 22px;
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--es-text-2);
}

/* ============================================================================
   SECTION 13 — FINAL CTA
   ========================================================================== */
.es-finalcta {
  position: relative;
  overflow: hidden;
  border-radius: var(--es-r-xl);
  padding: clamp(48px, 7vw, 88px) clamp(28px, 5vw, 72px);
  background: var(--es-grad-night);
  box-shadow: var(--es-sh-xl);
  text-align: center;
}
.es-finalcta__glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
}
.es-finalcta__glow--1 {
  width: 420px;
  height: 420px;
  top: -160px;
  left: -80px;
  background: radial-gradient(circle, rgba(6, 182, 212, 0.4), transparent 65%);
}
.es-finalcta__glow--2 {
  width: 420px;
  height: 420px;
  bottom: -180px;
  right: -60px;
  background: radial-gradient(circle, rgba(59, 130, 246, 0.4), transparent 65%);
}
.es-finalcta__inner {
  position: relative;
  z-index: 1;
  max-width: 720px;
  margin: 0 auto;
}
.es-finalcta h2 {
  font-size: clamp(30px, 4.5vw, 52px);
  font-weight: 800;
  color: #fff !important;
  line-height: 1.08;
}
.es-finalcta p {
  font-size: clamp(16px, 1.5vw, 19px);
  color: #94a3b8;
  margin: 20px 0 36px;
  line-height: 1.6;
}
.es-finalcta__actions {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}
.es-finalcta__note {
  margin-top: 28px;
  font-size: 13px;
  color: #64748b;
  display: flex;
  gap: 22px;
  justify-content: center;
  flex-wrap: wrap;
}
.es-finalcta__note span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.es-finalcta__note svg {
  width: 15px;
  height: 15px;
  color: var(--es-green);
}

/* ============================================================================
   FOOTER (premium override)
   ========================================================================== */
.ce-footer, .ce-footer { background: var(--es-night); position: relative; }

/* newsletter bar — gradient with glow */
.ce-footer__newsletter, .ce-footer__newsletter {
  background: var(--es-grad); position: relative; overflow: hidden; padding: 36px 0;
}
.ce-footer__newsletter::after, .ce-footer__newsletter::after {
  content: ''; position: absolute; width: 420px; height: 420px; border-radius: 50%; top: -60%; right: 6%;
  background: radial-gradient(circle, rgba(255,255,255,.18), transparent 60%); pointer-events: none;
}
.ce-footer__newsletter-inner, .ce-footer__newsletter-inner { position: relative; z-index: 1; gap: 24px; }
.ce-footer__newsletter-text strong, .ce-footer__newsletter-text strong { font-family: var(--es-font-head); font-weight: 800; font-size: 22px; color: #fff; }
.ce-footer__newsletter-text span, .ce-footer__newsletter-text span { color: rgba(255,255,255,.82); }
.ce-footer__newsletter-form, .ce-footer__newsletter-form {
  background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.22); border-radius: var(--es-r-pill);
  padding: 5px 5px 5px 6px; backdrop-filter: blur(8px);
}
.ce-footer__newsletter-form input, .ce-footer__newsletter-form input {
  background: transparent; border: none; color: #fff; font-family: var(--es-font-body); padding: 0 16px; min-width: 220px;
}
.ce-footer__newsletter-form input::placeholder, .ce-footer__newsletter-form input::placeholder { color: rgba(255,255,255,.7); }
.ce-footer__newsletter-form button, .ce-footer__newsletter-form button {
  background: #fff !important; color: var(--es-blue-700) !important; font-family: var(--es-font-head); font-weight: 700;
  border: none; border-radius: var(--es-r-pill); padding: 12px 26px; cursor: pointer; transition: transform .25s, box-shadow .25s;
}
.ce-footer__newsletter-form button:hover, .ce-footer__newsletter-form button:hover { transform: translateY(-2px); box-shadow: 0 16px 30px -12px rgba(0,0,0,.4); }

/* main footer body */
.ce-footer__top, .ce-footer__top {
  background: var(--es-night); border-top: 1px solid rgba(255,255,255,.06); padding: 64px 0 48px;
}
.ce-footer__logo, .ce-footer__logo { max-height: 44px; width: auto; margin-bottom: 18px; filter: brightness(0) invert(1); opacity: .95; }
.ce-footer__tagline, .ce-footer__tagline { color: #94A3B8; line-height: 1.65; font-size: 14.5px; max-width: 320px; }
.ce-footer__social, .ce-footer__social { display: flex; gap: 10px; margin-top: 22px; }
.ce-footer__social a, .ce-footer__social a {
  width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.10); color: #CBD5E1;
  transition: all .3s var(--es-ease);
}
.ce-footer__social a:hover, .ce-footer__social a:hover { background: var(--es-grad-soft); color: #fff; border-color: transparent; transform: translateY(-3px); box-shadow: var(--es-sh-cyan); }
.ce-footer__heading, .ce-footer__heading {
  font-family: var(--es-font-head); font-weight: 700; font-size: 14px; letter-spacing: .04em; color: #fff; margin-bottom: 18px;
}
.ce-footer__links li, .ce-footer__links li { margin-bottom: 11px; }
.ce-footer__links a, .ce-footer__links a {
  color: #94A3B8; font-size: 14.5px; transition: color .25s, padding-left .25s; position: relative;
}
.ce-footer__links a:hover, .ce-footer__links a:hover { color: #fff; padding-left: 6px; }
.ce-footer__contact-row, .ce-footer__contact-row { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; color: #94A3B8; font-size: 14px; }
.ce-footer__contact-row svg, .ce-footer__contact-row svg { color: var(--es-cyan); flex-shrink: 0; margin-top: 2px; }
.ce-footer__contact-row a, .ce-footer__contact-row a { color: #94A3B8; transition: color .25s; }
.ce-footer__contact-row a:hover, .ce-footer__contact-row a:hover { color: #fff; }
.ce-footer__payment, .ce-footer__payment { margin-top: 24px; }
.ce-footer__payment-label, .ce-footer__payment-label { display: block; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--es-text-3); margin-bottom: 10px; }
.ce-footer__payment-icons, .ce-footer__payment-icons { display: flex; gap: 10px; }
.ce-footer__payment-icons span, .ce-footer__payment-icons span {
  width: 46px; height: 32px; border-radius: 8px; display: grid; place-items: center;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.1); color: #CBD5E1; font-size: 18px;
}

/* bottom bar */
.ce-footer__bottom, .ce-footer__bottom { background: #010413; border-top: 1px solid rgba(255,255,255,.06); padding: 20px 0; }
.ce-footer__bottom-inner, .ce-footer__bottom-inner { color: #64748B; font-size: 13.5px; }
.ce-footer__bottom a, .ce-footer__bottom a { color: #94A3B8; transition: color .25s; }
.ce-footer__bottom a:hover, .ce-footer__bottom a:hover { color: #fff; }
.ce-footer__bottom-links, .ce-footer__bottom-links { display: flex; gap: 20px; }

/* ============================================================================
   SCROLL REVEAL + UTILITIES
   ========================================================================== */
.es-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.8s var(--es-ease),
    transform 0.8s var(--es-ease);
}
.es-reveal.is-in {
  opacity: 1;
  transform: none;
}
.es-reveal[data-delay="1"] {
  transition-delay: 0.08s;
}
.es-reveal[data-delay="2"] {
  transition-delay: 0.16s;
}
.es-reveal[data-delay="3"] {
  transition-delay: 0.24s;
}
.es-reveal[data-delay="4"] {
  transition-delay: 0.32s;
}
@media (prefers-reduced-motion: reduce) {
  .es-reveal {
    opacity: 1 !important;
    transform: none !important;
  }
  .es-hero__blob,
  .es-hero__panel,
  .es-marquee__track,
  .es-cert-badge2,
  .es-hp-bar {
    animation: none !important;
  }
}

/* ============================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1100px) {
  .es-bento {
    grid-template-columns: repeat(2, 1fr);
  }
  .es-bento__card--feature {
    grid-column: span 2;
    grid-row: span 1;
    min-height: 240px;
  }
  .es-feats {
    grid-template-columns: repeat(2, 1fr);
  }
  .es-speakers {
    grid-template-columns: repeat(2, 1fr);
  }
  .es-testi-grid {
    grid-template-columns: 1fr 1fr;
  }
  .es-stats {
    grid-template-columns: repeat(2, 1fr);
  }
  .es-journey__line {
    display: none;
  }
  .es-journey__steps {
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
  }
}
@media (max-width: 900px) {
  .es-hero__grid {
    grid-template-columns: 1fr;
  }
  .es-hero__visual {
    min-height: 420px;
    order: -1;
  }
  .es-cert-grid {
    grid-template-columns: 1fr;
  }
  .es-faq-grid {
    grid-template-columns: 1fr;
  }
  .es-cert-visual {
    order: -1;
    min-height: 320px;
  }
}
@media (max-width: 680px) {
  .es-bento {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
  }
  .es-bento__card {
    min-height: 150px;
  }
  .es-bento__card--feature {
    grid-column: 1 / -1;
    flex-direction: column;
    align-items: flex-start;
    gap: 18px;
    min-height: auto;
    padding: 28px;
  }
  .es-bento__card--feature .es-bento__arrow {
    position: absolute;
    top: 24px;
    right: 24px;
    width: 42px;
    height: 42px;
  }
  .es-feats,
  .es-speakers,
  .es-testi-grid,
  .es-stats {
    grid-template-columns: 1fr;
  }
  .es-journey__steps {
    grid-template-columns: 1fr;
  }
  .es-ecard,
  .es-wcard {
    flex-basis: 84vw;
    max-width: 84vw;
  }
  .es-head-row {
    flex-direction: column;
    align-items: flex-start;
  }
  .es-hero__panel--card2,
  .es-hero__panel--card3 {
    display: none;
  }
}

/* ============================================================================
   CONFERENCE / PROGRAM PAGE — premium re-skin of existing .ed-* structure
   (overrides editorial.css; preserves all checkout markup & JS hooks)
   ========================================================================== */
.es-conf .ed-conf-meta {
  background: var(--es-surface);
  border-bottom: 1px solid var(--es-border);
  padding: 16px 0;
}
.es-conf .ed-bread {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--es-font-head);
  font-size: 13px;
  font-weight: 600;
  color: var(--es-text-2);
}
.es-conf .ed-bread a {
  color: var(--es-text-2);
  transition: color 0.2s;
}
.es-conf .ed-bread a:hover {
  color: var(--es-blue-700);
}
.es-conf .ed-bread span {
  color: var(--es-ink);
}
.es-conf .ed-bread svg {
  color: var(--es-text-3);
}

/* Hero */
.es-conf .ed-conf {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(
      60% 70% at 12% 0%,
      rgba(59, 130, 246, 0.1),
      transparent 60%
    ),
    radial-gradient(
      55% 65% at 95% 10%,
      rgba(6, 182, 212, 0.12),
      transparent 60%
    ),
    var(--es-bg);
  padding: clamp(40px, 6vw, 72px) 0 clamp(48px, 7vw, 88px) !important;
}
.es-conf .ed-conf__grid {
  display: grid;
  grid-template-columns: 1.4fr 0.85fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: start;
}
.es-conf .ed-conf__title {
  font-family: var(--es-font-head) !important;
  font-size: clamp(28px, 3.8vw, 46px) !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.02em;
  color: var(--es-ink) !important;
  margin: 18px 0 !important;
}

.es-conf .ed-tag {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--es-font-head);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 7px 14px;
  border-radius: var(--es-r-pill);
  background: var(--es-surface-2);
  color: var(--es-text-2);
  border: 1px solid var(--es-border);
}
.es-conf .ed-tag--live {
  background: rgba(16, 185, 129, 0.12);
  color: #047857;
  border-color: transparent;
}
.es-conf .ed-tag--cat {
  background: rgba(59, 130, 246, 0.1);
  color: var(--es-blue-700);
  border-color: transparent;
}

.es-conf .ed-conf__byline {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 22px 0;
  flex-wrap: wrap;
}
.es-conf .ed-conf__byline-img img {
  width: 54px;
  height: 54px;
  border-radius: 16px;
  object-fit: cover;
  box-shadow: var(--es-sh-sm);
}
.es-conf .ed-conf__byline-kicker {
  font-size: 12px;
  color: var(--es-text-2);
}
.es-conf .ed-conf__byline-name {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 17px;
  color: var(--es-ink);
  display: block;
}

/* Fact tiles */
.es-conf .ed-facts {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 28px 0;
}
.es-conf .ed-fact {
  background: var(--es-surface);
  border: 1px solid var(--es-border);
  border-radius: var(--es-r-md);
  padding: 16px;
  box-shadow: var(--es-sh-xs);
  transition:
    transform 0.3s var(--es-ease),
    box-shadow 0.3s;
}
.es-conf .ed-fact:hover {
  transform: translateY(-3px);
  box-shadow: var(--es-sh-md);
}
.es-conf .ed-fact__label {
  font-family: var(--es-font-head);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--es-text-3);
  display: block;
}
.es-conf .ed-fact__value {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 16px;
  color: var(--es-ink);
  margin-top: 6px;
  display: block;
}

/* Coupon + alt links */
.es-conf .ed-conf__reassure {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  align-items: stretch;
  margin-top: 8px;
}
.es-conf .ed-reassure__coupon {
  background: linear-gradient(
    135deg,
    rgba(30, 64, 175, 0.06),
    rgba(6, 182, 212, 0.08)
  );
  border: 1px dashed var(--es-blue-500);
  border-radius: var(--es-r-md);
  padding: 14px 18px;
  cursor: pointer;
  text-align: left;
  transition: box-shadow 0.3s;
}
.es-conf .ed-reassure__coupon:hover {
  box-shadow: var(--es-sh-md);
}
.es-conf .ed-reassure__coupon-kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--es-text-2);
}
.es-conf .ed-reassure__coupon-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 4px 0;
}
.es-conf .ed-reassure__coupon-code {
  font-family: var(--es-font-head);
  font-weight: 800;
  font-size: 18px;
  color: var(--es-blue-700);
  letter-spacing: 0.02em;
}
.es-conf .ed-reassure__coupon-pct {
  font-size: 12px;
  font-weight: 700;
  color: #047857;
  background: rgba(16, 185, 129, 0.14);
  padding: 3px 9px;
  border-radius: var(--es-r-pill);
}
.es-conf .ed-reassure__coupon-status {
  font-size: 11px;
  color: var(--es-text-3);
}
.es-conf .ed-reassure__links {
  display: flex;
  flex-direction: column;
  gap: 6px;
  justify-content: center;
}
.es-conf .ed-reassure__links-kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--es-text-3);
}
.es-conf .ed-reassure__links a {
  font-size: 13px;
  font-weight: 600;
  color: var(--es-text-2);
  transition: color 0.2s;
}
.es-conf .ed-reassure__links a:hover {
  color: var(--es-blue-700);
}

/* Buy box — glass pricing card */
.es-conf .ed-buy {
  position: sticky;
  top: 96px;
  background: var(--es-glass);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--es-glass-brd);
  border-radius: var(--es-r-lg);
  box-shadow: var(--es-sh-lg);
  overflow: hidden;
}
.es-conf .ed-buy__head {
  background: var(--es-grad);
  padding: 20px 24px;
}
.es-conf .ed-buy__price-sub {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 15px;
  color: #fff;
}
.es-conf .ed-buy__body {
  padding: 20px 22px 4px;
  max-height: 360px;
  overflow-y: auto;
}
.es-conf .ed-buy__group {
  margin-bottom: 18px;
}
.es-conf .ed-buy__group-title {
  font-family: var(--es-font-head);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--es-text-3);
  margin-bottom: 10px;
}
.es-conf .ed-buy__opt {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 14px;
  margin-bottom: 8px;
  border: 1.5px solid var(--es-border);
  border-radius: var(--es-r-md);
  cursor: pointer;
  background: var(--es-surface);
  transition:
    border-color 0.25s,
    box-shadow 0.25s,
    background 0.25s;
  position: relative;
}
.es-conf .ed-buy__opt:hover {
  border-color: var(--es-blue-500);
}
.es-conf .ed-buy__opt input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.es-conf .ed-buy__opt-check {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  border: 2px solid var(--es-border-2);
  flex-shrink: 0;
  display: grid;
  place-items: center;
  transition: all 0.2s;
}
.es-conf .ed-buy__opt-check::after {
  content: "";
  width: 11px;
  height: 6px;
  border-left: 2.5px solid #fff;
  border-bottom: 2.5px solid #fff;
  transform: rotate(-45deg) scale(0);
  transition: transform 0.2s var(--es-ease);
  margin-top: -2px;
}
.es-conf .ed-buy__opt input:checked ~ .ed-buy__opt-check {
  background: var(--es-grad-soft);
  border-color: transparent;
}
.es-conf .ed-buy__opt input:checked ~ .ed-buy__opt-check::after {
  transform: rotate(-45deg) scale(1);
}
.es-conf .ed-buy__opt:has(input:checked) {
  border-color: var(--es-blue-500);
  background: linear-gradient(
    135deg,
    rgba(59, 130, 246, 0.05),
    rgba(6, 182, 212, 0.05)
  );
  box-shadow: var(--es-sh-sm);
}
.es-conf .ed-buy__opt-name {
  flex: 1;
  font-family: var(--es-font-head);
  font-weight: 600;
  font-size: 14px;
  color: var(--es-ink);
}
.es-conf .ed-buy__opt-price {
  font-family: var(--es-font-head);
  font-weight: 800;
  font-size: 15px;
  color: var(--es-blue-700);
}
.es-conf .ed-buy__total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 24px;
  margin-top: 8px;
  border-top: 1px solid var(--es-border);
  background: var(--es-surface);
}
.es-conf .ed-buy__total-label {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 14px;
  color: var(--es-text-2);
}
.es-conf .ed-buy__total-value {
  font-family: var(--es-font-head);
  font-weight: 800;
  font-size: 28px;
  color: var(--es-ink);
}
.es-conf .ed-buy__cta-wrap {
  padding: 0 24px 24px;
  background: var(--es-surface);
}
.es-conf .ed-buy__cta {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 16px;
  color: #fff;
  background: var(--es-grad-soft);
  border: none;
  border-radius: var(--es-r-pill);
  padding: 17px;
  cursor: pointer;
  box-shadow: var(--es-sh-blue);
  transition:
    transform 0.3s var(--es-ease),
    box-shadow 0.3s;
}
.es-conf .ed-buy__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 30px 70px -20px rgba(30, 64, 175, 0.7);
}

/* Article body */
.es-conf .ed-article {
  padding: clamp(48px, 6vw, 80px) 0;
}
.es-conf .ed-article__grid {
  display: grid;
  grid-template-columns: 1.6fr 0.9fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: start;
}
.es-conf .ed-block {
  margin-bottom: 40px;
}
.es-conf .ed-block__title {
  font-family: var(--es-font-head) !important;
  font-weight: 800 !important;
  font-size: clamp(22px, 2.6vw, 30px) !important;
  color: var(--es-ink) !important;
  position: relative;
  padding-bottom: 14px;
  margin-bottom: 22px !important;
}
.es-conf .ed-block__title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 48px;
  height: 3px;
  border-radius: 2px;
  background: var(--es-grad-soft);
}
.es-conf .ed-block__body {
  font-size: 16px;
  line-height: 1.75;
  color: var(--es-text);
}
.es-conf .ed-subhead {
  font-family: var(--es-font-head) !important;
  font-weight: 700;
  font-size: 19px;
  color: var(--es-ink);
  margin: 26px 0 10px;
}

/* Speaker bio card */
.es-conf .ed-bio {
  display: flex;
  gap: 22px;
  background: var(--es-surface);
  border: 1px solid var(--es-border);
  border-radius: var(--es-r-lg);
  padding: 26px;
  box-shadow: var(--es-sh-sm);
}
.es-conf .ed-bio__photo img {
  width: 110px;
  height: 110px;
  border-radius: var(--es-r-md);
  object-fit: cover;
  box-shadow: var(--es-sh-md);
}
.es-conf .ed-bio__name {
  font-family: var(--es-font-head) !important;
  font-weight: 800;
  font-size: 20px;
  color: var(--es-ink);
  margin: 0 0 4px;
}
.es-conf .ed-bio__role {
  font-size: 13px;
  color: var(--es-blue-700);
  font-weight: 600;
}
.es-conf .ed-bio__text {
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--es-text-2);
  margin-top: 12px;
}
.es-conf .ed-bio__link {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 14px;
  color: var(--es-blue-700);
}

/* Right rail */
.es-conf .ed-rail-block {
  background: var(--es-surface);
  border: 1px solid var(--es-border);
  border-radius: var(--es-r-lg);
  box-shadow: var(--es-sh-sm);
  overflow: hidden;
  margin-bottom: 20px;
}
.es-conf .ed-rail-block__head {
  font-family: var(--es-font-head);
  font-weight: 800;
  font-size: 14px;
  color: var(--es-ink);
  padding: 18px 20px;
  border-bottom: 1px solid var(--es-border);
}
.es-conf .ed-related-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--es-border);
  transition: background 0.2s;
}
.es-conf .ed-related-item:last-child {
  border-bottom: none;
}
.es-conf .ed-related-item:hover {
  background: var(--es-surface-2);
}
.es-conf .ed-related-item img {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  object-fit: cover;
  flex-shrink: 0;
}
.es-conf .ed-related-item__title {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 13.5px;
  color: var(--es-ink);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.es-conf .ed-related-item__speaker {
  font-size: 12px;
  color: var(--es-text-2);
  display: block;
}
.es-conf .ed-related-item__meta {
  font-size: 11px;
  color: var(--es-text-3);
}
.es-conf .ed-related-item__arrow {
  color: var(--es-text-3);
  flex-shrink: 0;
}
.es-conf .ed-share__btns {
  display: flex;
  gap: 10px;
  padding: 0 20px 8px;
}
.es-conf .ed-share__label {
  display: block;
  font-size: 13px;
  color: var(--es-text-2);
  padding: 14px 20px 8px;
}
.es-conf .ed-share__btns a,
.es-conf .ed-share__btns button {
  width: 40px;
  height: 40px;
  border-radius: 11px;
  border: 1px solid var(--es-border);
  background: var(--es-surface);
  color: var(--es-text-2);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: all 0.25s;
}
.es-conf .ed-share__btns a:hover,
.es-conf .ed-share__btns button:hover {
  background: var(--es-grad-soft);
  color: #fff;
  border-color: transparent;
  transform: translateY(-2px);
}

/* Sticky bottom bar */
.es-conf .ed-stickybar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 60;
  transform: translateY(120%);
  transition: transform 0.4s var(--es-ease);
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: saturate(180%) blur(18px);
  border-top: 1px solid var(--es-border);
  box-shadow: 0 -10px 40px -16px rgba(15, 23, 42, 0.25);
  padding: 14px 0;
}
.es-conf .ed-stickybar.is-visible {
  transform: translateY(0);
}
.es-conf .ed-stickybar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.es-conf .ed-stickybar__name {
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 15px;
  color: var(--es-ink);
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.es-conf .ed-stickybar__meta {
  font-size: 13px;
  color: var(--es-text-2);
}
.es-conf .ed-stickybar__meta strong {
  color: var(--es-blue-700);
}
.es-conf .ed-stickybar__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  font-family: var(--es-font-head);
  font-weight: 700;
  font-size: 15px;
  color: #fff;
  background: var(--es-grad-soft);
  border: none;
  border-radius: var(--es-r-pill);
  padding: 14px 26px;
  cursor: pointer;
  box-shadow: var(--es-sh-blue);
  transition: transform 0.3s var(--es-ease);
}
.es-conf .ed-stickybar__btn:hover {
  transform: translateY(-2px);
}

@media (max-width: 900px) {
  .es-conf .ed-conf__grid,
  .es-conf .ed-article__grid {
    grid-template-columns: 1fr;
  }
  .es-conf .ed-buy {
    position: static;
  }
  .es-conf .ed-facts {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 560px) {
  .es-conf .ed-bio {
    flex-direction: column;
  }
  .es-conf .ed-stickybar__meta {
    display: none;
  }
}

/* ============================================================================
   PREMIUM LISTING PAGES (live-webinars / recorded-webinar / search)
   Re-skins the editorial .ed-listing / .ed-toolbar markup when body.es-home.
   ========================================================================== */
.es-home .ed-listing, .es-home .ed-page { padding: clamp(48px,6vw,80px) 0 clamp(24px,3vw,36px); background: var(--es-bg); }
.es-home .ed-listing__bread, .es-home .ed-page__bread {
  display: flex; align-items: center; gap: 9px; margin-bottom: 22px;
  font-family: var(--es-font-head); font-size: 13px; font-weight: 600; color: var(--es-text-2);
}
.es-home .ed-listing__bread a, .es-home .ed-page__bread a { color: var(--es-text-2); }
.es-home .ed-listing__bread a:hover, .es-home .ed-page__bread a:hover { color: var(--es-blue-700); }
.es-home .ed-listing__bread span, .es-home .ed-page__bread span { color: var(--es-ink); }
.es-home .ed-listing__grid { display: grid; grid-template-columns: 1.6fr auto; gap: 32px; align-items: end; }
.es-home .ed-page__kicker, .es-home .ed-listing__kicker {
  display: inline-flex; align-items: center; gap: 8px; font-family: var(--es-font-head);
  font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--es-blue-700);
}
.es-home .ed-listing__h1, .es-home .ed-page__title {
  font-family: var(--es-font-head) !important; font-weight: 800 !important;
  font-size: clamp(32px,4.4vw,52px) !important; line-height: 1.08 !important; letter-spacing: -.02em;
  color: var(--es-ink) !important; margin: 12px 0 0 !important;
}
.es-home .ed-listing__h1-accent, .es-home .ed-page__title em {
  font-style: normal !important; color: transparent !important;
  background: var(--es-grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.es-home .ed-listing__lede { margin-top: 16px; font-size: clamp(16px,1.4vw,18px); line-height: 1.6; color: var(--es-text-2); max-width: 620px; }
.es-home .ed-listing__meta { text-align: right; }
.es-home .ed-listing__count {
  font-family: var(--es-font-head) !important; font-weight: 800; font-size: clamp(36px,4vw,52px); color: var(--es-ink); line-height: 1; display: block;
}
.es-home .ed-listing__count small { display: block; font-size: 12px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--es-text-3); margin-top: 6px; }
.es-home .ed-listing__pulse {
  display: inline-flex; align-items: center; gap: 7px; margin-top: 14px; font-size: 12px; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase; color: #047857; background: rgba(16,185,129,.12); padding: 6px 13px; border-radius: var(--es-r-pill);
}
.es-home .ed-listing__pulse::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--es-green); animation: es-pulse 1.8s infinite; }

/* toolbar */
.es-home .ed-toolbar { background: var(--es-surface); border-block: 1px solid var(--es-border); position: sticky; top: 73px; z-index: 30; backdrop-filter: blur(10px); }
.es-home .ed-toolbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 16px 0; flex-wrap: wrap; }
.es-home .ed-toolbar__filters { display: flex; gap: 8px; flex-wrap: wrap; }
.es-home .ed-chip {
  display: inline-flex; align-items: center; gap: 7px; font-family: var(--es-font-head); font-size: 13px; font-weight: 600;
  color: var(--es-text-2); background: var(--es-surface-2); border: 1px solid var(--es-border); border-radius: var(--es-r-pill);
  padding: 8px 15px; cursor: pointer; transition: all .25s var(--es-ease); text-decoration: none;
}
.es-home .ed-chip:hover { border-color: var(--es-blue-500); color: var(--es-blue-700); }
.es-home .ed-chip.is-active { background: var(--es-grad-soft); border-color: transparent; color: #fff; box-shadow: var(--es-sh-blue); }
.es-home .ed-chip__count { font-size: 11px; opacity: .8; font-weight: 700; }
.es-home .ed-chip.is-active .ed-chip__count { color: #fff; }
.es-home .ed-toolbar__right { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.es-home .ed-toolbar__search { display: flex; align-items: center; gap: 9px; background: var(--es-surface-2); border: 1px solid var(--es-border); border-radius: var(--es-r-pill); padding: 9px 16px; color: var(--es-text-2); transition: border-color .25s, box-shadow .25s; }
.es-home .ed-toolbar__search:focus-within { border-color: var(--es-blue-500); box-shadow: 0 0 0 4px rgba(59,130,246,.12); background: #fff; }
.es-home .ed-toolbar__search input { background: transparent; border: none; outline: none; font-family: var(--es-font-body); font-size: 14px; color: var(--es-ink); min-width: 160px; }
.es-home .ed-toolbar__sort { font-family: var(--es-font-head); font-size: 13px; font-weight: 600; color: var(--es-ink); background: var(--es-surface-2); border: 1px solid var(--es-border); border-radius: var(--es-r-pill); padding: 9px 16px; cursor: pointer; }

/* card grid */
.es-home .ed-listing-body, .es-home .ed-page-body { padding: clamp(36px,5vw,56px) 0 clamp(56px,7vw,88px); background: var(--es-bg); }
.es-home .ed-listing-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 22px;
}
.es-home .ed-listing-grid .itemb { min-width: 0; }
.es-home .ed-listing-grid .es-ecard, .es-home .ed-listing-grid .es-wcard {
  flex: initial !important; max-width: none !important; width: 100%; height: 100%;
}
.es-home .ed-search-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 22px; }
.es-home .ed-search-grid .es-ecard { flex: initial !important; max-width: none !important; width: 100%; }

/* empty state */
.es-home .ed-listing-empty {
  text-align: center; max-width: 540px; margin: 40px auto; padding: 56px 32px;
  background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-xl); box-shadow: var(--es-sh-sm);
}
.es-home .ed-listing-empty svg { color: var(--es-text-3); margin-bottom: 18px; }
.es-home .ed-listing-empty h3 { font-family: var(--es-font-head) !important; font-weight: 800; font-size: 24px; color: var(--es-ink); margin-bottom: 10px; }
.es-home .ed-listing-empty p { color: var(--es-text-2); line-height: 1.6; margin-bottom: 24px; }
.es-home .ed-listing-empty .ed-btn, .es-home .ed-listing-empty .ed-chip { text-decoration: none; }
.es-home .ed-listing-empty .ed-btn--primary {
  display: inline-flex; align-items: center; gap: 9px; background: var(--es-grad-soft) !important; color: #fff !important;
  font-family: var(--es-font-head); font-weight: 700; padding: 14px 26px; border-radius: var(--es-r-pill); box-shadow: var(--es-sh-blue); border: none;
}

/* pagination */
.es-home .ed-pagination { display: flex; justify-content: center; margin-top: 44px; }
.es-home .ed-pagination .pagination { display: inline-flex; gap: 6px; list-style: none; padding: 0; }
.es-home .ed-pagination .pagination li a, .es-home .ed-pagination .pagination li span {
  display: grid; place-items: center; min-width: 40px; height: 40px; padding: 0 12px; border-radius: var(--es-r-md);
  font-family: var(--es-font-head); font-weight: 700; font-size: 14px; color: var(--es-ink);
  background: var(--es-surface); border: 1px solid var(--es-border); text-decoration: none; transition: all .2s;
}
.es-home .ed-pagination .pagination li a:hover { border-color: var(--es-blue-500); color: var(--es-blue-700); }
.es-home .ed-pagination .pagination li.active span, .es-home .ed-pagination .pagination li.current span {
  background: var(--es-grad-soft); color: #fff; border-color: transparent; box-shadow: var(--es-sh-blue);
}

@media (max-width: 760px) {
  .es-home .ed-listing__grid { grid-template-columns: 1fr; }
  .es-home .ed-listing__meta { text-align: left; }
  .es-home .ed-toolbar { position: static; }
}

/* ============================================================================
   FOOTER — force premium dark over editorial's !important rules
   ========================================================================== */
.ce-footer { background: var(--es-night) !important; color: #94A3B8 !important; border-top: none !important; }
.ce-footer__top { background: var(--es-night) !important; border-top: 1px solid rgba(255,255,255,.06) !important; }
.ce-footer__bottom { background: #010413 !important; border-top: 1px solid rgba(255,255,255,.06); }
.ce-footer__tagline { color: #94A3B8 !important; font-family: var(--es-font-body) !important; font-size: 14.5px !important; }
.ce-footer__heading { color: #fff !important; font-family: var(--es-font-head) !important; }
.ce-footer__links a { color: #94A3B8 !important; }
.ce-footer__links a:hover { color: #fff !important; }
.ce-footer__contact-row, .ce-footer__contact-row span { color: #94A3B8 !important; }
.ce-footer__contact-row a { color: #94A3B8 !important; }
.ce-footer__contact-row a:hover { color: #fff !important; }
.ce-footer__contact-row svg { color: var(--es-cyan) !important; }
.ce-footer__social a { background: rgba(255,255,255,.06) !important; color: #CBD5E1 !important; border: 1px solid rgba(255,255,255,.10) !important; }
.ce-footer__social a:hover { background: var(--es-grad-soft) !important; color: #fff !important; }
.ce-footer__payment-label { color: var(--es-text-3) !important; }
.ce-footer__payment-icons span { background: rgba(255,255,255,.08) !important; color: #CBD5E1 !important; border: 1px solid rgba(255,255,255,.1) !important; }
.ce-footer__bottom-inner, .ce-footer__bottom-inner span { color: #64748B !important; }
.ce-footer__bottom a { color: #94A3B8 !important; }
.ce-footer__bottom a:hover { color: #fff !important; }
.ce-footer__logo { filter: brightness(0) invert(1) !important; }

/* ============================================================================
   PREMIUM CONTENT PAGES (About / Contact / FAQ / Support + shared ed-* blocks)
   Scoped to .es-home; overrides editorial.css.
   ========================================================================== */
.es-home .ed-page__title--lg { font-size: clamp(36px,5vw,60px) !important; }
.es-home .ed-page__lede { margin-top: 18px; font-size: clamp(16px,1.4vw,19px); line-height: 1.65; color: var(--es-text-2) !important; max-width: 720px; font-family: var(--es-font-body) !important; }
.es-home .ed-page__lede a { color: var(--es-blue-700) !important; font-weight: 600; }

/* section head / kicker / titles */
.es-home .ed-kicker, .es-home .ed-section__index {
  display: inline-flex; align-items: center; gap: 8px; font-family: var(--es-font-head) !important;
  font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--es-blue-700) !important;
}
.es-home .ed-section__index strong { color: var(--es-cyan) !important; }
.es-home .ed-section__title {
  font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: clamp(26px,3.2vw,40px) !important;
  line-height: 1.12 !important; letter-spacing: -.02em; color: var(--es-ink) !important;
}
.es-home .ed-section__head { display: grid; grid-template-columns: auto 1fr auto; gap: 28px; align-items: start; }

/* stat tiles (about) */
.es-home .ed-tiles { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.es-home .ed-tile {
  background: var(--es-surface) !important; border: 1px solid var(--es-border) !important; border-radius: var(--es-r-lg) !important;
  padding: 32px 28px !important; box-shadow: var(--es-sh-sm); transition: transform .4s var(--es-ease), box-shadow .4s;
}
.es-home .ed-tile:hover { transform: translateY(-5px); box-shadow: var(--es-sh-lg); }
.es-home .ed-tile__num { font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: clamp(34px,4vw,46px) !important;
  background: var(--es-grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent !important; line-height: 1; }
.es-home .ed-tile__title { font-family: var(--es-font-head) !important; font-weight: 700 !important; font-size: 18px !important; color: var(--es-ink) !important; margin: 14px 0 8px !important; }
.es-home .ed-tile__desc { font-family: var(--es-font-body) !important; font-size: 14px !important; line-height: 1.6 !important; color: var(--es-text-2) !important; }

/* two-col grids */
.es-home .ed-page-grid { display: grid; grid-template-columns: 1.5fr .85fr; gap: clamp(28px,4vw,56px); align-items: start; }
.es-home .ed-page-grid--wide { grid-template-columns: .8fr 1.4fr; }

/* prose */
.es-home .ed-prose { font-family: var(--es-font-body) !important; font-size: 16px !important; line-height: 1.8 !important; color: var(--es-text) !important; }
.es-home .ed-prose h2 { font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: 24px !important; color: var(--es-ink) !important; margin: 32px 0 14px !important; }
.es-home .ed-prose p { margin-bottom: 16px !important; color: var(--es-text-2) !important; }
.es-home .ed-prose ul { padding-left: 20px; margin-bottom: 18px; }
.es-home .ed-prose li { margin-bottom: 9px; color: var(--es-text-2); line-height: 1.65; }
.es-home .ed-prose a { color: var(--es-blue-700) !important; font-weight: 600; }
.es-home .ed-prose strong { color: var(--es-ink); }

/* steps / principles */
.es-home .ed-steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.es-home .ed-step {
  background: var(--es-surface) !important; border: 1px solid var(--es-border) !important; border-radius: var(--es-r-lg) !important;
  padding: 28px 26px !important; box-shadow: var(--es-sh-sm); position: relative; overflow: hidden; transition: transform .4s var(--es-ease), box-shadow .4s;
}
.es-home .ed-step::before { content:''; position:absolute; left:0; top:0; width:100%; height:3px; background: var(--es-grad-soft); transform: scaleX(0); transform-origin:left; transition: transform .4s var(--es-ease); }
.es-home .ed-step:hover { transform: translateY(-5px); box-shadow: var(--es-sh-lg); }
.es-home .ed-step:hover::before { transform: scaleX(1); }
.es-home .ed-step__num { font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: 14px !important; color: #fff !important;
  background: var(--es-grad-soft); width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; margin-bottom: 18px; box-shadow: var(--es-sh-blue); }
.es-home .ed-step__title { font-family: var(--es-font-head) !important; font-weight: 700 !important; font-size: 17px !important; color: var(--es-ink) !important; margin-bottom: 9px !important; }
.es-home .ed-step__desc { font-family: var(--es-font-body) !important; font-size: 14px !important; line-height: 1.6 !important; color: var(--es-text-2) !important; }

/* closing CTA */
.es-home .ed-cta { background: var(--es-grad-night) !important; border-radius: var(--es-r-xl); margin: clamp(40px,6vw,72px) 24px; padding: clamp(40px,6vw,72px) clamp(28px,5vw,64px) !important; position: relative; overflow: hidden; }
.es-home .ed-cta__rule { display: none; }
.es-home .ed-cta__grid { display: grid; grid-template-columns: 1.3fr auto; gap: 32px; align-items: center; position: relative; z-index: 1; }
.es-home .ed-cta__title { font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: clamp(28px,3.6vw,44px) !important; color: #fff !important; line-height: 1.1 !important; }
.es-home .ed-cta__title em { font-style: normal !important; background: var(--es-grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent !important; }
.es-home .ed-cta__lede { font-family: var(--es-font-body) !important; color: #94A3B8 !important; font-size: 16px !important; margin-top: 14px !important; line-height: 1.6; }
.es-home .ed-cta .ed-btn--ochre, .es-home .ed-cta .ed-btn--primary {
  background: var(--es-grad-soft) !important; color: #fff !important; border: none !important; border-radius: var(--es-r-pill) !important;
  font-family: var(--es-font-head) !important; font-weight: 700 !important; padding: 15px 28px !important; box-shadow: var(--es-sh-blue);
  display: inline-flex; align-items: center; gap: 9px;
}
.es-home .ed-cta .ed-btn:not(.ed-btn--ochre):not(.ed-btn--primary) {
  background: rgba(255,255,255,.1) !important; color: #fff !important; border: 1px solid rgba(255,255,255,.2) !important; border-radius: var(--es-r-pill) !important;
  font-family: var(--es-font-head) !important; font-weight: 700 !important; padding: 15px 28px !important; backdrop-filter: blur(8px);
}

/* generic premium button on content pages */
.es-home .ed-btn--primary {
  background: var(--es-grad-soft) !important; color: #fff !important; border: none !important; border-radius: var(--es-r-pill) !important;
  font-family: var(--es-font-head) !important; font-weight: 700 !important; padding: 14px 24px !important; box-shadow: var(--es-sh-blue);
  display: inline-flex; align-items: center; gap: 9px; transition: transform .25s var(--es-ease);
}
.es-home .ed-btn--primary:hover { transform: translateY(-2px); }

/* alert */
.es-home .ed-alert { display: flex; align-items: center; gap: 12px; padding: 16px 20px; border-radius: var(--es-r-md); margin-bottom: 28px; font-weight: 600; }
.es-home .ed-alert--success { background: rgba(16,185,129,.1) !important; color: #047857 !important; border: 1px solid rgba(16,185,129,.25); }

/* contact tiles */
.es-home .ed-contact-tiles { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-bottom: clamp(36px,5vw,56px); }
.es-home .ed-contact-tile {
  background: var(--es-surface) !important; border: 1px solid var(--es-border) !important; border-radius: var(--es-r-lg) !important;
  padding: 26px !important; box-shadow: var(--es-sh-sm); transition: transform .4s var(--es-ease), box-shadow .4s;
}
.es-home .ed-contact-tile:hover { transform: translateY(-4px); box-shadow: var(--es-sh-lg); }
.es-home .ed-contact-tile__icon { width: 48px; height: 48px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(135deg, rgba(30,64,175,.1), rgba(6,182,212,.12)) !important; color: var(--es-blue-700) !important; margin-bottom: 16px; }
.es-home .ed-contact-tile__label { display: block; font-family: var(--es-font-head) !important; font-size: 12px !important; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--es-text-3) !important; margin-bottom: 6px; }
.es-home .ed-contact-tile__value { font-family: var(--es-font-head) !important; font-weight: 700 !important; font-size: 17px !important; color: var(--es-ink) !important; }
.es-home a.ed-contact-tile__value:hover { color: var(--es-blue-700) !important; }

/* forms */
.es-home .ed-form-row { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.es-home .ed-form-row--inline { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.es-home .ed-form-row label { font-family: var(--es-font-head) !important; font-weight: 600 !important; font-size: 13px !important; color: var(--es-ink) !important; }
.es-home .ed-input, .es-home .ed-select, .es-home .ed-textarea {
  width: 100%; font-family: var(--es-font-body) !important; font-size: 15px !important; color: var(--es-ink) !important;
  background: var(--es-surface) !important; border: 1.5px solid var(--es-border-2) !important; border-radius: var(--es-r-md) !important;
  padding: 13px 16px !important; transition: border-color .25s, box-shadow .25s; outline: none;
}
.es-home .ed-input:focus, .es-home .ed-select:focus, .es-home .ed-textarea:focus { border-color: var(--es-blue-500) !important; box-shadow: 0 0 0 4px rgba(59,130,246,.12) !important; }
.es-home .ed-form__submit {
  display: inline-flex; align-items: center; gap: 9px; background: var(--es-grad-soft) !important; color: #fff !important;
  font-family: var(--es-font-head) !important; font-weight: 700 !important; font-size: 15px !important; border: none !important;
  border-radius: var(--es-r-pill) !important; padding: 15px 30px !important; cursor: pointer; box-shadow: var(--es-sh-blue); transition: transform .25s var(--es-ease);
}
.es-home .ed-form__submit:hover { transform: translateY(-2px); }

/* sidebar rail blocks (also used on conference, here for .es-home) */
.es-home .ed-rail-block { background: var(--es-surface) !important; border: 1px solid var(--es-border) !important; border-radius: var(--es-r-lg) !important; box-shadow: var(--es-sh-sm); overflow: hidden; margin-bottom: 20px; }
.es-home .ed-rail-block__head { font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: 14px !important; color: var(--es-ink) !important; padding: 18px 20px !important; border-bottom: 1px solid var(--es-border) !important; }
.es-home .ed-related-item { display: flex; align-items: center; gap: 12px; padding: 14px 20px !important; border-bottom: 1px solid var(--es-border) !important; transition: background .2s; text-decoration: none; }
.es-home .ed-related-item:last-child { border-bottom: none !important; }
.es-home .ed-related-item:hover { background: var(--es-surface-2) !important; }
.es-home .ed-related-item__title { font-family: var(--es-font-head) !important; font-weight: 700 !important; font-size: 14px !important; color: var(--es-ink) !important; display: block; }
.es-home .ed-related-item__meta { font-size: 12px !important; color: var(--es-text-3) !important; }
.es-home .ed-related-item__arrow { color: var(--es-text-3); margin-left: auto; flex-shrink: 0; }

/* editorial FAQ accordion (preserve max-height mechanism, restyle only) */
.es-home .ed-faq { display: flex; flex-direction: column; gap: 14px; }
.es-home .ed-faq__item { background: var(--es-surface) !important; border: 1px solid var(--es-border) !important; border-radius: var(--es-r-md) !important; overflow: hidden; transition: border-color .3s, box-shadow .3s; }
.es-home .ed-faq__item.is-open { border-color: var(--es-blue-500) !important; box-shadow: var(--es-sh-md); }
.es-home .ed-faq__q { font-family: var(--es-font-head) !important; font-weight: 700 !important; font-size: 16px !important; color: var(--es-ink) !important; padding: 20px 22px !important; display: flex; align-items: center; justify-content: space-between; gap: 16px; width: 100%; background: none; border: none; cursor: pointer; text-align: left; }
.es-home .ed-faq__q-icon { width: 30px; height: 30px; border-radius: 9px; flex-shrink: 0; display: grid; place-items: center; background: var(--es-surface-2) !important; color: var(--es-blue-700) !important; transition: transform .35s var(--es-ease), background .3s, color .3s; }
.es-home .ed-faq__item.is-open .ed-faq__q-icon { transform: rotate(135deg); background: var(--es-grad-soft) !important; color: #fff !important; }
.es-home .ed-faq__a { color: var(--es-text-2) !important; }
.es-home .ed-faq__a, .es-home .ed-faq__a p, .es-home .ed-faq__a li { font-family: var(--es-font-body) !important; font-size: 14.5px !important; line-height: 1.65 !important; }
.es-home .ed-faq__item.is-open .ed-faq__a { padding: 0 22px 20px !important; }

@media (max-width: 860px) {
  .es-home .ed-tiles, .es-home .ed-contact-tiles, .es-home .ed-steps { grid-template-columns: 1fr 1fr; }
  .es-home .ed-page-grid, .es-home .ed-page-grid--wide { grid-template-columns: 1fr; }
  .es-home .ed-cta__grid { grid-template-columns: 1fr; }
  .es-home .ed-section__head { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .es-home .ed-tiles, .es-home .ed-contact-tiles, .es-home .ed-steps, .es-home .ed-form-row--inline { grid-template-columns: 1fr; }
}

/* ============================================================================
   PREMIUM SPEAKER PAGES (speaker_list / speaker_detail)
   ========================================================================== */
/* category dropdown filter */
.es-home .ed-select-dropdown { position: relative; }
.es-home .ed-select-dropdown__trigger {
  display: inline-flex; align-items: center; gap: 10px; background: var(--es-surface-2); border: 1px solid var(--es-border);
  border-radius: var(--es-r-pill); padding: 9px 16px; font-family: var(--es-font-head); font-weight: 600; font-size: 13px; color: var(--es-ink); cursor: pointer;
}
.es-home .ed-select-dropdown__trigger:hover { border-color: var(--es-blue-500); }
.es-home .ed-select-dropdown__label { color: var(--es-text-3); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; }
.es-home .ed-select-dropdown__count { color: var(--es-text-3); font-weight: 700; }
.es-home .ed-select-dropdown__caret { transition: transform .3s; }
.es-home .ed-select-dropdown.is-open .ed-select-dropdown__caret { transform: rotate(180deg); }
.es-home .ed-select-dropdown__menu {
  position: absolute; top: calc(100% + 8px); left: 0; min-width: 230px; background: #fff; border: 1px solid var(--es-border);
  border-radius: var(--es-r-md); box-shadow: var(--es-sh-lg); padding: 8px; list-style: none; margin: 0; z-index: 40;
  opacity: 0; visibility: hidden; transform: translateY(-6px); transition: all .25s var(--es-ease);
}
.es-home .ed-select-dropdown.is-open .ed-select-dropdown__menu { opacity: 1; visibility: visible; transform: translateY(0); }
.es-home .ed-select-dropdown__menu li { list-style: none; }
.es-home .ed-select-dropdown__option {
  width: 100%; display: flex; justify-content: space-between; gap: 12px; padding: 10px 12px; border: none; background: none;
  border-radius: var(--es-r-sm); font-family: var(--es-font-head); font-weight: 600; font-size: 14px; color: var(--es-ink); cursor: pointer;
}
.es-home .ed-select-dropdown__option:hover { background: var(--es-surface-2); }
.es-home .ed-select-dropdown__option.is-active { background: var(--es-grad-soft); color: #fff; }
.es-home .ed-select-dropdown__option.is-active .ed-select-dropdown__count { color: rgba(255,255,255,.85); }

/* speaker grid + card (.spk) */
.es-home .ed-speakers-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(218px, 1fr)); gap: 22px; }
.es-home .spk-col { min-width: 0; }
.es-home .spk {
  display: block; position: relative; background: var(--es-surface); border: 1px solid var(--es-border);
  border-radius: var(--es-r-lg); overflow: hidden; box-shadow: var(--es-sh-sm); text-decoration: none;
  transition: transform .4s var(--es-ease), box-shadow .4s;
}
.es-home .spk:hover { transform: translateY(-6px); box-shadow: var(--es-sh-lg); }
.es-home .spk__visual { position: relative; aspect-ratio: 1/1; overflow: hidden; background: var(--es-surface-2); }
.es-home .spk__img-wrap { width: 100%; height: 100%; }
.es-home .spk__img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--es-ease); }
.es-home .spk:hover .spk__img { transform: scale(1.06); }
.es-home .spk__info { padding: 16px 18px 18px; }
.es-home .spk__name { font-family: var(--es-font-head) !important; font-weight: 700 !important; font-size: 16px !important; color: var(--es-ink) !important; margin: 0 0 3px !important; }
.es-home .spk__role-meta { font-family: var(--es-font-body) !important; font-size: 13px !important; color: var(--es-text-2) !important; }
.es-home .spk__arrow {
  position: absolute; top: 14px; right: 14px; width: 36px; height: 36px; border-radius: 11px;
  background: rgba(255,255,255,.92); backdrop-filter: blur(6px); display: grid; place-items: center; color: var(--es-blue-700);
  opacity: 0; transform: translateY(-4px); transition: all .3s var(--es-ease); box-shadow: var(--es-sh-sm);
}
.es-home .spk:hover .spk__arrow { opacity: 1; transform: translateY(0); }

/* speaker detail hero */
.es-home .ed-speaker__hero { padding: clamp(36px,5vw,68px) 0; background: radial-gradient(58% 70% at 8% 0%, rgba(59,130,246,.08), transparent 60%), radial-gradient(50% 60% at 100% 10%, rgba(6,182,212,.08), transparent 60%), var(--es-bg); }
.es-home .ed-speaker__back { display: inline-flex; align-items: center; gap: 8px; font-family: var(--es-font-head); font-weight: 600; font-size: 13px; color: var(--es-text-2); margin-bottom: 28px; }
.es-home .ed-speaker__back:hover { color: var(--es-blue-700); }
.es-home .ed-speaker__grid { display: grid; grid-template-columns: 330px 1fr; gap: clamp(28px,4vw,56px); align-items: start; }
.es-home .ed-speaker__photo { border-radius: var(--es-r-xl); overflow: hidden; box-shadow: var(--es-sh-xl); border: 1px solid var(--es-border); aspect-ratio: 4/5; background: var(--es-surface-2); position: sticky; top: 96px; }
.es-home .ed-speaker__photo img { width: 100%; height: 100%; object-fit: cover; }
.es-home .ed-speaker__kicker { display: inline-flex; align-items: center; gap: 8px; font-family: var(--es-font-head); font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--es-blue-700); }
.es-home .ed-speaker__kicker::before { content: ''; width: 22px; height: 2px; border-radius: 2px; background: var(--es-grad-soft); }
.es-home .ed-speaker__name { font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: clamp(30px,4vw,46px) !important; color: var(--es-ink) !important; letter-spacing: -.02em; margin: 14px 0 6px !important; }
.es-home .ed-speaker__role { font-family: var(--es-font-head) !important; font-weight: 600 !important; font-size: 17px !important; color: var(--es-blue-700) !important; }
.es-home .ed-speaker__creds { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 14px; margin: 28px 0; }
.es-home .ed-speaker__cred { background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-md); padding: 14px 16px; box-shadow: var(--es-sh-xs); }
.es-home .ed-speaker__cred-label { display: block; font-family: var(--es-font-head); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--es-text-3); font-weight: 700; margin-bottom: 5px; }
.es-home .ed-speaker__cred-value { font-family: var(--es-font-head); font-weight: 700; font-size: 15px; color: var(--es-ink); }
.es-home .ed-speaker__bio { font-family: var(--es-font-body) !important; font-size: 16px !important; line-height: 1.8 !important; color: var(--es-text-2) !important; margin-top: 10px; }
.es-home .ed-speaker__bio p { margin-bottom: 14px; }
.es-home .ed-speaker-programs { padding: clamp(40px,5vw,72px) 0; background: var(--es-surface); }
.es-home .ed-speaker-programs .ed-listing-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px,1fr)); gap: 22px; }
.es-home .ed-speaker-programs .ed-listing-grid .es-ecard { flex: initial !important; max-width: none !important; width: 100%; }

@media (max-width: 820px) {
  .es-home .ed-speaker__grid { grid-template-columns: 1fr; }
  .es-home .ed-speaker__photo { position: static; max-width: 280px; }
}

/* ============================================================================
   CONFERENCE PAGE — "best" redesign additions
   ========================================================================== */
/* hero trust strip */
.es-conf .ed-conf__trust { display: flex; flex-wrap: wrap; gap: 10px 24px; margin: 24px 0 4px; padding-top: 22px; border-top: 1px solid var(--es-border); }
.es-conf .ed-conf__trust-item { display: inline-flex; align-items: center; gap: 8px; font-family: var(--es-font-head); font-weight: 600; font-size: 13px; color: var(--es-text-2); }
.es-conf .ed-conf__trust-item svg { width: 18px; height: 18px; color: var(--es-green); flex-shrink: 0; }

/* buy box head price */
.es-conf .ed-buy__head-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.es-conf .ed-buy__head-from { font-family: var(--es-font-head); font-size: 12px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: rgba(255,255,255,.78); }
.es-conf .ed-buy__head-badge { font-family: var(--es-font-head); font-size: 10px; font-weight: 800; letter-spacing: .08em; color: #fff; background: rgba(255,255,255,.2); border: 1px solid rgba(255,255,255,.32); padding: 4px 11px; border-radius: var(--es-r-pill); }
.es-conf .ed-buy__head-price { font-family: var(--es-font-head); font-weight: 800; font-size: 36px; color: #fff; line-height: 1; display: block; letter-spacing: -.02em; }
.es-conf .ed-buy__price-sub { display: block; margin-top: 8px; font-size: 13px; color: rgba(255,255,255,.85); font-weight: 500; }

/* assure note under CTA */
.es-conf .ed-buy__assure { display: flex; justify-content: center; gap: 22px; margin-top: 16px; }
.es-conf .ed-buy__assure span { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--es-text-2); font-weight: 600; }
.es-conf .ed-buy__assure svg { width: 14px; height: 14px; color: var(--es-green); }

/* what's-included feature cards */
.es-conf .ed-cf-feats { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; margin-bottom: 48px; }
.es-conf .ed-cf-feat { display: flex; gap: 14px; align-items: flex-start; background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-md); padding: 18px; box-shadow: var(--es-sh-xs); transition: transform .3s var(--es-ease), box-shadow .3s; }
.es-conf .ed-cf-feat:hover { transform: translateY(-3px); box-shadow: var(--es-sh-md); }
.es-conf .ed-cf-feat__ico { width: 44px; height: 44px; border-radius: 13px; flex-shrink: 0; display: grid; place-items: center; background: linear-gradient(135deg, rgba(30,64,175,.1), rgba(6,182,212,.12)); color: var(--es-blue-700); }
.es-conf .ed-cf-feat__ico svg { width: 22px; height: 22px; }
.es-conf .ed-cf-feat b { display: block; font-family: var(--es-font-head); font-weight: 700; font-size: 14.5px; color: var(--es-ink); }
.es-conf .ed-cf-feat small { display: block; font-size: 12.5px; color: var(--es-text-2); margin-top: 2px; line-height: 1.45; }

@media (max-width: 560px) { .es-conf .ed-cf-feats { grid-template-columns: 1fr; } }

/* ============================================================================
   PREMIUM AUTH PAGES (login / register / forgotpassword)
   ========================================================================== */
.es-home .ed-auth { min-height: calc(100vh - 74px); display: grid; place-items: center; padding: clamp(32px,5vw,64px) 24px; background: radial-gradient(50% 50% at 80% 0%, rgba(6,182,212,.08), transparent 60%), var(--es-bg); }
.es-home .ed-auth__split {
  display: grid; grid-template-columns: 1fr 1fr; max-width: 1060px; width: 100%; margin: 0 auto;
  background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-xl); overflow: hidden; box-shadow: var(--es-sh-xl);
}
.es-home .ed-auth__form-side { padding: clamp(34px,4.5vw,56px); }
.es-home .ed-auth__kicker { display: inline-flex; align-items: center; gap: 8px; font-family: var(--es-font-head); font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--es-blue-700); }
.es-home .ed-auth__kicker::before { content: ''; width: 22px; height: 2px; border-radius: 2px; background: var(--es-grad-soft); }
.es-home .ed-auth__title { font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: clamp(28px,3.6vw,42px) !important; line-height: 1.1 !important; letter-spacing: -.02em; color: var(--es-ink) !important; margin: 14px 0 10px !important; }
.es-home .ed-auth__title em { font-style: normal !important; background: var(--es-grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent !important; }
.es-home .ed-auth__lede { font-family: var(--es-font-body) !important; font-size: 15px !important; line-height: 1.6 !important; color: var(--es-text-2) !important; margin-bottom: 28px !important; }
.es-home .ed-auth__alt { margin-top: 24px; font-family: var(--es-font-body); font-size: 14px; color: var(--es-text-2); }
.es-home .ed-auth__alt a { color: var(--es-blue-700); font-weight: 700; }

/* dark visual panel */
.es-home .ed-auth__visual { background: var(--es-grad-night); padding: clamp(34px,4.5vw,56px); color: #fff; display: flex; flex-direction: column; justify-content: space-between; position: relative; overflow: hidden; }
.es-home .ed-auth__visual::before { content: ''; position: absolute; width: 360px; height: 360px; border-radius: 50%; top: -120px; right: -100px; background: radial-gradient(circle, rgba(6,182,212,.35), transparent 60%); pointer-events: none; }
.es-home .ed-auth__visual > div { position: relative; z-index: 1; }
.es-home .ed-auth__visual-meta { font-family: var(--es-font-head); font-size: 12px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--es-cyan); margin-bottom: 18px; }
.es-home .ed-auth__visual-quote { font-family: var(--es-font-head) !important; font-weight: 700 !important; font-size: clamp(19px,2vw,25px) !important; font-style: normal !important; line-height: 1.4 !important; color: #fff !important; margin: 0 0 16px !important; }
.es-home .ed-auth__visual-cite { font-family: var(--es-font-body); font-size: 14px; color: #94A3B8; }
.es-home .ed-auth__visual-cite a { color: var(--es-cyan); }
.es-home .ed-auth__visual-stats { display: flex; gap: 32px; margin-top: 32px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.12); }
.es-home .ed-auth__visual-stat strong { display: block; font-family: var(--es-font-head); font-weight: 800; font-size: clamp(22px,2.6vw,30px); line-height: 1; background: linear-gradient(120deg,#fff,#67E8F9); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.es-home .ed-auth__visual-stat span { font-family: var(--es-font-body); font-size: 13px; color: #94A3B8; }

/* password field + toggle */
.es-home .ed-pass-field { position: relative; }
.es-home .ed-pass-field .ed-input { padding-right: 48px !important; }
.es-home .ed-pass-toggle { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); width: 34px; height: 34px; border: none; background: none; color: var(--es-text-3); cursor: pointer; display: grid; place-items: center; border-radius: 8px; transition: all .2s; }
.es-home .ed-pass-toggle:hover { color: var(--es-blue-700); background: var(--es-surface-2); }

/* form help + full submit */
.es-home .ed-form-help { font-size: 12.5px; color: var(--es-text-3); margin-top: 7px; }
.es-home .ed-form__submit--full { width: 100%; justify-content: center; }

/* checkbox */
.es-home .ed-checkbox { display: flex; align-items: flex-start; gap: 11px; cursor: pointer; margin: 4px 0 22px; }
.es-home .ed-checkbox input { position: absolute; opacity: 0; pointer-events: none; }
.es-home .ed-checkbox__box { width: 20px; height: 20px; border-radius: 6px; border: 2px solid var(--es-border-2); flex-shrink: 0; margin-top: 1px; display: grid; place-items: center; transition: all .2s; }
.es-home .ed-checkbox__box::after { content: ''; width: 10px; height: 5px; border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg) scale(0); transition: transform .2s var(--es-ease); margin-top: -2px; }
.es-home .ed-checkbox input:checked ~ .ed-checkbox__box { background: var(--es-grad-soft); border-color: transparent; }
.es-home .ed-checkbox input:checked ~ .ed-checkbox__box::after { transform: rotate(-45deg) scale(1); }
.es-home .ed-checkbox__label { font-size: 13.5px; color: var(--es-text-2); line-height: 1.5; }
.es-home .ed-checkbox__label a { color: var(--es-blue-700); font-weight: 600; }

/* alert variants */
.es-home .ed-alert--info { background: rgba(59,130,246,.1) !important; color: var(--es-blue-700) !important; border: 1px solid rgba(59,130,246,.25); }
.es-home .ed-alert--error { background: rgba(239,68,68,.08) !important; color: #b91c1c !important; border: 1px solid rgba(239,68,68,.22); }

@media (max-width: 820px) {
  .es-home .ed-auth__split { grid-template-columns: 1fr; max-width: 460px; }
  .es-home .ed-auth__visual { display: none; }
}

/* ============================================================================
   PREMIUM LEGAL TOC + GHOST BTN + ACCOUNT DASHBOARD
   ========================================================================== */
/* ghost / print button */
.es-home .ed-btn--ghost {
  display: inline-flex; align-items: center; gap: 8px; background: var(--es-surface) !important; color: var(--es-ink) !important;
  border: 1px solid var(--es-border-2) !important; border-radius: var(--es-r-pill) !important; font-family: var(--es-font-head) !important;
  font-weight: 600 !important; box-shadow: var(--es-sh-xs); transition: all .25s var(--es-ease);
}
.es-home .ed-btn--ghost:hover { border-color: var(--es-blue-500) !important; color: var(--es-blue-700) !important; transform: translateY(-2px); }

/* legal table of contents */
.es-home .ed-toc { position: sticky; top: 96px; background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-lg); padding: 22px; box-shadow: var(--es-sh-sm); }
.es-home .ed-toc__head { font-family: var(--es-font-head); font-weight: 800; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--es-text-3); margin-bottom: 16px; }
.es-home .ed-toc__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.es-home .ed-toc__list a { display: flex; gap: 10px; padding: 8px 10px; border-radius: var(--es-r-sm); font-family: var(--es-font-body); font-size: 13.5px; color: var(--es-text-2); text-decoration: none; transition: all .2s; }
.es-home .ed-toc__list a::before { content: attr(data-num); font-family: var(--es-font-head); font-weight: 700; font-size: 11px; color: var(--es-text-3); }
.es-home .ed-toc__list a:hover { background: var(--es-surface-2); color: var(--es-ink); }
.es-home .ed-toc__list a.is-active { background: linear-gradient(135deg, rgba(59,130,246,.08), rgba(6,182,212,.08)); color: var(--es-blue-700); font-weight: 600; }
.es-home .ed-toc__list a.is-active::before { color: var(--es-blue-700); }

/* ---- account dashboard ---- */
.es-home .tabs-wrapper { margin: clamp(40px,5vw,72px) auto !important; width: 100% !important; max-width: var(--es-max); padding: 0 24px; }
.es-home .tabs { min-width: 0 !important; gap: 10px; margin-bottom: 24px; }
.es-home .tabs label {
  width: auto !important; padding: 12px 28px !important; border-radius: var(--es-r-pill) !important; border: 1px solid var(--es-border) !important;
  background: var(--es-surface) !important; color: var(--es-text-2) !important; font-family: var(--es-font-head) !important; font-weight: 700 !important;
  font-size: 14px !important; box-shadow: none !important; transition: all .25s var(--es-ease);
}
.es-home .tabs label:hover { border-color: var(--es-blue-500) !important; color: var(--es-blue-700) !important; }
.es-home .tabs [type=radio]:checked + label {
  background: var(--es-grad-soft) !important; color: #fff !important; border-color: transparent !important; box-shadow: var(--es-sh-blue) !important;
}
.es-home .tabs .tab {
  padding: clamp(20px,3vw,36px) !important; background: var(--es-surface) !important; border: 1px solid var(--es-border) !important;
  border-radius: var(--es-r-lg) !important; box-shadow: var(--es-sh-sm) !important; width: 100% !important;
}
.es-home .tabs .tab h2 { font-family: var(--es-font-head) !important; font-weight: 800 !important; color: var(--es-ink) !important; margin-bottom: 22px !important; }
.es-home .tabs .table { width: 100% !important; border-collapse: separate; border-spacing: 0; }
.es-home .tabs .table th, .es-home .tabs .table td { padding: 14px 18px !important; border: 1px solid var(--es-border) !important; font-family: var(--es-font-body); font-size: 14px; color: var(--es-text); vertical-align: middle; }
.es-home .tabs .table th { background: var(--es-surface-2) !important; font-family: var(--es-font-head) !important; font-weight: 700; color: var(--es-ink) !important; }
.es-home .tabs .table .form-control { font-family: var(--es-font-body) !important; font-size: 14px !important; border: 1.5px solid var(--es-border-2) !important; border-radius: var(--es-r-md) !important; padding: 11px 14px !important; color: var(--es-ink) !important; }
.es-home .tabs .table .form-control:focus { border-color: var(--es-blue-500) !important; box-shadow: 0 0 0 4px rgba(59,130,246,.12) !important; outline: none; }
.es-home .btn-success {
  background: var(--es-grad-soft) !important; border: none !important; border-radius: var(--es-r-pill) !important; color: #fff !important;
  font-family: var(--es-font-head) !important; font-weight: 700 !important; padding: 11px 22px !important; box-shadow: var(--es-sh-blue); transition: transform .25s;
}
.es-home .btn-success:hover { transform: translateY(-2px); }
.es-home .alert-success { background: rgba(16,185,129,.1) !important; color: #047857 !important; border: 1px solid rgba(16,185,129,.25) !important; border-radius: var(--es-r-md) !important; font-family: var(--es-font-body); }
.es-home .fa-arrow-alt-circle-down, .es-home .fa-eye { color: var(--es-blue-700) !important; }

@media (max-width: 820px) {
  .es-home .ed-toc { position: static; }
  .es-home .tabs .table, .es-home .tabs .table tbody, .es-home .tabs .table tr, .es-home .tabs .table td, .es-home .tabs .table th { display: block; width: 100% !important; }
}

/* ============================================================================
   PREMIUM CHECKOUT & PAYMENT (pay / gateways / cart / order-form / success)
   Visual-only overrides — layout preserved from editorial; logic untouched.
   ========================================================================== */
/* --- pay.php (Stripe order summary) --- */
.es-home .pay-page { padding: clamp(40px,5vw,72px) 0; background: var(--es-bg); }
.es-home .pay-page__head { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin-bottom: 28px; flex-wrap: wrap; }
.es-home .pay-page__title { display: inline-flex; align-items: center; gap: 12px; font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: clamp(24px,3vw,34px) !important; color: var(--es-ink) !important; }
.es-home .pay-page__title svg { color: var(--es-blue-700); }
.es-home .pay-page__order { font-family: var(--es-font-head); font-weight: 700; font-size: 14px; color: var(--es-blue-700); background: rgba(59,130,246,.1); padding: 8px 16px; border-radius: var(--es-r-pill); }
.es-home .pay-alert { display: flex; align-items: center; gap: 10px; background: rgba(59,130,246,.08); color: var(--es-blue-700); border: 1px solid rgba(59,130,246,.2); border-radius: var(--es-r-md); padding: 14px 18px; margin-bottom: 24px; font-weight: 600; }
.es-home .pay-layout { display: grid; grid-template-columns: 1.5fr .9fr; gap: 24px; align-items: start; }
.es-home .pay-sidebar { position: sticky; top: 96px; }
.es-home .pay-summary { background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-lg); padding: 26px; box-shadow: var(--es-sh-md); }
.es-home .pay-summary__title { font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: 18px !important; color: var(--es-ink) !important; margin-bottom: 18px !important; }
.es-home .pay-summary__rows { display: flex; flex-direction: column; gap: 12px; }
.es-home .pay-summary__row { display: flex; justify-content: space-between; font-family: var(--es-font-body); font-size: 15px; color: var(--es-text-2); }
.es-home .pay-summary__row--discount { color: #047857; }
.es-home .pay-summary__row--total { border-top: 1px solid var(--es-border); padding-top: 14px; margin-top: 4px; font-family: var(--es-font-head) !important; font-weight: 800; font-size: 20px; color: var(--es-ink) !important; }
.es-home .pay-summary__row--total span { color: var(--es-ink); }
.es-home .pay-stripe { margin-top: 22px; }
.es-home .pay-secure { display: flex; align-items: center; gap: 8px; margin-top: 16px; font-size: 12.5px; color: var(--es-text-2); font-weight: 600; }
.es-home .pay-secure svg { color: var(--es-green); }
.es-home .ed-cart-trust__cards { display: flex; gap: 12px; margin-top: 14px; font-size: 26px; color: var(--es-text-3); }

/* --- shared cart section + rows (pay + cart) --- */
.es-home .ed-cart-section { background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-lg); padding: 8px 26px; box-shadow: var(--es-sh-sm); }
.es-home .ed-cart-section__head { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--es-border); }
.es-home .ed-cart-section__title { font-family: var(--es-font-head) !important; font-weight: 800 !important; font-size: 18px !important; color: var(--es-ink) !important; }
.es-home .ed-cart-section__count { font-size: 13px; font-weight: 700; color: var(--es-text-3); font-family: var(--es-font-head); }
.es-home .ed-cart-row { display: flex; justify-content: space-between; gap: 16px; padding: 20px 0; border-bottom: 1px solid var(--es-border); }
.es-home .ed-cart-row:last-child { border-bottom: none; }
.es-home .ed-cart-row__title { font-family: var(--es-font-head) !important; font-weight: 700 !important; font-size: 16px !important; color: var(--es-ink) !important; margin-bottom: 8px !important; }
.es-home .ed-cart-row__price { font-family: var(--es-font-head); font-weight: 800; font-size: 18px; color: var(--es-ink); }
.es-home .ed-cart-row__remove { color: var(--es-text-3); transition: color .2s; }
.es-home .ed-cart-row__remove:hover { color: #dc2626; }

/* --- cart summary / stepper / confirm --- */
.es-home .ed-cart-summary { background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-lg); box-shadow: var(--es-sh-md); overflow: hidden; }
.es-home .ed-cart-summary__head { font-family: var(--es-font-head) !important; font-weight: 800; font-size: 16px; color: var(--es-ink); padding: 20px 22px; border-bottom: 1px solid var(--es-border); }
.es-home .ed-cart-summary__body { padding: 22px; }
.es-home .ed-cart-summary__line { display: flex; justify-content: space-between; font-size: 14.5px; color: var(--es-text-2); margin-bottom: 12px; }
.es-home .ed-cart-summary__total { display: flex; justify-content: space-between; align-items: center; border-top: 1px solid var(--es-border); padding-top: 16px; margin-top: 6px; }
.es-home .ed-cart-summary__total-label { font-family: var(--es-font-head); font-weight: 700; color: var(--es-text-2); }
.es-home .ed-cart-summary__total-value { font-family: var(--es-font-head) !important; font-weight: 800; font-size: 24px; color: var(--es-ink); }
/* cta is a CONTAINER (button + keep link), not a button */
.es-home .ed-cart-summary__cta {
  display: flex !important; flex-direction: column; align-items: stretch; gap: 12px; width: 100%; margin-top: 18px;
  background: none !important; border: none !important; box-shadow: none !important; padding: 0 !important;
}
.es-home .ed-cart-summary__btn {
  display: inline-flex !important; align-items: center; justify-content: center; gap: 8px; width: 100%; margin: 0 !important;
  background: var(--es-grad-soft) !important; color: #fff !important; border: none !important; border-radius: var(--es-r-pill) !important;
  font-family: var(--es-font-head) !important; font-weight: 700 !important; font-size: 15px !important; padding: 15px 24px !important;
  box-shadow: var(--es-sh-blue) !important; cursor: pointer; transition: transform .25s var(--es-ease), box-shadow .25s;
}
.es-home .ed-cart-summary__btn:hover { transform: translateY(-2px); box-shadow: 0 28px 60px -20px rgba(30,64,175,.7) !important; }
.es-home .ed-cart-summary__keep {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px; width: 100%; margin: 0;
  background: none !important; box-shadow: none !important; padding: 10px !important; border-radius: var(--es-r-pill);
  font-family: var(--es-font-head); font-weight: 600; font-size: 13.5px; color: var(--es-text-2) !important; transition: color .2s, background .2s;
}
.es-home .ed-cart-summary__keep:hover { color: var(--es-blue-700) !important; background: var(--es-surface-2); }
.es-home .ed-back-link { display: inline-flex; align-items: center; gap: 8px; font-family: var(--es-font-head); font-weight: 600; font-size: 13px; color: var(--es-text-2); }
.es-home .ed-back-link:hover { color: var(--es-blue-700); }
.es-home .ed-stepper { display: flex; align-items: center; gap: 8px; margin: 8px 0 28px; }
.es-home .ed-stepper__item { display: inline-flex; align-items: center; gap: 8px; font-family: var(--es-font-head); font-weight: 600; font-size: 13px; color: var(--es-text-3); }
.es-home .ed-stepper__item.is-active, .es-home .ed-stepper__item[aria-current] { color: var(--es-blue-700); }
.es-home .ed-stepper__num { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; background: var(--es-surface-2); color: var(--es-text-2); font-size: 12px; font-weight: 800; border: 1px solid var(--es-border); }
.es-home .ed-stepper__item.is-active .ed-stepper__num, .es-home .ed-stepper__item[aria-current] .ed-stepper__num { background: var(--es-grad-soft); color: #fff; border-color: transparent; }
.es-home .ed-stepper__connector { flex: 1; height: 2px; background: var(--es-border); border-radius: 2px; min-width: 20px; }
.es-home .ed-confirm__panel { background: var(--es-surface); border-radius: var(--es-r-lg); box-shadow: var(--es-sh-xl); border: 1px solid var(--es-border); }
.es-home .ed-confirm__title { font-family: var(--es-font-head) !important; font-weight: 800; color: var(--es-ink); }
.es-home .ed-confirm__btn--primary { background: var(--es-grad-soft) !important; color: #fff !important; border: none !important; border-radius: var(--es-r-pill) !important; font-family: var(--es-font-head); font-weight: 700; }
.es-home .ed-confirm__btn--danger { background: #dc2626 !important; color: #fff !important; border: none !important; border-radius: var(--es-r-pill) !important; font-family: var(--es-font-head); font-weight: 700; }
.es-home .ed-confirm__btn--ghost { background: var(--es-surface) !important; color: var(--es-ink) !important; border: 1px solid var(--es-border-2) !important; border-radius: var(--es-r-pill) !important; font-family: var(--es-font-head); font-weight: 700; }

/* --- order-form --- */
.es-home .ed-orderform { background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-lg); box-shadow: var(--es-sh-md); overflow: hidden; }
.es-home .ed-orderform__masthead { background: var(--es-grad-night); color: #fff; padding: clamp(24px,3vw,36px); }
.es-home .ed-orderform__masthead-title { font-family: var(--es-font-head) !important; font-weight: 800; color: #fff !important; }
.es-home .ed-orderform__masthead-meta { color: #94A3B8; }
.es-home .ed-orderform__col-title { font-family: var(--es-font-head) !important; font-weight: 700; color: var(--es-ink); }
.es-home .ed-orderform__field-label { font-family: var(--es-font-head); font-weight: 600; font-size: 13px; color: var(--es-text-2); }
.es-home .ed-orderform__field-line { border-bottom: 1.5px solid var(--es-border-2); }
.es-home .ed-orderform__action { background: var(--es-grad-soft) !important; color: #fff !important; border: none !important; border-radius: var(--es-r-pill) !important; font-family: var(--es-font-head); font-weight: 700; box-shadow: var(--es-sh-blue); }
.es-home .ed-orderform__table th { font-family: var(--es-font-head); color: var(--es-ink); }

/* --- bootstrap payment gateways (pay_card / pay_server / pay_squareup / pay_worldpay) --- */
.es-home .heading-content, .es-home .heading-table { font-family: var(--es-font-head) !important; font-weight: 800 !important; color: var(--es-ink) !important; }
.es-home .card { background: var(--es-surface) !important; border: 1px solid var(--es-border) !important; border-radius: var(--es-r-lg) !important; box-shadow: var(--es-sh-sm) !important; }
.es-home .card-body { padding: clamp(18px,2.5vw,28px) !important; }
.es-home .card-footer { background: var(--es-surface-2) !important; border-top: 1px solid var(--es-border) !important; }
.es-home .table-bordered th, .es-home .table-bordered td { border: 1px solid var(--es-border) !important; padding: 13px 16px !important; font-family: var(--es-font-body); color: var(--es-text); vertical-align: middle; }
.es-home .table-bordered th, .es-home .cart_table th { background: var(--es-surface-2) !important; font-family: var(--es-font-head) !important; font-weight: 700; color: var(--es-ink) !important; }
.es-home .final_total { font-family: var(--es-font-head) !important; font-weight: 800 !important; color: var(--es-blue-700) !important; }
.es-home .form-control, .es-home .input-group .form-control {
  font-family: var(--es-font-body) !important; font-size: 15px !important; color: var(--es-ink) !important;
  border: 1.5px solid var(--es-border-2) !important; border-radius: var(--es-r-md) !important; padding: 12px 15px !important; box-shadow: none !important;
}
.es-home .form-control:focus { border-color: var(--es-blue-500) !important; box-shadow: 0 0 0 4px rgba(59,130,246,.12) !important; }
.es-home .form-group label, .es-home .form-check label { font-family: var(--es-font-head) !important; font-weight: 600 !important; font-size: 13px !important; color: var(--es-ink) !important; }
.es-home .btn-primary, .es-home .formbtns .btn, .es-home .formbtns button {
  background: var(--es-grad-soft) !important; border: none !important; border-radius: var(--es-r-pill) !important; color: #fff !important;
  font-family: var(--es-font-head) !important; font-weight: 700 !important; padding: 13px 26px !important; box-shadow: var(--es-sh-blue); transition: transform .25s;
}
.es-home .btn-primary:hover, .es-home .formbtns button:hover { transform: translateY(-2px); }
.es-home .alert-warning { background: rgba(245,158,11,.1) !important; color: #b45309 !important; border: 1px solid rgba(245,158,11,.28) !important; border-radius: var(--es-r-md) !important; font-family: var(--es-font-body); }

@media (max-width: 860px) {
  .es-home .pay-layout { grid-template-columns: 1fr; }
  .es-home .pay-sidebar { position: static; }
}

/* --- cart refinements (stepper is-current, head bg, summary accent, qty) --- */
.es-home .ed-stepper__item.is-current { color: var(--es-blue-700); }
.es-home .ed-stepper__item.is-current .ed-stepper__num { background: var(--es-grad-soft); color: #fff; border-color: transparent; }
.es-home .ed-stepper__label { font-family: var(--es-font-head); font-weight: 600; font-size: 13px; }
.es-home .ed-cart-section__head { background: transparent !important; padding: 18px 0 !important; }
.es-home .ed-cart-summary { border: 1px solid var(--es-border) !important; }
.es-home .ed-cart-summary::before { display: none !important; }
.es-home .ed-checkout-step { width: 100%; }
.es-home .iquantity { border: 1.5px solid var(--es-border-2) !important; border-radius: var(--es-r-sm) !important; background: var(--es-surface) !important; color: var(--es-ink) !important; }

/* ============================================================================
   CONFERENCE PAGE — "best" layout refinements
   ========================================================================== */
/* hero "what's included" block */
.es-conf .ed-cf-block { margin-top: 30px; }
.es-conf .ed-cf-block__label { display: inline-flex; align-items: center; gap: 8px; font-family: var(--es-font-head); font-size: 12px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--es-text-3); margin-bottom: 14px; }
.es-conf .ed-cf-block__label::before { content: ''; width: 20px; height: 2px; border-radius: 2px; background: var(--es-grad-soft); }
.es-conf .ed-cf-block .ed-cf-feats { margin-bottom: 0; }

/* promo / reassure → unified premium card */
.es-conf .ed-conf__reassure {
  margin-top: 30px; padding: 0; gap: 0; align-items: stretch;
  background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-lg);
  box-shadow: var(--es-sh-sm); overflow: hidden;
}
.es-conf .ed-reassure__coupon {
  flex: 1 1 240px; border: none; border-right: 1px dashed var(--es-border-2); border-radius: 0;
  background: linear-gradient(135deg, rgba(30,64,175,.05), rgba(6,182,212,.07)); padding: 20px 24px;
}
.es-conf .ed-reassure__coupon:hover { box-shadow: none; background: linear-gradient(135deg, rgba(30,64,175,.09), rgba(6,182,212,.11)); }
.es-conf .ed-reassure__links { flex: 1 1 200px; padding: 20px 24px; gap: 4px; }
.es-conf .ed-reassure__links a { display: inline-flex; align-items: center; justify-content: space-between; padding: 6px 0; border-bottom: 1px solid var(--es-border); }
.es-conf .ed-reassure__links a:last-child { border-bottom: none; }
.es-conf .ed-reassure__links-kicker { margin-bottom: 4px; }

/* buy box — taller formats + custom scrollbar */
.es-conf .ed-buy__body { max-height: 430px; }
.es-conf .ed-buy__body::-webkit-scrollbar { width: 6px; }
.es-conf .ed-buy__body::-webkit-scrollbar-thumb { background: var(--es-border-2); border-radius: 3px; }
.es-conf .ed-buy__body::-webkit-scrollbar-track { background: transparent; }
.es-conf .ed-buy__body { scrollbar-width: thin; scrollbar-color: var(--es-border-2) transparent; }

@media (max-width: 560px) {
  .es-conf .ed-conf__reassure { flex-direction: column; }
  .es-conf .ed-reassure__coupon { border-right: none; border-bottom: 1px dashed var(--es-border-2); }
}

/* ============================================================================
   COMBINED CHECKOUT (cart + billing single page) — reference-inspired, elevated
   ========================================================================== */
.es-home .ed-co { display: grid; grid-template-columns: 1.55fr .9fr; gap: 28px; align-items: start; }
.es-home .ed-co__main { display: flex; flex-direction: column; gap: 18px; }

/* coupon */
.es-home .ed-co__coupon { display: flex; align-items: center; gap: 10px; background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-md); padding: 6px 6px 6px 16px; box-shadow: var(--es-sh-xs); }
.es-home .ed-co__coupon svg { width: 18px; height: 18px; color: var(--es-text-3); flex-shrink: 0; }
.es-home .ed-co__coupon-input { flex: 1; border: none; background: none; outline: none; font-family: var(--es-font-body); font-size: 14px; color: var(--es-ink); min-width: 0; }
.es-home .ed-co__coupon-btn { background: var(--es-ink); color: #fff; border: none; border-radius: var(--es-r-sm); font-family: var(--es-font-head); font-weight: 700; font-size: 13px; padding: 11px 22px; cursor: pointer; transition: background .2s; }
.es-home .ed-co__coupon-btn:hover { background: var(--es-blue-700); }

/* dark totals box */
.es-home .ed-co__totals { background: var(--es-grad-night); border-radius: var(--es-r-lg); padding: 22px 26px; color: #fff; box-shadow: var(--es-sh-md); }
.es-home .ed-co__total-line { display: flex; justify-content: space-between; align-items: center; font-family: var(--es-font-body); font-size: 15px; color: #cbd5e1; margin-bottom: 12px; }
.es-home .ed-co__total-line strong { color: #fff; font-weight: 700; }
.es-home .ed-co__total-line--discount, .es-home .ed-co__total-line--discount strong { color: #34d399; }
.es-home .ed-co__total-grand { display: flex; justify-content: space-between; align-items: center; border-top: 1px solid rgba(255,255,255,.14); padding-top: 16px; margin-top: 6px; }
.es-home .ed-co__total-grand span { font-family: var(--es-font-head); font-weight: 700; font-size: 16px; color: #fff; }
.es-home .ed-co__total-grand strong { font-family: var(--es-font-head); font-weight: 800; font-size: 26px; color: #fff; letter-spacing: -.01em; }

/* billing side */
.es-home .ed-co__side { position: sticky; top: 96px; }
.es-home .ed-co__billing { background: var(--es-surface); border: 1px solid var(--es-border); border-radius: var(--es-r-lg); box-shadow: var(--es-sh-lg); padding: 26px; }
.es-home .ed-co__billing-head { display: flex; align-items: center; gap: 10px; font-family: var(--es-font-head); font-weight: 800; font-size: 18px; color: var(--es-ink); margin-bottom: 22px; }
.es-home .ed-co__step-badge { font-family: var(--es-font-head); font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--es-blue-700); background: rgba(59,130,246,.1); padding: 5px 10px; border-radius: var(--es-r-pill); }
.es-home .ed-co__form .ed-form-row { margin-bottom: 13px; }
.es-home .ed-co__form .ed-input, .es-home .ed-co__form .ed-select { padding: 12px 14px !important; }
.es-home .ed-co__pay { width: 100%; display: inline-flex; align-items: center; justify-content: center; gap: 9px; margin-top: 10px; background: var(--es-grad-soft); color: #fff; border: none; border-radius: var(--es-r-pill); font-family: var(--es-font-head); font-weight: 700; font-size: 16px; padding: 16px; cursor: pointer; box-shadow: var(--es-sh-blue); transition: transform .25s var(--es-ease), box-shadow .25s; }
.es-home .ed-co__pay svg { width: 18px; height: 18px; }
.es-home .ed-co__pay:hover { transform: translateY(-2px); box-shadow: 0 28px 60px -20px rgba(30,64,175,.7); }
.es-home .ed-co__secure { display: flex; align-items: center; justify-content: center; gap: 7px; margin-top: 14px; font-size: 12px; color: var(--es-text-2); font-weight: 600; }
.es-home .ed-co__secure svg { width: 14px; height: 14px; color: var(--es-green); }

/* cart row tags + qty */
.es-home .ed-cart-row__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.es-home .ed-cart-row__tag { font-family: var(--es-font-head); font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--es-blue-700); background: rgba(59,130,246,.09); padding: 4px 9px; border-radius: var(--es-r-pill); }
.es-home .ed-cart-row__qtyline { display: flex; align-items: center; gap: 14px; font-size: 13px; color: var(--es-text-2); }
.es-home .ed-cart-row__qtyline label { display: flex; align-items: center; gap: 8px; font-family: var(--es-font-head); font-weight: 600; }
.es-home .ed-cart-row__qtyline .iquantity { width: 58px; padding: 7px 8px; border: 1.5px solid var(--es-border-2); border-radius: var(--es-r-sm); background: var(--es-surface); color: var(--es-ink); text-align: center; font-family: var(--es-font-body); font-size: 14px; }
.es-home .ed-cart-row__qtyline .iquantity:focus { border-color: var(--es-blue-500); outline: none; box-shadow: 0 0 0 3px rgba(59,130,246,.12); }

@media (max-width: 900px) {
  .es-home .ed-co { grid-template-columns: 1fr; }
  .es-home .ed-co__side { position: static; }
}
