/* ZERO Markets · WEwork design — clean dark + green
   Standalone stylesheet. No inheritance from styles.css or colors_and_type.css.
   Source of truth for the WEwork visual system.
   ---------------------------------------------------------------------- */

/* ---------- Web fonts (re-use the existing Plus Jakarta Sans files) ---------- */
@font-face { font-family: "Plus Jakarta Sans"; font-weight: 400; font-display: swap;
  src: url("fonts/PlusJakartaSans-Regular.ttf") format("truetype"); }
@font-face { font-family: "Plus Jakarta Sans"; font-weight: 500; font-display: swap;
  src: url("fonts/PlusJakartaSans-Medium.ttf") format("truetype"); }
@font-face { font-family: "Plus Jakarta Sans"; font-weight: 600; font-display: swap;
  src: url("fonts/PlusJakartaSans-SemiBold.ttf") format("truetype"); }
@font-face { font-family: "Plus Jakarta Sans"; font-weight: 700; font-display: swap;
  src: url("fonts/PlusJakartaSans-Bold.ttf") format("truetype"); }
@font-face { font-family: "Plus Jakarta Sans"; font-weight: 800; font-display: swap;
  src: url("fonts/PlusJakartaSans-ExtraBold.ttf") format("truetype"); }

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img, svg { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; padding: 0; margin: 0; }

/* ---------- Tokens (hardcoded, no dependency chain) ---------- */
:root {
  --bg:           #0B1110;    /* Page background */
  --bg-2:         #131A1F;    /* Card / panel */
  --bg-3:         #1A2127;    /* Raised surface */
  --bg-deep:      #070C0B;    /* Footer / extra deep */
  --bg-green:     #0E2E1E;    /* Hero accent panel */
  --line:         rgba(255,255,255,0.07);
  --line-2:       rgba(255,255,255,0.12);
  --green:        #00B955;    /* Primary brand green */
  --green-bright: #20DF80;    /* Hover / chart up — aligned to Figma bright green */
  --green-dim:    rgba(0,185,85,0.18);
  --green-glow:   rgba(0,185,85,0.32);
  --text:         #F5F7F7;
  --text-mute:    #9CA3AA;
  --text-faint:   #6F7375;
  --error:        #FF5366;
  --radius:       16px;
  --radius-lg:    24px;
  --radius-pill:  999px;
  --shadow-card:  0 30px 60px -16px rgba(0,0,0,0.6);
  --shadow-glow:  0 30px 60px -20px rgba(0,185,85,0.25);
  --font:         "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  /* Legacy aliases — needed so existing inline JSX styles keep working on dark theme */
  --font-sans:    var(--font);
  --font-num:     var(--font);

  /* Neutral palette — n-90 is the DARKEST bg; n-30..n-50 are mutes; high numbers reversed
     because existing JSX used n-90 as DARK TEXT on light bg.
     On dark theme we flip the semantic: n-90 = lightest text. */
  --n-0:  var(--bg);
  --n-10: var(--bg-2);
  --n-20: var(--bg-3);
  --n-30: #6F7375;
  --n-40: #8E9394;
  --n-50: var(--text-mute);   /* secondary text */
  --n-60: #C9CFCF;
  --n-70: #2C393E;            /* line/border on dark */
  --n-80: #1A2127;            /* surface variant */
  --n-85: var(--bg-2);        /* card bg */
  --n-90: #F5F7F7;            /* primary text (flipped: was darkest, now lightest) */
  --n-100: #FFFFFF;

  /* Primary green palette */
  --p-10: #002111; --p-20: #003922; --p-30: #005530; --p-40: #00723E;
  --p-50: #009447; --p-60: var(--green);
  --p-70: var(--green-bright); --p-80: #62F0A8; --p-90: #99FFCC; --p-95: rgba(0,185,85,0.18);

  /* Accent (used heavily) */
  --accent:        var(--green);
  --accent-strong: var(--green-bright);

  /* Semantic color tokens */
  --color-primary:            var(--green);
  --color-on-primary:          #06170E;
  --color-primary-container:   var(--p-30);
  --color-on-primary-container: var(--p-90);

  --color-background:         var(--bg);
  --color-on-background:      var(--text);
  --color-surface:            var(--bg-2);
  --color-on-surface:         var(--text);
  --color-surface-variant:    var(--bg-3);
  --color-on-surface-variant: var(--text-mute);
  --color-surface-container:  var(--bg-2);
  --color-surface-container-low:    var(--bg-2);
  --color-surface-container-lowest: var(--bg-deep);
  --color-outline:           var(--line-2);
  --color-outline-variant:   var(--line);

  /* Error / warning containers */
  --e-10: #410008; --e-40: #BA1A2D; --e-60: var(--error); --e-90: #FFDAD9;
  --w-10: #2B1700; --w-40: #8C5800; --w-50: #D0972C; --w-60: #FFD875; --w-90: #FFE26F;

  /* State layers */
  --state-primary-04:  rgba(0,185,85,0.06);
  --state-primary-08:  rgba(0,185,85,0.12);
  --state-primary-16:  rgba(0,185,85,0.18);
  --state-primary-20:  rgba(0,185,85,0.24);

  --shadow-focus: 0 0 0 3px rgba(0,185,85,0.30);
}

/* ---------- Base ---------- */
body {
  background: var(--bg);
  color: var(--text);
  font: 400 16px/1.55 var(--font);
  -webkit-font-smoothing: antialiased;
}

/* ---------- Layout helpers ---------- */
.zm-container { max-width: 1280px; margin: 0 auto; padding: 0 32px; }
.zm-container--wide { max-width: 1380px; }
.zm-shell { max-width: 1320px; margin: 0 auto; padding: 0 32px; }

/* ---------- Eyebrow (green dot + uppercase) ---------- */
.zm-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font: 600 12px/1 var(--font);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--green);
}
.zm-eyebrow::before {
  content: ""; width: 8px; height: 8px; border-radius: 999px;
  background: var(--green);
}

/* ---------- Buttons ---------- */
.zm-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px; height: 48px; padding: 0 24px;
  border-radius: var(--radius-pill); border: 0;
  font: 700 14px/1 var(--font);
  transition: transform 160ms cubic-bezier(.2,0,0,1), background 200ms, border-color 200ms, color 200ms;
  white-space: nowrap;
}
.zm-btn--primary { background: var(--green); color: var(--color-on-primary); }
.zm-btn--primary:hover { background: var(--green-bright); transform: translateY(-1px); }
.zm-btn--light    { background: #fff; color: #0B1110; }
.zm-btn--light:hover { background: #F0F0F0; transform: translateY(-1px); }
.zm-btn--ghost    { background: transparent; color: #fff; border: 1px solid var(--line-2); }
.zm-btn--ghost:hover { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.32); }
.zm-btn--sm { height: 40px; padding: 0 18px; font-size: 13px; }
.zm-btn--lg { height: 56px; padding: 0 32px; font-size: 15px; }

/* ---------- Header ---------- */
.zm-header {
  position: sticky; top: 0; z-index: 50;
  background: transparent;
  border-bottom: 1px solid transparent;
  transition: background 200ms ease, border-color 200ms ease, backdrop-filter 200ms ease;
}
/* Solid + blur after the user scrolls past the hero top, or when a mega menu is open
   (so the dropdown panel meets a coherent header surface). */
.zm-header.is-scrolled,
.zm-header.is-mega-open {
  background: rgba(11,17,16,0.72);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
          backdrop-filter: blur(16px) saturate(1.4);
  border-bottom-color: var(--line);
}
.zm-header__inner {
  display: flex; align-items: center; gap: 40px;
  height: 72px; max-width: 1380px; margin: 0 auto; padding: 0 32px;
}
.zm-header__brand { display: inline-flex; align-items: center; gap: 10px; }
.zm-header__brand-text {
  font: 800 18px/1 var(--font); letter-spacing: 0.04em; color: #fff;
}
.zm-header__brand-text em {
  color: var(--green); font-style: normal; font-weight: 800;
  margin-right: 6px; letter-spacing: -0.02em;
}
.zm-header__nav { display: flex; gap: 8px; flex: 1; justify-content: center; }
.zm-header__nav a {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-radius: var(--radius-pill);
  font: 500 14px/1 var(--font); color: #C9CFCF;
  transition: color 160ms, background 160ms;
}
.zm-header__nav a:hover { color: #fff; background: rgba(255,255,255,0.04); }
.zm-header__nav .ph { font-size: 12px; opacity: 0.7; }
.zm-header__cta { display: inline-flex; align-items: center; gap: 10px; }

/* ---------- Hero ---------- */
.zm-hero {
  position: relative; padding: 0;
  overflow: hidden;           /* full-bleed ambassador photo — clip to viewport */
  isolation: isolate;
}
.zm-hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(1100px 600px at 90% -10%, rgba(0,185,85,0.18), transparent 65%),
    radial-gradient(700px 400px at 0% 100%, rgba(0,185,85,0.08), transparent 70%);
}
.zm-hero__grid {
  display: grid; grid-template-columns: 6fr 7fr; gap: 56px;
  max-width: 1380px; margin: 0 auto; padding: 0 32px;
  align-items: stretch;
}
.zm-hero__photo-wrap {
  position: relative; min-height: 580px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.zm-hero__photo {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center 20%;
}
.zm-hero__photo-shade {
  position: absolute; inset: 0;
  background:
    linear-gradient(120deg, rgba(11,17,16,0.65) 0%, rgba(11,17,16,0.10) 35%, rgba(11,17,16,0) 60%),
    linear-gradient(0deg, rgba(11,17,16,0.45) 0%, rgba(11,17,16,0) 40%);
}
.zm-hero__copy {
  position: absolute; left: 36px; top: 56px; right: 220px;
  z-index: 1;
}
.zm-hero__h1 {
  font: 800 64px/1.05 var(--font); letter-spacing: -0.028em;
  color: #fff; margin: 0;
  text-wrap: balance;
}
.zm-hero__sub {
  font: 400 16px/1.55 var(--font); color: #C9CFCF; margin: 0 0 28px;
  max-width: 44ch;
}
.zm-hero__cta { display: flex; gap: 10px; flex-wrap: wrap; }
.zm-hero__pager {
  position: absolute; bottom: 24px; left: 36px;
  display: flex; gap: 8px;
}
.zm-hero__pager span {
  width: 24px; height: 4px; border-radius: 4px; background: rgba(255,255,255,0.20);
}
.zm-hero__pager span.is-active { background: var(--green); width: 36px; }

/* Hero right column — bento of trust cards + center panel + phone */
.zm-hero__side {
  display: grid; grid-template-columns: 1fr 1fr 1.1fr;
  gap: 12px; align-items: stretch;
}
.zm-hero__trust {
  display: flex; flex-direction: column; gap: 12px;
}
.zm-hero__trust-card {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 22px;
  display: flex; flex-direction: column; gap: 10px;
  min-height: 116px;
}
.zm-hero__trust-card-icon {
  width: 32px; height: 32px; border-radius: 8px;
  background: var(--green-dim); color: var(--green);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 16px;
}
.zm-hero__trust-card-eyebrow {
  font: 700 11px/1 var(--font); letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--green);
}
.zm-hero__trust-card-text {
  font: 600 14px/1.4 var(--font); color: #fff;
}
.zm-hero__center {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 26px 22px;
  display: flex; flex-direction: column; gap: 14px; justify-content: space-between;
  min-height: 360px;
}
.zm-hero__center-leaf {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--green-dim); color: var(--green);
  display: inline-flex; align-items: center; justify-content: center;
}
.zm-hero__center-h {
  font: 700 22px/1.18 var(--font); color: #fff; margin: 0;
  letter-spacing: -0.012em;
}
.zm-hero__center-h em { color: var(--green); font-style: normal; }
.zm-hero__center-p {
  font: 400 13px/1.5 var(--font); color: var(--text-mute); margin: 0;
}
.zm-hero__phone-col {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 24px 20px 0;
  display: flex; flex-direction: column; gap: 14px;
  position: relative; overflow: hidden;
}
.zm-hero__stores { display: flex; flex-direction: column; gap: 8px; }
.zm-hero__store {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: 12px;
  background: #fff; color: #000;
  font: 600 12px/1.1 var(--font);
  width: fit-content;
}
.zm-hero__store small { display: block; font-weight: 500; font-size: 9px; opacity: 0.7; }
.zm-hero__store i { font-size: 22px; }
.zm-hero__unlock {
  font: 700 16px/1.2 var(--font); color: #fff;
  letter-spacing: -0.01em;
}
.zm-hero__phone-mock {
  margin-top: auto; margin-bottom: -40px; align-self: center;
  width: 140px; height: 220px;
  border: 8px solid #1A2127;
  border-radius: 28px;
  background: linear-gradient(180deg, var(--bg-2) 0%, var(--bg-3) 100%);
  position: relative; overflow: hidden;
}
.zm-hero__phone-mock::before {
  content: ""; position: absolute; top: 8px; left: 50%; transform: translateX(-50%);
  width: 36px; height: 4px; border-radius: 2px; background: rgba(255,255,255,0.18);
}

/* ---------- Section primitive ---------- */
.zm-section { padding: 96px 0; }
.zm-section--tight { padding: 64px 0; }
.zm-section__head {
  text-align: center; max-width: 720px; margin: 0 auto 56px;
  display: flex; flex-direction: column; align-items: center; gap: 16px;
}
.zm-section__head--left { text-align: left; margin-left: 0; align-items: flex-start; }
.zm-section__h {
  font: 700 44px/1.1 var(--font); letter-spacing: -0.022em;
  color: #fff; margin: 0;
  text-wrap: balance;
}
.zm-section__sub {
  font: 400 16px/1.55 var(--font); color: var(--text-mute);
  margin: 0; max-width: 600px;
}

/* ---------- Product tabs (Forex / Commodities / ...) ---------- */
.zm-prods__tabs {
  display: flex; justify-content: center; gap: 8px; flex-wrap: wrap;
  margin-bottom: 32px;
}
.zm-prods__tab {
  height: 44px; padding: 0 22px; border-radius: var(--radius-pill);
  border: 0; background: var(--bg-2); color: #C9CFCF;
  font: 600 13px/1 var(--font); transition: all 200ms;
}
.zm-prods__tab:hover { background: var(--bg-3); color: #fff; }
.zm-prods__tab.is-active { background: var(--green); color: var(--color-on-primary); }

.zm-prods__panel {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: grid; grid-template-columns: 38fr 62fr;   /* 40/60 like Figma */
  min-height: 420px;
}
.zm-prods__panel-copy { padding: 40px 36px; display: flex; flex-direction: column; gap: 20px; justify-content: space-between; }
.zm-prods__panel-icon {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,255,255,0.04); border: 1px solid var(--line);
  color: var(--green);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 18px;
}
.zm-prods__panel-h { font: 700 24px/1.2 var(--font); color: #fff; margin: 0; }
.zm-prods__panel-p { font: 400 14px/1.55 var(--font); color: var(--text-mute); margin: 0; max-width: 40ch; }
.zm-prods__panel-photo { position: relative; overflow: hidden; min-height: 420px; }
.zm-prods__panel-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; }

/* ---------- "Trade with confidence" + stats split ---------- */
.zm-confidence {
  display: grid; grid-template-columns: 1.05fr 1.2fr; gap: 64px;
  align-items: center;
  position: relative; isolation: isolate;
}
.zm-confidence::before {
  content: ""; position: absolute; inset: -40px -120px;
  background: radial-gradient(60% 50% at 75% 30%, rgba(0,185,85,0.18), transparent 65%);
  z-index: -1; pointer-events: none;
}
.zm-confidence__copy { display: flex; flex-direction: column; gap: 18px; }
.zm-confidence__h { font: 700 36px/1.15 var(--font); color: #fff; margin: 0; letter-spacing: -0.018em; }
.zm-confidence__p { font: 400 15px/1.55 var(--font); color: var(--text-mute); margin: 0; max-width: 48ch; }
.zm-confidence__list { display: flex; flex-direction: column; gap: 10px; margin-top: 8px; padding: 0; list-style: none; }
.zm-confidence__list li { display: flex; gap: 14px; align-items: center; font: 500 14px/1.4 var(--font); color: #fff; position: relative; padding-left: 0; }
.zm-confidence__list li::before {
  content: ""; width: 20px; height: 20px; border-radius: 50%;
  background: var(--green-dim); flex-shrink: 0;
}
.zm-confidence__list li::after {
  content: ""; position: absolute; left: 5px; top: 9px;
  width: 9px; height: 5px; border-left: 2px solid var(--green); border-bottom: 2px solid var(--green);
  transform: rotate(-45deg);
}

/* 2 cols × 3 rows; numbers WHITE; small green check icon top-right */
.zm-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.zm-stat {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 28px 28px 26px;
  display: grid; grid-template-columns: 1fr auto; grid-template-rows: auto 1fr;
  column-gap: 12px; row-gap: 14px;
  min-height: 132px;
  position: relative; overflow: hidden;
}
.zm-stat::before {
  content: ""; position: absolute; top: 0; right: 0;
  width: 200px; height: 200px;
  background: radial-gradient(60% 60% at 100% 0%, rgba(0,185,85,0.10), transparent 65%);
  pointer-events: none;
}
.zm-stat__num {
  grid-column: 1; grid-row: 1;
  font: 700 38px/1 var(--font); color: #fff;
  letter-spacing: -0.022em; font-variant-numeric: tabular-nums;
}
.zm-stat__icon {
  grid-column: 2; grid-row: 1;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--green-dim); color: var(--green);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 13px;
}
.zm-stat__lbl {
  grid-column: 1 / -1; grid-row: 2;
  font: 500 13px/1.4 var(--font); color: var(--text-mute);
  align-self: end;
}

/* ---------- "Start trading confidence" 4-step ---------- */
.zm-onboard {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  margin-top: 32px;
}
.zm-onboard__intro {
  grid-column: span 1;
  background: linear-gradient(180deg, rgba(0,185,85,0.12) 0%, rgba(0,185,85,0.02) 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius); padding: 28px 24px;
  display: flex; flex-direction: column; gap: 14px;
}
.zm-onboard__intro h3 { font: 700 22px/1.18 var(--font); color: #fff; margin: 0; }
.zm-onboard__intro p { font: 400 13px/1.5 var(--font); color: var(--text-mute); margin: 0; }
.zm-onboard__step {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 28px 24px;
  display: flex; flex-direction: column; gap: 12px;
}
.zm-onboard__step-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--green-dim); color: var(--green);
  display: inline-flex; align-items: center; justify-content: center; font-size: 18px;
}
.zm-onboard__step h4 { font: 700 17px/1.25 var(--font); color: #fff; margin: 0; }
.zm-onboard__step p { font: 400 13px/1.5 var(--font); color: var(--text-mute); margin: 0; }
.zm-onboard__cta {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 28px 24px;
  display: flex; flex-direction: column; gap: 12px; justify-content: space-between;
}
.zm-onboard__cta h4 { font: 700 17px/1.25 var(--font); color: #fff; margin: 0; }
.zm-onboard__photo {
  grid-column: span 2; border-radius: var(--radius); overflow: hidden; min-height: 220px;
  background: var(--bg-2);
}
.zm-onboard__photo img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- "Take the markets with you" green band ---------- */
.zm-mktband {
  background: linear-gradient(135deg, var(--green) 0%, #056630 100%);
  border-radius: var(--radius-lg); padding: 56px 48px;
  display: flex; align-items: center; justify-content: space-between; gap: 32px;
  flex-wrap: wrap;
  margin-top: 32px;
}
.zm-mktband__copy { max-width: 560px; }
.zm-mktband__h { font: 700 28px/1.2 var(--font); color: #fff; margin: 0 0 10px; }
.zm-mktband__p { font: 400 15px/1.55 var(--font); color: rgba(255,255,255,0.85); margin: 0 0 18px; }
.zm-mktband__stores { display: flex; gap: 10px; }
.zm-mktband__store {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: 10px;
  background: #0B1110; color: #fff;
  font: 600 12px/1.1 var(--font);
}
.zm-mktband__store i { font-size: 22px; }
.zm-mktband__store small { display: block; font-weight: 500; font-size: 9px; opacity: 0.7; }

/* ---------- Fund-your-account hero strip ---------- */
.zm-fund {
  display: grid; grid-template-columns: 1fr 1.2fr; gap: 56px;
  align-items: center; padding: 96px 0;
}
.zm-fund__copy { display: flex; flex-direction: column; gap: 18px; }
.zm-fund__h { font: 700 44px/1.1 var(--font); color: #fff; letter-spacing: -0.022em; margin: 0; }
.zm-fund__p { font: 400 16px/1.55 var(--font); color: var(--text-mute); margin: 0; max-width: 44ch; }
.zm-fund__art {
  background: linear-gradient(135deg, var(--bg-2), var(--bg-3));
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 40px;
  position: relative; min-height: 360px;
  display: flex; align-items: center; justify-content: center;
}
.zm-fund__pay-icons {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px;
  width: 100%; max-width: 460px;
}
.zm-fund__pay-icon {
  background: #fff; border-radius: 12px;
  height: 60px; display: flex; align-items: center; justify-content: center;
  font: 700 13px/1 var(--font); color: #0B1110;
}

/* ---------- Plan cards ---------- */
.zm-plans { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; align-items: stretch; }
.zm-plan {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 30px 28px;
  display: flex; flex-direction: column; gap: 18px;
  position: relative; overflow: hidden;
  transition: box-shadow .35s ease, border-color .35s ease;
}
.zm-plan > * { position: relative; z-index: 1; }
.zm-plan.is-popular {
  background: linear-gradient(180deg, rgba(0,185,85,0.16) 0%, var(--bg-2) 60%);
  border: 1px solid rgba(0,185,85,0.55);
  box-shadow: 0 30px 70px -30px rgba(0,185,85,0.55);
}

.zm-plan__head { display: flex; align-items: flex-start; justify-content: space-between; }
.zm-plan__badge {
  width: 52px; height: 52px; border-radius: 50%; flex-shrink: 0;
  display: grid; place-items: center;
  background: var(--bg-3);
  border: 1px solid var(--line-2);
}
.zm-plan__badge img { width: 56%; height: 56%; object-fit: contain; display: block; }
.zm-plan.is-popular .zm-plan__badge {
  background: rgba(0,185,85,0.18);
  border-color: rgba(0,185,85,0.45);
}
.zm-plan__pop {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(0,185,85,0.18); color: var(--green-bright);
  font: 600 12px/1 var(--font); letter-spacing: 0.01em; text-transform: none;
  padding: 7px 13px 7px 11px; border-radius: var(--radius-pill);
  border: 1px solid rgba(32,223,128,0.32);
}
.zm-plan__pop-ic { width: 13px; height: 13px; display: block; flex-shrink: 0; }

.zm-plan__intro { display: flex; flex-direction: column; gap: 6px; }
.zm-plan__name { font: 700 24px/1.15 var(--font); color: #fff; margin: 0; letter-spacing: -0.01em; }

.zm-plan__price { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.zm-plan__price-val { font: 700 38px/1 var(--font); color: #fff; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.zm-plan__price-meta { display: flex; flex-direction: column; gap: 2px; }
.zm-plan__price-unit { font: 500 13px/1.3 var(--font); color: var(--text-mute); }
.zm-plan__price-brl  { font: 400 12px/1.3 var(--font); color: var(--text-faint); }

.zm-plan__cta { padding-top: 2px; }
.zm-plan__cta .zm-btn { width: 100%; }

.zm-plan__desc { font: 400 13px/1.55 var(--font); color: var(--text-mute); margin: 0; }
.zm-plan__feats {
  display: flex; flex-direction: column; gap: 12px;
  margin: 2px 0 0; padding: 18px 0 0;
  border-top: 1px solid var(--line); list-style: none;
}
.zm-plan__feats li {
  display: flex; gap: 12px; align-items: center;
  font: 500 13px/1.4 var(--font); color: var(--text);
  position: relative; padding-left: 0;
}
.zm-plan__feats li::before {
  content: ""; width: 20px; height: 20px; border-radius: 50%; flex-shrink: 0;
  background: var(--green-dim); border: 1px solid rgba(0,185,85,0.35);
}
.zm-plan__feats li::after {
  content: ""; position: absolute; left: 6px; top: 7px;
  width: 7px; height: 4px;
  border-left: 2px solid var(--green-bright); border-bottom: 2px solid var(--green-bright);
  transform: rotate(-45deg);
}

/* ---------- Trading platform / "smarter way to trade" ---------- */
.zm-platform { display: grid; grid-template-columns: 1.05fr 1fr; gap: 48px; align-items: center; padding: 64px 0; }
.zm-platform__art {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 32px;
  min-height: 320px;
  display: grid; grid-template-rows: auto 1fr; gap: 20px;
}
.zm-platform__art-row {
  display: flex; gap: 18px; align-items: center;
  padding: 12px 0; border-bottom: 1px solid var(--line);
  font: 600 13px/1 var(--font); color: var(--text-mute);
}
.zm-platform__art-row.is-up { color: var(--green); }
.zm-platform__art-row.is-down { color: var(--error); }
.zm-platform__art-row strong { color: #fff; font-weight: 700; min-width: 80px; }
.zm-platform__num { font: 700 76px/1 var(--font); color: #fff; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.zm-platform__num-row { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.zm-platform__num-row > span { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.zm-platform__num-row > span small { font: 600 10px/1 var(--font); color: var(--text-mute); letter-spacing: 0.10em; text-transform: uppercase; }

.zm-platform__copy { display: flex; flex-direction: column; gap: 18px; }
.zm-platform__features { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 12px; }
.zm-platform__feat {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 18px;
  display: flex; flex-direction: column; gap: 6px;
}
.zm-platform__feat-eyebrow { font: 700 10px/1 var(--font); letter-spacing: 0.12em; text-transform: uppercase; color: var(--green); }
.zm-platform__feat-text { font: 500 13px/1.4 var(--font); color: var(--text-mute); }

/* ---------- Choose your platform (Windows / Mac / iOS / Android / WebTrader) ---------- */
.zm-platforms-row { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; margin: 32px 0; }
.zm-platforms-row button {
  height: 44px; padding: 0 24px; border-radius: var(--radius-pill);
  border: 1px solid var(--line); background: var(--bg-2); color: #C9CFCF;
  font: 600 13px/1 var(--font);
}
.zm-platforms-row button.is-active { background: var(--green); border-color: var(--green); color: var(--color-on-primary); }

.zm-platforms-detail {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 0;
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius-lg); overflow: hidden;
}
.zm-platforms-detail__copy { padding: 48px; display: flex; flex-direction: column; gap: 18px; justify-content: space-between; }
.zm-platforms-detail__photo { background: linear-gradient(180deg, #16261D, #0B1110); position: relative; overflow: hidden; }
.zm-platforms-detail__photo img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- Testimonials ---------- */
.zm-testi { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 32px; }
.zm-testi__card {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 28px 26px;
  display: flex; flex-direction: column; gap: 18px; justify-content: space-between;
  min-height: 260px;
}
.zm-testi__stars { display: flex; gap: 4px; color: var(--green); font-size: 14px; }
.zm-testi__quote { font: 400 14px/1.55 var(--font); color: #C9CFCF; margin: 0; }
.zm-testi__author { display: flex; gap: 12px; align-items: center; }
.zm-testi__avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--bg-3); }
.zm-testi__name { font: 600 14px/1.2 var(--font); color: #fff; }
.zm-testi__role { font: 400 12px/1.3 var(--font); color: var(--text-mute); margin-top: 2px; }

/* ---------- "New to trading?" overlay band ---------- */
.zm-newto {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius-lg); overflow: hidden;
  display: grid; grid-template-columns: 1fr 1.4fr;
  align-items: stretch;
}
.zm-newto__copy { padding: 56px 48px; display: flex; flex-direction: column; gap: 18px; justify-content: center; }
.zm-newto__h { font: 700 32px/1.18 var(--font); color: #fff; margin: 0; letter-spacing: -0.018em; }
.zm-newto__p { font: 400 14px/1.55 var(--font); color: var(--text-mute); margin: 0; max-width: 48ch; }
.zm-newto__cta { display: flex; gap: 10px; flex-wrap: wrap; }
.zm-newto__photo { position: relative; overflow: hidden; min-height: 360px; background: var(--bg-3); }
.zm-newto__photo img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- Footer triple-band (24/5 Support, etc.) ---------- */
.zm-tribar {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 48px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px;
  margin-top: 32px;
}
.zm-tribar__cell { display: flex; flex-direction: column; gap: 10px; }
.zm-tribar__icon {
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--green-dim); color: var(--green);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 20px;
}
.zm-tribar__h { font: 700 14px/1 var(--font); letter-spacing: 0.10em; text-transform: uppercase; color: var(--green); margin: 0; }
.zm-tribar__p { font: 400 14px/1.55 var(--font); color: var(--text-mute); margin: 0; }

/* ---------- Footer (original structure: brand col + 4 link cols + stack + legal accordion) ---------- */
.zm-footer {
  background: var(--bg-deep);
  color: #C9CFCF;
  padding: 80px 0 32px;
  margin: 96px 0 0;
  border: 0; border-radius: 0;
}
.zm-footer .zm-container { max-width: 1320px; }

/* Top row: brand block on left, 4-col link grid on right */
.zm-footer__top {
  display: grid;
  grid-template-columns: 1.1fr 2.4fr;
  gap: 64px;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--line);
}
.zm-footer__brand-row { display: inline-flex; align-items: center; }
.zm-footer__brand-row img { height: 32px; width: auto; display: block; filter: brightness(0) invert(1); }
.zm-footer__tagline { font: 400 14px/1.55 var(--font); color: #9CA3AA; margin: 18px 0 0; max-width: 360px; }

.zm-footer__cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; padding: 0; border: 0; }
.zm-footer__cols > div { display: flex; flex-direction: column; }
.zm-footer__cols h4 { font: 600 12px/1 var(--font); letter-spacing: .12em; text-transform: uppercase; color: var(--green); margin: 0 0 16px; }
.zm-footer__cols a { display: block; font: 400 14px/2.0 var(--font); color: #C9CFCF; transition: color 160ms; }
.zm-footer__cols a:hover { color: var(--green-bright); }

/* The Stack — partner logos row */
.zm-footer__partners { padding: 28px 0; border-top: 0; border-bottom: 1px solid var(--line); display: flex; gap: 32px; align-items: center; flex-wrap: wrap; }
.zm-footer__partners-label { font: 600 11px/1 var(--font); letter-spacing: .14em; text-transform: uppercase; color: var(--text-faint); }
.zm-footer__partners-logos { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; row-gap: 16px; }
.zm-footer__partner-logo { height: 22px; width: auto; filter: brightness(0) invert(1); opacity: 0.55; transition: opacity 160ms; }
.zm-footer__partner-logo:hover { opacity: 0.9; }
.zm-footer__partner-logo[alt="Alpaca"]     { height: 28px; }
.zm-footer__partner-logo[alt="Nelogica"]   { height: 18px; }
.zm-footer__partner-logo[alt="Levycam"]    { height: 36px; }
.zm-footer__partner-logo[alt="BlackArrow"] { height: 22px; }
.zm-footer__partner-logo[alt="Nasdaq"]     { height: 16px; }
.zm-footer__partner-logo[alt="LSEG"]       { height: 14px; }

/* Legal disclosures accordion (Avisos Legais e Regulatórios) */
.zm-footer__legal { border-bottom: 1px solid var(--line); display: block; padding: 0; gap: 0; }
.zm-footer__legal-toggle { display: flex; width: 100%; align-items: center; justify-content: space-between; gap: 32px; padding: 24px 0; background: transparent; border: 0; cursor: pointer; color: inherit; text-align: left; }
.zm-footer__legal-toggle-text { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.zm-footer__legal-toggle-text strong { font: 600 13px/1.2 var(--font); color: #C9CFCF; letter-spacing: .02em; }
.zm-footer__legal-toggle-text span { font: 400 12px/1.5 var(--font); color: #9CA3AA; }
.zm-footer__legal-toggle i { font-size: 16px; color: #9CA3AA; flex-shrink: 0; transition: color 160ms; }
.zm-footer__legal.is-open .zm-footer__legal-toggle i { color: var(--green-bright); }
.zm-footer__legal-body { padding: 8px 0 32px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px 48px; }
.zm-footer__legal-section { display: flex; flex-direction: column; gap: 8px; }
.zm-footer__legal-section h5 { font: 600 10px/1 var(--font); letter-spacing: .12em; text-transform: uppercase; color: var(--green); margin: 0 0 4px; }
.zm-footer__legal-section .zm-legal__p { font: 400 12px/1.6 var(--font); color: #9CA3AA; margin: 0; }
.zm-footer__legal-section .zm-legal__list { padding-left: 18px; margin: 4px 0; color: #9CA3AA; font: 400 12px/1.6 var(--font); }
.zm-footer__legal-section .zm-legal__list li { margin-bottom: 2px; }
.zm-footer__legal-section .zm-legal__links { list-style: none; padding: 0; margin: 8px 0 0; display: flex; flex-direction: column; gap: 6px; }
.zm-footer__legal-section .zm-legal__links a { color: var(--green-bright); font: 500 12px/1.4 var(--font); display: inline-flex; align-items: center; gap: 6px; }
.zm-footer__legal-section .zm-legal__links a:hover { color: #fff; }
.zm-footer__legal-deeplink { grid-column: 1 / -1; margin: 8px 0 0; }
.zm-footer__legal-deeplink a { font: 500 13px/1 var(--font); color: var(--green-bright); }
.zm-footer__legal-deeplink a:hover { color: #fff; }

/* Compliance text */
.zm-footer__compliance { padding: 32px 0; border-bottom: 1px solid var(--line); }
.zm-footer__compliance p { margin: 0; font: 400 12px/1.6 var(--font); color: #9CA3AA; }

/* Bottom row */
.zm-footer__bottom { padding-top: 24px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; font: 400 12px/1 var(--font); color: var(--text-faint); }
.zm-footer__bottom span { color: var(--text-faint); }

/* ---------- Responsive ---------- */
@media (max-width: 1080px) {
  .zm-hero__grid { grid-template-columns: 1fr; gap: 32px; }
  .zm-hero__side { grid-template-columns: 1fr 1fr; }
  .zm-fund, .zm-confidence, .zm-platform, .zm-platforms-detail, .zm-newto, .zm-onboard, .zm-tribar { grid-template-columns: 1fr; }
  .zm-onboard__photo { grid-column: span 1; }
  .zm-plans { grid-template-columns: 1fr; }
  .zm-testi { grid-template-columns: 1fr 1fr; }
  .zm-footer__top { grid-template-columns: 1fr; gap: 32px; }
  .zm-footer__cols { grid-template-columns: repeat(2, 1fr); }
  .zm-footer__legal-body { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .zm-hero__h1 { font-size: 40px; }
  .zm-section__h, .zm-fund__h { font-size: 28px; }
  .zm-hero__copy { left: 24px; right: 24px; top: 32px; }
  .zm-hero__side { grid-template-columns: 1fr; }
  .zm-stats { grid-template-columns: 1fr; }
  .zm-testi { grid-template-columns: 1fr; }
  .zm-footer { padding: 56px 0 24px; margin: 64px 0 0; }
  .zm-footer__cols { grid-template-columns: 1fr; gap: 24px; }
}

/* ════════════════════════════════════════════════════════════════════════════
   PART B · LEGACY-COMPATIBLE CLASSES
   These classes are referenced by the 22 existing page JSX files. They use the
   same dark + green visual system declared above, just under different names.
   ════════════════════════════════════════════════════════════════════════════ */

/* ---------- Section primitives (Section / SectionHead from primitives.jsx) ---------- */
.zm-section { padding: 96px 0; background: transparent; color: var(--text); position: relative; }
.zm-section--tight { padding: 64px 0; }
.zm-section--surface { background: var(--bg-2); }
.zm-section--container { background: var(--bg-deep); }
.zm-section--dark { background: var(--bg-deep); color: #fff; }
.zm-section--dark::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(60% 60% at 50% 0%, rgba(0,185,85,0.10), transparent 70%);
}
.zm-section--dark > .zm-container { position: relative; z-index: 1; }
.zm-section__head { display: flex; flex-direction: column; gap: 14px; margin-bottom: 56px; max-width: 760px; }
.zm-section__head--center { align-items: center; text-align: center; margin: 0 auto 56px; }
.zm-section__title { font: 700 44px/1.1 var(--font); letter-spacing: -0.022em; color: #fff; margin: 0; text-wrap: balance; }
.zm-section__title--lg { font-size: 56px; line-height: 1.05; letter-spacing: -0.026em; }
.zm-section__lede { font: 400 16px/1.55 var(--font); color: var(--text-mute); margin: 0; max-width: 600px; }
.zm-section--dark .zm-section__title { color: #fff; }
.zm-section--dark .zm-section__lede { color: var(--text-mute); }

/* ---------- Eyebrow variants (existing JSX uses dark / neutral modifiers) ---------- */
.zm-eyebrow--ondark { color: var(--green); background: transparent; }
.zm-eyebrow--neutral { color: var(--text-mute); }
.zm-eyebrow--neutral::before { background: var(--text-mute); }

/* ---------- Generic grid ---------- */
.zm-grid { display: grid; gap: 16px; }
.zm-grid--2 { grid-template-columns: repeat(2, 1fr); }
.zm-grid--3 { grid-template-columns: repeat(3, 1fr); }
.zm-grid--4 { grid-template-columns: repeat(4, 1fr); }
.zm-grid--6 { grid-template-columns: repeat(6, 1fr); }
@media (max-width: 960px) {
  .zm-grid--3, .zm-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .zm-grid--2, .zm-grid--3, .zm-grid--4, .zm-grid--6 { grid-template-columns: 1fr; }
}

/* ---------- Value-prop card (.zm-vp) ---------- */
.zm-vp {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 28px;
  display: flex; flex-direction: column; gap: 14px;
  position: relative; overflow: hidden;
  transition: border-color 200ms, transform 200ms;
}
.zm-vp::before {
  content: ""; position: absolute; top: 0; right: 0; width: 200px; height: 200px;
  background: radial-gradient(60% 60% at 100% 0%, rgba(0,185,85,0.08), transparent 65%);
  pointer-events: none;
}
.zm-vp:hover { border-color: rgba(0,185,85,0.32); transform: translateY(-2px); }
.zm-vp > * { position: relative; z-index: 1; }
.zm-vp .ph, .zm-vp .ph-fill {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--green-dim); color: var(--green);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 22px;
}
.zm-vp__title { font: 700 18px/1.3 var(--font); color: #fff; margin: 0; }
.zm-vp__body  { font: 400 14px/1.55 var(--font); color: var(--text-mute); margin: 0; flex: 1; }

/* ---------- Card / Panel ---------- */
.zm-card  { background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; color: var(--text); }
.zm-card--dark   { background: var(--bg-deep); border-color: var(--line); }
.zm-card--accent { background: linear-gradient(160deg, #0E5C2F 0%, #052B17 100%); border-color: rgba(0,185,85,0.32); color: #fff; }
.zm-panel { background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 32px; color: var(--text); }
.zm-panel--accent {
  background:
    radial-gradient(55% 110% at 0% 50%, rgba(0,185,85,0.20) 0%, rgba(0,185,85,0.05) 40%, transparent 70%),
    var(--bg-2);
  border-color: var(--line-2);
  color: #fff;
}
.zm-panel--dark { background: var(--bg-deep); border-color: var(--line); }

/* ---------- Tag pills ---------- */
.zm-tag { display: inline-flex; align-items: center; gap: 6px; border-radius: var(--radius-pill); font: 600 12px/1 var(--font); padding: 6px 10px; font-variant-numeric: tabular-nums; }
.zm-tag--up { background: var(--green-dim); color: var(--green); }
.zm-tag--down { background: rgba(255,83,102,0.18); color: var(--error); }
.zm-tag--mute { background: rgba(255,255,255,0.06); color: #C9CFCF; }
.zm-tag--mute-dark { background: rgba(255,255,255,0.08); color: #C9CFCF; }
.zm-tag--soon { background: rgba(255,216,117,0.18); color: #FFD875; }

/* ---------- Button compatibility (existing JSX uses different kinds) ---------- */
.zm-btn--solid { background: var(--green); color: var(--color-on-primary); box-shadow: 0 8px 24px -8px rgba(0,185,85,0.55); }
.zm-btn--solid:hover { background: var(--green-bright); transform: translateY(-1px); }
.zm-btn--outline { background: transparent; color: #fff; border: 1px solid var(--line-2); }
.zm-btn--outline:hover { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.32); }
.zm-btn--outline-dark { background: transparent; color: #fff; border: 1px solid var(--line-2); }
.zm-btn--outline-dark:hover { background: rgba(255,255,255,0.06); border-color: var(--green); color: var(--green-bright); }
.zm-btn--text { background: transparent; color: var(--green-bright); padding: 0 12px; height: auto; }
.zm-btn--text:hover { background: rgba(0,185,85,0.10); }
.zm-btn--text-dark { background: transparent; color: var(--green-bright); padding: 0 12px; height: auto; }
.zm-btn--text-dark:hover { background: rgba(0,185,85,0.12); }
.zm-btn:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(0,185,85,0.30); }

/* ---------- Page hero (PageHero component) — full photo on right with mask-feathered left edge ---------- */
.zm-page { padding-bottom: 96px; }
.zm-page__hero {
  padding: 24px 0 96px;
  position: relative; isolation: isolate;
  min-height: 560px;
  overflow: hidden;
  background: var(--bg);            /* solid dark base */
  --hero-photo: url("graph/Rectangle 44.png");   /* default fallback; per-page set via inline style */
}
/* Photo layer — anchored right, contained (whole photo visible), and feathered on the LEFT
   via mask-image so it dissolves naturally into the dark background. No harsh dark-overlay. */
.zm-page__hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background-image: var(--hero-photo);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
  /* Horizontal feather: left edge fades to transparent; right side fully opaque.
     Plus a touch of bottom feather for the next section to ease in. */
  -webkit-mask-image:
    linear-gradient(90deg,
      transparent 0%,
      transparent 32%,
      rgba(0,0,0,0.12) 42%,
      rgba(0,0,0,0.45) 52%,
      rgba(0,0,0,0.80) 62%,
      #000 72%,
      #000 100%),
    linear-gradient(180deg, #000 65%, rgba(0,0,0,0.55) 100%);
  mask-image:
    linear-gradient(90deg,
      transparent 0%,
      transparent 32%,
      rgba(0,0,0,0.12) 42%,
      rgba(0,0,0,0.45) 52%,
      rgba(0,0,0,0.80) 62%,
      #000 72%,
      #000 100%),
    linear-gradient(180deg, #000 65%, rgba(0,0,0,0.55) 100%);
  -webkit-mask-composite: source-in;
  mask-composite: intersect;     /* both masks must agree → smooth corner falloff */
}
/* Subtle radial vignette + tiny green accent for polish */
.zm-page__hero::after {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(60% 80% at 0% 50%, rgba(7,12,11,0.40), transparent 55%),
    radial-gradient(40% 50% at 0% 30%, rgba(0,185,85,0.06), transparent 60%);
  pointer-events: none;
}
.zm-page__hero .zm-container { position: relative; z-index: 1; }
.zm-page__hero > .zm-container .zm-bc,
.zm-page__hero > .zm-bc { padding: 8px 0 24px; }

/* Dark glass text card — sits in the upper-left of the hero */
.zm-page__hero-card {
  background: rgba(11,17,16,0.55);
  backdrop-filter: blur(20px) saturate(1.1);
  -webkit-backdrop-filter: blur(20px) saturate(1.1);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 24px;
  padding: 36px 40px;
  max-width: 520px;
  display: flex; flex-direction: column; gap: 16px;
  box-shadow: 0 30px 60px -16px rgba(0,0,0,0.5);
}
.zm-page__hero-card h1 {
  font: 700 40px/1.1 var(--font);
  color: #fff; margin: 4px 0 4px;
  letter-spacing: -0.022em;
  text-wrap: balance;
}
.zm-page__hero-card .zm-page__hero-lede {
  font: 400 15px/1.55 var(--font);
  color: #C9CFCF; margin: 0 0 14px;
  max-width: 44ch;
}
.zm-page__hero-card .zm-page__hero-cta {
  display: flex; gap: 10px; flex-wrap: wrap;
}

/* Legacy: hero-art hidden by default; bg photo replaces it. Page can still pass art and we won't render visibly */
.zm-page__hero-art { display: none; }

@media (max-width: 900px) {
  .zm-page__hero { min-height: 460px; padding: 24px 0 64px; }
  .zm-page__hero-card { max-width: 100%; padding: 28px 24px; }
  .zm-page__hero-card h1 { font-size: 32px; }
}
.zm-page__hero-inner { display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: center; }
.zm-page__hero h1 { font: 800 56px/1.05 var(--font); letter-spacing: -0.024em; color: #fff; margin: 16px 0 20px; text-wrap: balance; }
.zm-page__hero-lede { font: 400 18px/1.55 var(--font); color: var(--text-mute); margin: 0 0 28px; max-width: 56ch; }
.zm-page__hero-cta { display: flex; gap: 10px; flex-wrap: wrap; }
/* Art slot hidden by default — Cafu+couch bg fills the right side instead.
   Pages that need a custom hero art (BankSweep SVG, Open Account phone) opt in
   via the .zm-page__hero-art--show modifier on the wrapping element. */
.zm-page__hero-art { display: none; }
.zm-page__hero-art--show {
  display: block;
  position: relative; min-height: 360px;
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius-lg); overflow: hidden;
}
.zm-page__hero-art--show img { width: 100%; height: 100%; object-fit: cover; }
/* Hero inner — single column when art is hidden so text gets full breathing room */
.zm-page__hero-inner { grid-template-columns: minmax(420px, 600px) 1fr; }
.zm-photo, .zm-photo--frame {
  width: 100%; height: 100%; min-height: 360px;
  border-radius: var(--radius-lg); overflow: hidden;
  object-fit: cover;
  border: 1px solid var(--line);
}
.zm-photo--hero-wide { border: none; border-radius: 16px; }
@media (max-width: 900px) {
  .zm-page__hero-inner { grid-template-columns: 1fr; }
  .zm-page__hero h1 { font-size: 36px; }
}

/* ---------- Breadcrumb ---------- */
.zm-bc { display: flex; align-items: center; gap: 8px; font: 500 13px/1 var(--font); color: var(--text-mute); padding: 24px 0 0; }
.zm-bc a { cursor: pointer; transition: color 160ms; }
.zm-bc a:hover { color: var(--green-bright); }
.zm-bc .ph { font-size: 14px; }

/* ---------- Prose (long-form text) ---------- */
.zm-prose { font: 400 16px/1.65 var(--font); color: var(--text-mute); }
.zm-prose p { margin: 0 0 18px; }
.zm-prose strong { color: #fff; font-weight: 600; }
.zm-prose a { color: var(--green-bright); text-decoration: underline; text-underline-offset: 3px; }

/* ---------- Steps (StepList) ---------- */
.zm-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.zm-step {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 28px;
  counter-increment: step;
}
.zm-step__num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: 999px;
  background: var(--green); color: #fff;
  font: 700 14px/1 var(--font); font-variant-numeric: tabular-nums;
}
.zm-step__title { font: 700 18px/1.3 var(--font); color: #fff; margin: 18px 0 8px; }
.zm-step__body  { font: 400 14px/1.55 var(--font); color: var(--text-mute); margin: 0; }
@media (max-width: 900px) { .zm-steps { grid-template-columns: 1fr; } }

/* ---------- Checklist ---------- */
.zm-check { display: flex; flex-direction: column; gap: 10px; }
.zm-check li { position: relative; padding-left: 30px; font: 500 14px/1.5 var(--font); color: #fff; }
.zm-check li::before {
  content: ""; position: absolute; left: 0; top: 2px; width: 20px; height: 20px;
  border-radius: 50%; background: var(--green-dim);
}
.zm-check li::after {
  content: ""; position: absolute; left: 5px; top: 9px;
  width: 9px; height: 5px;
  border-left: 2px solid var(--green); border-bottom: 2px solid var(--green);
  transform: rotate(-45deg);
}

/* ---------- Notice ---------- */
.zm-notice {
  background: rgba(255,255,255,0.03); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 16px 20px;
  display: flex; gap: 12px; align-items: flex-start;
  color: #C9CFCF; font: 400 14px/1.55 var(--font);
}
.zm-notice .ph { color: var(--green); font-size: 20px; flex-shrink: 0; }

/* ---------- Mkt strip (markets ticker under home hero) ---------- */
.zm-mkt-strip { background: var(--bg-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.zm-mkt-strip__inner { max-width: 1380px; margin: 0 auto; padding: 16px 32px; display: flex; gap: 24px; align-items: center; flex-wrap: wrap; }
.zm-mkt-strip__label { font: 700 11px/1 var(--font); letter-spacing: .14em; text-transform: uppercase; color: var(--green); flex-shrink: 0; }
.zm-mkt-strip__list { font: 500 13px/1.4 var(--font); color: var(--text-mute); flex: 1; min-width: 0; }
.zm-mkt-strip__item { color: #C9CFCF; }
.zm-mkt-strip__item strong { color: #fff; font-weight: 700; margin-right: 4px; font-variant-numeric: tabular-nums; }
.zm-mkt-strip__sep { color: rgba(255,255,255,0.18); margin: 0 4px; }

/* ---------- Trust strip (logos row) ---------- */
.zm-trust { padding: 56px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.zm-trust__inner { display: flex; align-items: center; justify-content: space-between; gap: 48px; flex-wrap: wrap; }
.zm-trust__label { font: 500 13px/1.5 var(--font); color: var(--text-mute); max-width: 280px; }
.zm-trust__logos { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; row-gap: 16px; }
.zm-trust__logo { display: block; opacity: 0.55; filter: brightness(0) invert(1); transition: opacity 200ms; }
.zm-trust__logo:hover { opacity: 0.9; }
.zm-trust__logo[alt="alpaca"]     { height: 48px; }
.zm-trust__logo[alt="nelogica"]   { height: 38px; }
.zm-trust__logo[alt="levycam"]    { height: 64px; }
.zm-trust__logo[alt="blackarrow"] { height: 40px; }
.zm-trust__logo[alt="nasdaq"]     { height: 32px; }
.zm-trust__logo[alt="lseg"]       { height: 28px; }

/* ---------- FAQ (.zm-faq + .zm-acc) ---------- */
.zm-faq { display: flex; flex-direction: column; gap: 12px; }
.zm-acc {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); overflow: hidden;
  transition: background 200ms, border-color 200ms;
}
.zm-acc:hover { background: var(--bg-3); }
.zm-acc.is-open { border-color: rgba(0,185,85,0.45); background: var(--bg-3); }
.zm-acc__head {
  width: 100%; background: transparent; border: 0; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 28px; font: 600 16px/1.35 var(--font); color: #fff; gap: 16px;
  text-align: left;
}
.zm-acc__head .ph { font-size: 22px; color: var(--green); transition: transform 200ms; flex-shrink: 0; }
.zm-acc.is-open .zm-acc__head .ph { transform: rotate(180deg); }
.zm-acc__body { padding: 0 28px 22px; font: 400 14px/1.6 var(--font); color: var(--text-mute); }
.zm-acc__body p { margin: 0 0 12px; }
.zm-acc__body p:last-child { margin-bottom: 0; }

/* ---------- Symbol grid (US tickers list on Stocks/ETFs pages) ---------- */
.zm-syms { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; }
.zm-sym {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 16px; cursor: pointer;
  transition: border-color 200ms, transform 200ms;
  display: flex; flex-direction: column; align-items: flex-start; gap: 10px;
}
.zm-sym:hover { border-color: rgba(0,185,85,0.32); transform: translateY(-2px); }
.zm-sym__icon { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0; overflow: hidden; }
.zm-sym__icon-img { width: 22px; height: 22px; filter: brightness(0) invert(1); }
.zm-sym__icon--raw .zm-sym__icon-img { width: 100%; height: 100%; filter: none; }
.zm-sym__icon-letter { font: 700 15px/1 var(--font); color: #fff; }
.zm-sym__sym { font: 700 14px/1 var(--font); color: #fff; letter-spacing: .02em; font-variant-numeric: tabular-nums; }
.zm-sym__name { font: 400 12px/1.3 var(--font); color: var(--text-mute); }
@media (max-width: 900px) { .zm-syms { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 500px) { .zm-syms { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Cost breakdown (FX page) ---------- */
.zm-cost { background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 32px; }
.zm-cost__head { display: flex; flex-direction: column; gap: 6px; padding-bottom: 24px; border-bottom: 1px solid var(--line); }
.zm-cost__from { font: 400 13px/1 var(--font); color: var(--text-mute); letter-spacing: .04em; text-transform: uppercase; }
.zm-cost__amt { font: 700 40px/1.05 var(--font); letter-spacing: -.014em; color: #fff; font-variant-numeric: tabular-nums; }
.zm-cost__body { padding: 16px 0; display: flex; flex-direction: column; }
.zm-cost__row { display: grid; grid-template-columns: 1fr auto auto; gap: 24px; align-items: center; padding: 14px 0; border-bottom: 1px solid var(--line); }
.zm-cost__row:last-child { border-bottom: none; }
.zm-cost__row.is-vet { font-weight: 600; padding-top: 18px; border-top: 1px solid var(--line); border-bottom: none; }
.zm-cost__row.is-net { background: var(--green-dim); border: 1px solid rgba(0,185,85,0.32); border-radius: var(--radius); padding: 18px 16px; margin-top: 8px; }
.zm-cost__label { font: 500 14px/1.4 var(--font); color: #fff; display: flex; flex-direction: column; gap: 2px; }
.zm-cost__label small { font: 400 12px/1.3 var(--font); color: var(--text-mute); }
.zm-cost__amount { font: 500 14px/1 var(--font); color: #fff; text-align: right; font-variant-numeric: tabular-nums; }
.zm-cost__pct { font: 500 13px/1 var(--font); color: var(--text-mute); text-align: right; min-width: 56px; font-variant-numeric: tabular-nums; }
.zm-cost__row.is-net .zm-cost__label { color: var(--green-bright); font-weight: 700; }
.zm-cost__row.is-net .zm-cost__amount,
.zm-cost__row.is-net .zm-cost__pct { color: var(--green-bright); font-weight: 700; font-size: 18px; }
.zm-cost__foot { padding-top: 20px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.zm-cost__rate { font: 500 13px/1.4 var(--font); color: var(--text-mute); display: flex; flex-direction: column; gap: 2px; }
.zm-cost__rate strong { color: #fff; font-variant-numeric: tabular-nums; }

/* ---------- Table ---------- */
.zm-table { width: 100%; border-collapse: collapse; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; }
.zm-table th { font: 600 12px/1 var(--font); text-transform: uppercase; letter-spacing: .12em; color: var(--green); text-align: left; padding: 18px 24px; border-bottom: 1px solid var(--line); }
.zm-table td { padding: 18px 24px; font: 400 14px/1.5 var(--font); color: #C9CFCF; border-bottom: 1px solid rgba(255,255,255,0.04); }
.zm-table tr:last-child td { border-bottom: none; }
.zm-table td strong { color: #fff; }

/* ---------- Pillars (3-up trust) ---------- */
.zm-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.zm-pillar {
  background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 28px;
  display: flex; flex-direction: column; gap: 12px;
}
.zm-pillar .ph-fill { color: var(--green); font-size: 28px; }
.zm-pillar__eyebrow { font: 700 11px/1 var(--font); letter-spacing: .14em; text-transform: uppercase; color: var(--green); }
.zm-pillar__title { font: 600 17px/1.35 var(--font); color: #fff; }
@media (max-width: 900px) { .zm-pillars { grid-template-columns: 1fr; } }

/* ---------- Onboarding (Home page) ---------- */
.zm-onboard { display: grid; grid-template-columns: 1fr 1.2fr; gap: 56px; align-items: center; margin-top: 0; }
.zm-onboard__photo {
  grid-column: auto;       /* reset wework's `span 2` so photo stays in 1 col */
  border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/3;
  min-height: auto;
  background: transparent;
}
.zm-onboard__photo img { width: 100%; height: 100%; object-fit: cover; }
.zm-onboard__body { display: flex; flex-direction: column; gap: 8px; }
@media (max-width: 900px) { .zm-onboard { grid-template-columns: 1fr; } }

/* ---------- Custody split + sweep strip ---------- */
.zm-custody-split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.zm-custody-split h2 { color: #fff; }
@media (max-width: 900px) { .zm-custody-split { grid-template-columns: 1fr; } }

.zm-sweep-strip {
  display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center;
  padding: 56px 56px; border-radius: var(--radius-lg);
  background: linear-gradient(160deg, #0E5C2F 0%, #052B17 100%);
  color: #fff; position: relative; overflow: hidden;
}
.zm-sweep-strip__eyebrow { font: 600 11px/1 var(--font); letter-spacing: .14em; text-transform: uppercase; color: var(--green-bright); display: inline-flex; align-items: center; gap: 8px; }
.zm-sweep-strip__eyebrow i { font-size: 14px; }
.zm-sweep-strip h3 { font: 700 32px/1.18 var(--font); letter-spacing: -.014em; color: #fff; margin: 14px 0 16px; text-wrap: balance; }
.zm-sweep-strip p  { font: 400 15px/1.55 var(--font); color: rgba(255,255,255,0.78); margin: 0 0 24px; max-width: 460px; }
.zm-sweep-strip__ctas { display: flex; gap: 8px; flex-wrap: wrap; }
.zm-sweep-strip__art { background: rgba(0,0,0,0.30); border: 1px solid rgba(255,255,255,0.10); border-radius: var(--radius); padding: 20px; display: flex; flex-direction: column; gap: 12px; }
.zm-sweep-strip__art-row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: rgba(0,0,0,0.45); border: 1px solid rgba(255,255,255,0.08); border-radius: 10px; }
.zm-sweep-strip__art-row i { font-size: 18px; color: var(--green-bright); flex-shrink: 0; }
.zm-sweep-strip__art-row strong { display: block; font: 600 13px/1.2 var(--font); color: #fff; }
.zm-sweep-strip__art-row span { font: 400 11px/1.4 var(--font); color: rgba(255,255,255,0.6); }
.zm-sweep-strip__art-row em { font: 600 13px/1 var(--font); color: var(--green-bright); font-style: normal; margin-left: auto; font-variant-numeric: tabular-nums; }
@media (max-width: 900px) { .zm-sweep-strip { grid-template-columns: 1fr; padding: 40px 28px; } }

/* ---------- BankSweep page specifics ---------- */
.zm-sweep-diagram { display: grid; grid-template-columns: 1fr 1fr 1fr; align-items: center; gap: 16px; padding: 24px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--bg-2); color: var(--text-mute); min-height: 300px; }
.zm-sweep-diagram__col { display: flex; flex-direction: column; gap: 10px; }
.zm-sweep-diagram__cap { font: 600 10px/1 var(--font); letter-spacing: .14em; text-transform: uppercase; color: var(--text-mute); }
.zm-sweep-diagram__chip { padding: 16px; border-radius: 12px; background: var(--green-dim); border: 1px solid rgba(0,185,85,0.32); display: flex; flex-direction: column; gap: 4px; }
.zm-sweep-diagram__chip-amt { font: 700 22px/1.1 var(--font); color: #fff; letter-spacing: -.01em; }
.zm-sweep-diagram__chip-tag { font: 500 11px/1 var(--font); color: var(--green-bright); letter-spacing: .04em; }
.zm-sweep-diagram__sub { font: 400 11px/1.4 var(--font); color: var(--text-mute); }
.zm-sweep-diagram__flow { width: 100%; height: 200px; color: var(--green); }
.zm-sweep-diagram__bank { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px; background: rgba(255,255,255,0.04); }
.zm-sweep-diagram__bank i { font-size: 18px; color: var(--green-bright); }
.zm-sweep-diagram__bank strong { display: block; font: 600 13px/1.1 var(--font); color: #fff; }
.zm-sweep-diagram__bank span { font: 400 11px/1.2 var(--font); color: var(--text-mute); }

.zm-sweep-pillars { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 32px; }
.zm-sweep-pillar { padding: 28px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--bg-2); }
.zm-sweep-pillar__icon { width: 44px; height: 44px; border-radius: 12px; background: var(--green-dim); color: var(--green); display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.zm-sweep-pillar__icon i { font-size: 22px; }
.zm-sweep-pillar h4 { font: 600 17px/1.3 var(--font); color: #fff; margin: 0 0 8px; }
.zm-sweep-pillar p  { font: 400 14px/1.55 var(--font); color: var(--text-mute); margin: 0; }

.zm-sweep-verbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 32px; }
.zm-sweep-verb { padding: 28px 24px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--bg-2); color: #fff; position: relative; }
.zm-sweep-verb__n { position: absolute; top: 20px; right: 24px; font: 600 11px/1 var(--font); color: var(--green); letter-spacing: .12em; }
.zm-sweep-verb h4 { font: 700 22px/1.15 var(--font); color: #fff; margin: 0 0 12px; letter-spacing: -.01em; }
.zm-sweep-verb p  { font: 400 13px/1.55 var(--font); color: var(--text-mute); margin: 0; }
@media (max-width: 900px) { .zm-sweep-pillars, .zm-sweep-verbs { grid-template-columns: 1fr; } }

.zm-sweep-coverage { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 32px; }
.zm-sweep-coverage__yes, .zm-sweep-coverage__no { padding: 28px; border-radius: var(--radius); }
.zm-sweep-coverage__yes { background: var(--green-dim); border: 1px solid rgba(0,185,85,0.32); }
.zm-sweep-coverage__no  { background: var(--bg-2); border: 1px solid var(--line); }
.zm-sweep-coverage h5 { font: 600 11px/1 var(--font); letter-spacing: .14em; text-transform: uppercase; margin: 0 0 16px; }
.zm-sweep-coverage__yes h5 { color: var(--green-bright); }
.zm-sweep-coverage__no  h5 { color: var(--text-mute); }
.zm-sweep-coverage ul { display: flex; flex-direction: column; gap: 12px; }
.zm-sweep-coverage li { font: 400 14px/1.5 var(--font); color: #C9CFCF; padding-left: 24px; position: relative; }
.zm-sweep-coverage__yes li::before { content: ""; position: absolute; left: 0; top: 8px; width: 14px; height: 8px; border-left: 2px solid var(--green-bright); border-bottom: 2px solid var(--green-bright); transform: rotate(-45deg); }
.zm-sweep-coverage__no  li::before { content: ""; position: absolute; left: 4px; top: 9px; width: 10px; height: 2px; background: var(--text-mute); }

.zm-sweep-cashside { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.zm-sweep-cashside h3 { font: 700 32px/1.2 var(--font); letter-spacing: -.012em; color: #fff; margin: 12px 0 16px; text-wrap: balance; }
.zm-sweep-cashside p  { font: 400 16px/1.6 var(--font); color: var(--text-mute); margin: 0; }
.zm-sweep-bar { background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius); padding: 28px; display: flex; flex-direction: column; gap: 14px; }
.zm-sweep-bar__row { display: grid; grid-template-columns: 32px 1fr 90px; gap: 12px; align-items: center; }
.zm-sweep-bar__row > span:first-child { font: 600 11px/1 var(--font); color: var(--text-mute); letter-spacing: .04em; }
.zm-sweep-bar__row > div { height: 18px; background: rgba(255,255,255,0.06); border-radius: 4px; overflow: hidden; position: relative; }
.zm-sweep-bar__row > div span { display: block; height: 100%; background: var(--green); border-radius: 4px; transition: width 600ms; }
.zm-sweep-bar__row > strong { font: 600 13px/1 var(--font); color: #fff; text-align: right; font-variant-numeric: tabular-nums; }
.zm-sweep-bar__row.is-now > strong { color: var(--green-bright); }
.zm-sweep-bar__row.is-now > div span { background: var(--green-bright); }
@media (max-width: 900px) { .zm-sweep-cashside { grid-template-columns: 1fr; gap: 32px; } }

.zm-sweep-hero { position: relative; width: 100%; aspect-ratio: 600 / 440; }
.zm-sweep-hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

.zm-sweep-calc { border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--bg-2); overflow: hidden; }
.zm-sweep-calc__head { padding: 28px 32px; border-bottom: 1px solid var(--line); }
.zm-sweep-calc__head h3 { font: 700 22px/1.2 var(--font); color: #fff; margin: 0 0 6px; }
.zm-sweep-calc__head p  { font: 400 14px/1.5 var(--font); color: var(--text-mute); margin: 0; }
.zm-sweep-calc__rows { display: flex; flex-direction: column; }
.zm-sweep-calc__row { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0; border-bottom: 1px solid var(--line); }
.zm-sweep-calc__row:last-child { border-bottom: 0; }
.zm-sweep-calc__cell { padding: 20px 32px; display: flex; flex-direction: column; gap: 6px; border-right: 1px solid var(--line); }
.zm-sweep-calc__cell:last-child { border-right: 0; }
.zm-sweep-calc__lbl { font: 500 11px/1 var(--font); letter-spacing: .12em; text-transform: uppercase; color: var(--text-mute); }
.zm-sweep-calc__cell strong { font: 700 22px/1.1 var(--font); color: #fff; letter-spacing: -.01em; }
.zm-sweep-calc__cell--hi strong { color: var(--green-bright); }
@media (max-width: 720px) { .zm-sweep-calc__row { grid-template-columns: 1fr; } }

/* ---------- CTA strip (Home) ---------- */
.zm-cta-strip {
  background: linear-gradient(160deg, rgba(14,92,47,0.52) 0%, rgba(5,43,23,0.40) 100%), var(--bg-2) !important;
  border: 1px solid rgba(0,185,85,0.15) !important;
  border-radius: var(--radius-lg);
  color: #fff !important;
  padding: 40px 48px !important;
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px; flex-wrap: wrap;
}
.zm-cta-strip h3 { color: #fff !important; }
.zm-cta-strip p  { color: rgba(255,255,255,0.78) !important; }
.zm-cta-strip__photo { width: 320px; height: 220px; border-radius: var(--radius); overflow: hidden; }
.zm-cta-strip__photo img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- Night band ("Markets don't sleep") — flat photo only, no overlays ---------- */
.zm-night { position: relative; min-height: 520px; overflow: hidden; isolation: isolate; background: #05080b; }
.zm-night__bg {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: 56%; height: 100%;
  object-fit: cover; object-position: 50% 30%;
  z-index: -2;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,0.30) 16%, #000 46%);
          mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,0.30) 16%, #000 46%);
}
.zm-night__shader { display: none; }
.zm-night__overlay { display: none; }
.zm-night__inner { position: relative; z-index: 1; padding: 96px 0; display: flex; flex-direction: column; align-items: flex-start; gap: 16px; }
.zm-night__title { font: 800 56px/1.05 var(--font); letter-spacing: -.024em; color: #fff; margin: 0; max-width: 600px; text-wrap: balance; }
.zm-night__copy  { font: 400 18px/1.55 var(--font); color: #C9CFCF; margin: 0; max-width: 420px; }

/* App-store badge buttons + desktop hover QR popover */
.zm-night__stores { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 28px; }
.zm-store {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  height: 56px; padding: 0 28px;
  border: 1px solid rgba(255,255,255,0.45);
  border-radius: var(--radius-pill);
  background: rgba(0,0,0,0.35);
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
}
.zm-store:hover { background: rgba(255,255,255,0.10); border-color: rgba(255,255,255,0.80); transform: translateY(-1px); }
.zm-store__badge { height: 26px; width: auto; display: block; }
.zm-store__qr {
  position: absolute; left: 50%; bottom: calc(100% + 14px);
  transform: translateX(-50%) translateY(8px);
  background: var(--bg-3); border: 1px solid var(--line-2);
  border-radius: 16px; padding: 14px;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  box-shadow: 0 24px 60px -18px rgba(0,0,0,0.75);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .22s ease, transform .22s ease, visibility .22s;
  z-index: 6;
}
.zm-store__qr img {
  width: 148px; height: 148px; min-width: 148px; max-width: none;
  aspect-ratio: 1 / 1; flex-shrink: 0;
  object-fit: contain; display: block; border-radius: 10px;
}
.zm-store__qr small { font: 600 12px/1.2 var(--font); color: var(--text); white-space: nowrap; }
.zm-store__qr::after {
  content: ""; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  border: 8px solid transparent; border-top-color: var(--bg-3);
}
@media (hover: hover) and (pointer: fine) {
  .zm-store:hover .zm-store__qr,
  .zm-store:focus-within .zm-store__qr {
    opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0);
  }
}
@media (max-width: 720px) {
  .zm-night__title { font-size: 38px; }
  .zm-night__bg {
    width: 100%; object-position: 50% 28%;
    -webkit-mask-image: none; mask-image: none;
  }
  .zm-night__overlay {
    display: block; position: absolute; inset: 0; z-index: -1; pointer-events: none;
    background: linear-gradient(180deg, rgba(5,8,11,0.55) 0%, rgba(5,8,11,0.86) 100%);
  }
}

/* ---------- Hero ambassador (Cafu card, used in Home hero) ---------- */
.zm-hero__preview { position: relative; min-height: 580px; display: flex; align-items: flex-end; overflow: visible; }
/* Full-bleed ambassador photo (P1 look) — bleeds to viewport right edge, fades into page */
.zm-hero__media { position: absolute; top: 0; right: 0; bottom: 0; width: 58%; z-index: 1; overflow: hidden;
  background-image: url(assets/banner/cafu-hero.jpg); background-repeat: no-repeat;
  background-size: cover; background-position: 50% 100%; }
.zm-hero__media-fade {
  position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(to right, var(--bg) 0%, rgba(11,17,16,0.55) 14%, rgba(11,17,16,0) 42%),
    linear-gradient(to bottom, var(--bg) 0%, rgba(11,17,16,0.7) 9%, rgba(11,17,16,0) 32%),
    linear-gradient(to top, rgba(7,12,11,0.4) 0%, rgba(7,12,11,0) 20%);
}
.zm-hero__sig {
  position: absolute; right: 190px; bottom: 30px; z-index: 4;
  display: flex; flex-direction: column; align-items: flex-start;
}
.zm-hero__sig-script { width: 168px; height: auto; margin: 0 0 -8px -150px; opacity: .95; }
.zm-hero__sig-label { display: flex; align-items: center; gap: 12px; }
.zm-hero__sig-slash { width: 17px; height: auto; flex-shrink: 0; }
.zm-hero__sig-name { font: 500 30px/1 var(--font); color: #fff; letter-spacing: -.01em; }
.zm-hero__sig-bar { width: 1px; height: 32px; flex-shrink: 0; background: rgba(255,255,255,0.38); }
.zm-hero__sig-role { display: flex; flex-direction: column; font: 600 11px/1.4 var(--font); letter-spacing: .12em; text-transform: uppercase; color: #E9E1CD; }
.zm-hero__legal { position: absolute; left: 32px; bottom: 26px; z-index: 4; margin: 0; max-width: 200px; font: 500 11px/1.4 var(--font); color: rgba(255,255,255,0.50); }

/* ---------- Hero wrap (Home page top section) ---------- */
.zm-hero__bg { position: absolute; inset: 0; z-index: -1; background:
  radial-gradient(1100px 580px at 78% -10%, rgba(0,185,85,0.18), transparent 60%),
  radial-gradient(700px 420px at 0% 100%, rgba(0,185,85,0.06), transparent 65%); }
.zm-hero__wrap { position: relative; z-index: 3; max-width: 1380px; margin: 0 auto; padding: 0 32px; min-height: 720px; display: flex; align-items: center; }
.zm-hero__split { display: grid; grid-template-columns: 46fr 54fr; gap: 56px; align-items: center; min-height: 540px; }
.zm-hero__lead { display: flex; flex-direction: column; gap: 22px; max-width: 560px; }
.zm-hero__trust { list-style: none; padding: 0; margin: 8px 0 0; display: flex; flex-wrap: wrap; gap: 8px 22px; font: 500 13px/1.4 var(--font); color: var(--text-mute); }
.zm-hero__trust li { position: relative; padding-left: 18px; }
.zm-hero__trust li::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 6px; height: 6px; border-radius: 999px; background: var(--green); }
@media (max-width: 900px) {
  .zm-hero__split { grid-template-columns: 1fr; min-height: 0; }
  .zm-hero__h1 { font-size: 40px; }
  /* Mobile: photo becomes a faint full-width backdrop; label/logos hidden, text stays readable */
  .zm-hero__media { width: 100%; }
  .zm-hero__media-fade { background:
    linear-gradient(to right, var(--bg) 0%, rgba(11,17,16,0.78) 45%, rgba(11,17,16,0.45) 100%),
    linear-gradient(to top, rgba(7,12,11,0.85) 0%, rgba(7,12,11,0.2) 45%); }
  .zm-hero__sig, .zm-hero__legal, .zm-hero__logos { display: none; }
  .zm-hero__wrap { min-height: 520px; }
}

/* ---------- Mega menu (header dropdown) ---------- */
.zm-mega::before { content: ""; position: absolute; left: 0; right: 0; top: -12px; height: 12px; }
.zm-mega {
  position: absolute; top: 72px; left: 0; right: 0;
  background: rgba(11,17,16,0.96); backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
  padding: 32px 0; z-index: 49;
  opacity: 0; pointer-events: none; transform: translateY(-6px);
  transition: all 200ms cubic-bezier(.2,0,0,1);
}
.zm-mega.is-open { opacity: 1; pointer-events: auto; transform: translateY(0); }
.zm-mega__inner { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; max-width: 1380px; margin: 0 auto; padding: 0 32px; }
.zm-mega__col h5 { font: 600 11px/1 var(--font); letter-spacing: .14em; text-transform: uppercase; color: var(--green); margin: 0 0 14px; }
.zm-mega__link { display: block; padding: 8px 0; font: 500 15px/1.3 var(--font); color: #fff; cursor: pointer; transition: color 160ms; }
.zm-mega__link span { display: block; font-weight: 400; font-size: 13px; color: var(--text-mute); margin-top: 2px; }
.zm-mega__link:hover { color: var(--green-bright); }
.zm-mega__col[style] { background: rgba(255,255,255,0.04) !important; }

/* ---------- Mobile drawer ---------- */
.zm-burger { display: none; }
@media (max-width: 960px) {
  .zm-header__nav { display: none; }
  .zm-burger { display: inline-flex; }
}
.zm-drawer { position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 100; opacity: 0; pointer-events: none; transition: opacity 200ms; }
.zm-drawer.is-open { opacity: 1; pointer-events: auto; }
.zm-drawer__panel { position: absolute; top: 0; right: 0; bottom: 0; width: 88%; max-width: 380px; background: var(--bg-2); color: #fff; transform: translateX(100%); transition: transform 320ms cubic-bezier(.3,0,0,1); display: flex; flex-direction: column; }
.zm-drawer.is-open .zm-drawer__panel { transform: translateX(0); }
.zm-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--line); }
.zm-drawer__body { flex: 1; overflow-y: auto; padding: 16px 0; }
.zm-drawer__sect { padding: 8px 0; border-bottom: 1px solid var(--line); }
.zm-drawer__sect h5 { font: 600 11px/1 var(--font); letter-spacing: .12em; text-transform: uppercase; color: var(--green); margin: 12px 24px 6px; }
.zm-drawer__link { display: block; padding: 12px 24px; font: 500 16px/1.3 var(--font); color: #fff; cursor: pointer; }
.zm-drawer__link:hover { background: rgba(255,255,255,0.06); }
.zm-drawer__foot { padding: 20px 24px; border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 8px; }

/* ---------- Header refinements (additions) ---------- */
.zm-header__brand { display: inline-flex; align-items: center; gap: 14px; height: 56px; flex-shrink: 0; }
.zm-header__logo { display: block; width: auto; max-width: none; flex-shrink: 0; }
.zm-header__logo--zero    { height: 36px; }
.zm-header__logo--levycam { height: 52px; opacity: 0.9; }
.zm-header__logo { filter: brightness(0) invert(1); }
.zm-header__brand-divider { display: inline-block; width: 1px; height: 32px; background: rgba(255,255,255,0.22); flex-shrink: 0; }
/* Header inner row needs enough height for the larger brand */
.zm-header__inner { min-height: 80px; }
.zm-header__actions { display: flex; align-items: center; gap: 10px; }
.zm-header__lang { display: inline-flex; gap: 2px; padding: 3px; background: rgba(255,255,255,0.06); border-radius: var(--radius-pill); }
.zm-header__lang button { background: transparent; border: 0; cursor: pointer; padding: 6px 12px; border-radius: var(--radius-pill); font: 700 12px/1 var(--font); color: var(--text-mute); }
.zm-header__lang button.is-active { background: rgba(255,255,255,0.14); color: #fff; }
.zm-navlink { padding: 8px 14px; border-radius: var(--radius-pill); font: 500 14px/1 var(--font); color: #C9CFCF; transition: all 160ms; cursor: pointer; display: inline-flex; align-items: center; gap: 4px; background: transparent; border: 0; }
.zm-navlink:hover { background: rgba(255,255,255,0.06); color: #fff; }
.zm-navlink.is-active { background: rgba(255,255,255,0.10); color: #fff; }

/* ---------- Search bar (Help centre) ---------- */
.zm-search { display: flex; gap: 8px; align-items: center; background: rgba(255,255,255,0.04); border: 1px solid var(--line); border-radius: var(--radius-pill); padding: 8px 8px 8px 22px; min-width: min(560px, 100%); }
.zm-search .ph { color: var(--text-mute); font-size: 18px; }
.zm-search input { flex: 1; background: transparent; border: 0; outline: 0; color: #fff; font: 500 15px/1 var(--font); }
.zm-search input::placeholder { color: var(--text-faint); }

/* ---------- Fine print ---------- */
.zm-fineprint { font: 400 12px/1.55 var(--font); color: var(--text-faint); }

/* ---------- Legal page (Legal route) ---------- */
.zm-legalpage { display: grid; grid-template-columns: 260px 1fr; gap: 64px; align-items: start; padding: 56px 0 96px; }
.zm-legalpage__nav { position: sticky; top: 88px; display: flex; flex-direction: column; gap: 4px; }
.zm-legalpage__nav-eyebrow { font: 600 10px/1 var(--font); letter-spacing: .12em; text-transform: uppercase; color: var(--text-mute); margin: 0 0 12px; padding-left: 12px; }
.zm-legalpage__nav a { display: block; padding: 10px 12px; border-radius: 8px; font: 500 13px/1.35 var(--font); color: #C9CFCF; border-left: 2px solid transparent; transition: all 160ms; }
.zm-legalpage__nav a:hover { background: rgba(255,255,255,0.04); color: var(--green-bright); }
.zm-legalpage__nav a.is-active { background: var(--green-dim); color: var(--green-bright); border-left-color: var(--green); }
.zm-legalpage__main { display: flex; flex-direction: column; gap: 96px; max-width: 760px; }
.zm-legalpage__section { scroll-margin-top: 88px; }
.zm-legalpage__section-eyebrow { font: 600 11px/1 var(--font); letter-spacing: .14em; text-transform: uppercase; color: var(--green); margin: 0 0 14px; }
.zm-legalpage__section-h { font: 700 28px/1.2 var(--font); letter-spacing: -.01em; color: #fff; margin: 0 0 20px; text-wrap: balance; }
.zm-legalpage__section-anchor { display: inline-flex; align-items: center; gap: 4px; font: 500 12px/1 var(--font); color: var(--text-mute); margin-bottom: 24px; cursor: pointer; }
.zm-legalpage__section-anchor:hover { color: var(--green-bright); }
.zm-legalpage__section .zm-legal__p { font: 400 16px/1.55 var(--font); color: #C9CFCF; margin: 0 0 16px; }
.zm-legalpage__section .zm-legal__list { padding-left: 22px; margin: 4px 0 16px; color: #C9CFCF; font: 400 16px/1.55 var(--font); }
.zm-legalpage__section .zm-legal__list li { margin-bottom: 6px; }
.zm-legalpage__section .zm-legal__links { display: flex; flex-direction: column; gap: 8px; padding: 0; margin: 12px 0 0; }
.zm-legalpage__section .zm-legal__links a { display: inline-flex; align-items: center; gap: 8px; font: 500 14px/1.4 var(--font); color: var(--green-bright); }
.zm-legalpage__docs { padding: 56px 0 96px; border-top: 1px solid var(--line); }
.zm-legalpage__docs h3 { font: 700 22px/1.2 var(--font); color: #fff; margin: 0 0 24px; }
.zm-legalpage__doc { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border: 1px solid var(--line); border-radius: 12px; transition: background 160ms, border-color 160ms; margin-bottom: 8px; background: var(--bg-2); }
.zm-legalpage__doc:hover { background: var(--green-dim); border-color: rgba(0,185,85,0.32); }
.zm-legalpage__doc-l { display: flex; align-items: center; gap: 14px; min-width: 0; }
.zm-legalpage__doc-l i { font-size: 20px; color: var(--green-bright); flex-shrink: 0; }
.zm-legalpage__doc-l span { font: 500 14px/1.3 var(--font); color: #fff; }
.zm-legalpage__doc-meta { font: 400 12px/1 var(--font); color: var(--text-mute); }
@media (max-width: 960px) {
  .zm-legalpage { grid-template-columns: 1fr; gap: 32px; }
  .zm-legalpage__nav { position: static; flex-direction: row; flex-wrap: wrap; }
  .zm-legalpage__nav-eyebrow { display: none; }
  .zm-legalpage__nav a { padding: 8px 14px; border-radius: var(--radius-pill); border-left: 0; background: var(--bg-2); }
  .zm-legalpage__main { gap: 56px; }
}

/* ---------- Terminal mock (used as hero art for Invest pages) ---------- */
.zm-term { background: var(--bg-deep); border-radius: var(--radius); border: 1px solid var(--line); overflow: hidden; color: var(--text); font-variant-numeric: tabular-nums; }
.zm-term__chrome { display: flex; align-items: center; gap: 8px; padding: 12px 16px; background: var(--bg-2); border-bottom: 1px solid var(--line); }
.zm-term__dots { display: flex; gap: 6px; }
.zm-term__dots span { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,0.18); }
.zm-term__title { font: 500 12px/1 var(--font); color: var(--text-mute); flex: 1; text-align: center; }
.zm-term__body { padding: 16px; display: grid; grid-template-columns: 200px 1fr 180px; gap: 12px; }
.zm-term__panel { background: rgba(255,255,255,0.03); border: 1px solid var(--line); border-radius: 8px; padding: 12px; }
.zm-term__head { font: 600 10px/1 var(--font); letter-spacing: .12em; text-transform: uppercase; color: var(--text-faint); margin-bottom: 12px; }
.zm-term__row { display: flex; align-items: center; justify-content: space-between; padding: 6px 0; font: 500 12px/1 var(--font); border-bottom: 1px solid rgba(255,255,255,0.04); }
.zm-term__row:last-child { border-bottom: 0; }
.zm-term__row .sym { font-weight: 700; color: #fff; }
.zm-term__row .price { color: #C9CFCF; }
.zm-term__row .chg.up { color: var(--green-bright); }
.zm-term__row .chg.down { color: var(--error); }
.zm-term__chart { background: rgba(255,255,255,0.02); border: 1px solid var(--line); border-radius: 8px; padding: 16px; min-height: 260px; display: flex; flex-direction: column; gap: 10px; }
.zm-term__chart-head { display: flex; align-items: center; justify-content: space-between; }
.zm-term__chart-sym { font: 600 12px/1 var(--font); color: var(--text-mute); }
.zm-term__chart-price { font: 700 20px/1 var(--font); color: #fff; font-variant-numeric: tabular-nums; }
.zm-term__chart-svg { width: 100%; }
.zm-term__book { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 2px; font: 500 11px/1 var(--font); align-items: center; }
.zm-term__book-row { padding: 4px 0; }
.zm-term__book-row.ask { color: var(--error); }
.zm-term__book-row.bid { color: var(--green-bright); text-align: right; }
.zm-term__book-px { color: var(--text-mute); text-align: center; }

/* ---------- Zero App feature stripes ---------- */
.zm-zafeat { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; padding: 64px 0; border-bottom: 1px solid var(--line); }
.zm-zafeat:last-child { border-bottom: 0; }
.zm-zafeat--reverse { direction: rtl; }
.zm-zafeat--reverse > * { direction: ltr; }
.zm-zafeat__title { font: 800 36px/1.1 var(--font); letter-spacing: -.018em; color: #fff; margin: 0 0 16px; }
.zm-zafeat__copy  { font: 400 16px/1.55 var(--font); color: var(--text-mute); margin: 0; }
.zm-zafeat__media { display: flex; justify-content: center; }

/* ---------- Prods (Home tabs — vertical sidebar of 4 equal-width pills) ---------- */
.zm-prods { display: grid; grid-template-columns: 220px 1fr; gap: 24px; align-items: stretch; }
.zm-prods__tabs {
  display: flex; flex-direction: column; gap: 10px;
  background: transparent;
  align-items: stretch;
}
.zm-prods__tab {
  height: 52px; padding: 0 18px; border-radius: var(--radius-pill);
  border: 1px solid var(--line); background: var(--bg-2); color: #C9CFCF;
  font: 600 13px/1 var(--font);
  cursor: pointer; transition: background 160ms, color 160ms, border-color 160ms;
  display: flex; align-items: center; justify-content: center;
  width: 100%;
  text-align: center;
}
.zm-prods__tab:hover { background: var(--bg-3); color: #fff; }
.zm-prods__tab.is-active { background: var(--green); border-color: var(--green); color: var(--color-on-primary); }

/* Override wework's 2-col grid panel → clean vertical stack, fixed height across tabs */
.zm-prods__panel {
  display: flex !important;
  flex-direction: column !important;
  grid-template-columns: none !important;
  gap: 24px !important;
  padding: 32px !important;
  min-height: 420px !important;     /* tight, uniform across all 4 tabs */
  overflow: hidden !important;
  box-sizing: border-box !important;
}
.zm-prods__head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 24px; flex-wrap: wrap; flex-shrink: 0;
}
.zm-prods__head > div:first-child { max-width: 60%; }
.zm-prods__heading { font: 700 26px/1.15 var(--font); color: #fff; margin: 0; letter-spacing: -.012em; }
.zm-prods__sub { font: 400 15px/1.5 var(--font); color: var(--text-mute); margin: 8px 0 0; }

/* Symbol grid — 6 equal cards, contained inside panel, names can wrap */
.zm-syms {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));   /* minmax(0,1fr) = no overflow */
  gap: 10px;
  flex-shrink: 0;
}
.zm-sym {
  background: rgba(255,255,255,0.02); border: 1px solid var(--line);
  border-radius: 14px; padding: 14px 12px;
  display: flex; flex-direction: column; align-items: flex-start; gap: 6px;
  min-height: 108px;                  /* equal height per card */
  height: 100%;
  min-width: 0;
  overflow: hidden;
  transition: border-color 160ms, transform 160ms;
}
.zm-sym:hover { border-color: rgba(0,185,85,0.32); transform: translateY(-2px); }
.zm-sym__icon { width: 32px; height: 32px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; overflow: hidden; flex-shrink: 0; }
.zm-sym__icon-img { width: 18px; height: 18px; }
.zm-sym__icon--raw .zm-sym__icon-img { width: 100%; height: 100%; }
.zm-sym__icon-letter { font: 700 13px/1 var(--font); color: #fff; }
.zm-sym__sym { font: 700 13px/1 var(--font); color: #fff; font-variant-numeric: tabular-nums; }
.zm-sym__name {
  font: 400 11px/1.35 var(--font); color: var(--text-mute);
  white-space: normal;                /* allow wrap on long names */
  overflow: hidden;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  max-width: 100%;
  word-break: break-word;
}

/* Stats row — pinned to bottom of panel, 3 even cols, no wrap on numbers */
.zm-prods__stats {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px;
  padding-top: 24px; border-top: 1px solid var(--line); margin-top: auto;
  flex-shrink: 0;
}
.zm-prods__stats > div { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.zm-prods__stat-num {
  font: 700 24px/1.15 var(--font); color: #fff;
  letter-spacing: -.012em; font-variant-numeric: tabular-nums;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.zm-prods__stat-lbl { font: 400 13px/1.4 var(--font); color: var(--text-mute); }

/* Cash tab — compact: smaller rate number, smaller phone, fits the 420px panel */
.zm-prods__cash {
  display: grid; grid-template-columns: 1fr 320px; gap: 40px;
  align-items: center; flex-shrink: 0; min-height: 0;
}
.zm-cash-left { display: flex; flex-direction: column; gap: 26px; }
.zm-prods__cash-rate { display: flex; align-items: baseline; gap: 8px; }
.zm-prods__cash-rate-num {
  font: 700 60px/1 var(--font); letter-spacing: -.03em;
  color: var(--green-bright); font-variant-numeric: tabular-nums;
}
.zm-prods__cash-rate-tag { font: 600 16px/1 var(--font); color: var(--text-mute); }

/* Three gold feature rows (Earn more / Invest instantly / Stay automatic) */
.zm-cash-feats { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 16px; }
.zm-cash-feats li {
  display: flex; gap: 14px; align-items: center;
}
.zm-cash-feats img {
  width: 44px; height: 44px; flex-shrink: 0; object-fit: contain;
  filter: drop-shadow(0 4px 10px rgba(214,176,84,0.25));
}
.zm-cash-feats strong {
  display: block; font: 700 14px/1.3 var(--font); color: var(--text);
  letter-spacing: -.005em;
}
.zm-cash-feats span {
  display: block; font: 400 13px/1.4 var(--font); color: var(--text-mute);
  margin-top: 2px;
}

/* 3D composition art — 4 layers, each sliding up from outside the container.
 * All 4 share params (delay 0ms, duration 800ms, ease-in, forwards).
 * Different starting translateY makes layer 1 the slowest perceived mover
 * (longest distance), creating layered progressive build-up. */
.zm-cash-art {
  position: relative; width: 100%; max-width: 320px;
  aspect-ratio: 688 / 940;
  margin: 0 auto;
  overflow: hidden;        /* clip layers that start outside */
}
.zm-cash-art__layer {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; object-position: center;
  opacity: 0;
  animation-duration: 800ms;
  animation-timing-function: ease-in;
  animation-fill-mode: forwards;
  animation-delay: 0ms;
  will-change: transform, opacity;
}
.zm-cash-art__layer--1 { z-index: 1; animation-name: zm-cash-rise-1; }
.zm-cash-art__layer--2 { z-index: 2; animation-name: zm-cash-rise-2; }
.zm-cash-art__layer--3 { z-index: 3; animation-name: zm-cash-rise-3; }
.zm-cash-art__layer--4 { z-index: 4; animation-name: zm-cash-rise-4; }

@keyframes zm-cash-rise-1 { from { transform: translateY(140%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes zm-cash-rise-2 { from { transform: translateY(105%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes zm-cash-rise-3 { from { transform: translateY( 70%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes zm-cash-rise-4 { from { transform: translateY( 35%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

@media (prefers-reduced-motion: reduce) {
  .zm-cash-art__layer { animation: none; opacity: 1; transform: none; }
}

@media (max-width: 1080px) {
  .zm-syms { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .zm-prods__cash { grid-template-columns: 1fr; }
  .zm-prods__cash-rate-num { font-size: 64px; }
}
@media (max-width: 900px) {
  .zm-prods { grid-template-columns: 1fr; }
  .zm-prods__head > div:first-child { max-width: 100%; }
  .zm-prods__panel { min-height: 0 !important; }
}
@media (max-width: 560px) {
  .zm-syms { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .zm-prods__stats { grid-template-columns: 1fr; }
}

@media (max-width: 1080px) {
  .zm-syms { grid-template-columns: repeat(3, 1fr); }
  .zm-prods__cash { grid-template-columns: 1fr; }
  .zm-prods__cash-rate-num { font-size: 64px; }
}
@media (max-width: 900px) {
  .zm-prods { grid-template-columns: 1fr; }
  .zm-prods__head > div:first-child { max-width: 100%; }
}
@media (max-width: 560px) {
  .zm-syms { grid-template-columns: repeat(2, 1fr); }
  .zm-prods__stats { grid-template-columns: 1fr; }
}
.zm-prods__heading { font: 700 28px/1.15 var(--font); letter-spacing: -.012em; margin: 0; color: #fff; }
.zm-prods__sub { font: 400 15px/1.55 var(--font); color: var(--text-mute); margin: 8px 0 0; max-width: 540px; }
.zm-prods__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; padding-top: 24px; border-top: 1px solid var(--line); }
.zm-prods__note { margin: 16px 0 0; font: 400 12px/1.5 var(--font); color: var(--text-faint); }
.zm-prods__stat-num { font: 700 28px/1 var(--font); color: #fff; font-variant-numeric: tabular-nums; }
.zm-prods__stat-lbl { font: 400 13px/1.4 var(--font); color: var(--text-mute); margin-top: 6px; }
.zm-prods__cash { display: grid; grid-template-columns: minmax(200px, 1fr) 2fr; gap: 32px; align-items: end; padding: 24px 0; }
.zm-prods__cash-rate { display: flex; align-items: baseline; gap: 6px; }
.zm-prods__cash-rate-num { font: 700 96px/.95 var(--font); letter-spacing: -.03em; color: var(--green-bright); }
.zm-prods__cash-rate-tag { font: 600 16px/1 var(--font); color: var(--text-mute); }
.zm-prods__cash-phone, .zm-prods__cash-art { width: 100%; height: 220px; }
@media (max-width: 900px) {
  .zm-prods { grid-template-columns: 1fr; }
  .zm-prods__cash { grid-template-columns: 1fr; }
  .zm-prods__cash-rate-num { font-size: 72px; }
}

/* ---------- Plan poweredby (existing JSX has this) ---------- */
.zm-plan__poweredby {
  display: flex; align-items: center; gap: 7px;
  font: 400 11px/1 var(--font); color: var(--text-faint);
  padding-top: 16px; margin-top: auto;
}
.zm-plan__pb-logo { height: 22px; width: auto; display: block; opacity: .9; }
.zm-plan__tag  { font: 400 14px/1.5 var(--font); color: var(--text-mute); margin: 0; }

/* ---------- Tweaks panel (live editor — keep visible but unobtrusive on dark) ---------- */
.zm-tweaks { position: fixed; top: 0; right: 0; bottom: 0; width: 320px; background: rgba(11,17,16,0.96); border-left: 1px solid var(--line); transform: translateX(100%); transition: transform 200ms; z-index: 200; color: var(--text); padding: 24px; overflow-y: auto; }
.zm-tweaks.is-open { transform: translateX(0); }
.zm-tweaks__toggle { position: fixed; bottom: 24px; right: 24px; width: 48px; height: 48px; border-radius: 999px; background: var(--green); color: var(--color-on-primary); border: 0; z-index: 199; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; box-shadow: 0 8px 24px -8px rgba(0,185,85,0.6); }
.zm-tweaks__panel { background: rgba(11,17,16,0.96); color: #fff; }

/* ---------- Hero floating tech-stock glass bubbles (Home hero right column) ---------- */
.zm-hero__logos {
  position: absolute; inset: 0;
  pointer-events: none;            /* wrapper transparent; logos opt back in */
  perspective: 900px;
  z-index: 4;                      /* sits above card bg, below Cafu portrait (which is z:1 inside card) */
}
.zm-hero__logo {
  --rx: 0deg; --ry: 0deg;
  --mx: 30%; --my: 30%;
  position: absolute;
  width: 64px; height: 64px;
  border-radius: 18px;
  display: grid; place-items: center;
  background:
    radial-gradient(120% 120% at var(--mx) var(--my), rgba(255,255,255,0.28), rgba(255,255,255,0.06) 60%),
    linear-gradient(135deg, rgba(255,255,255,0.16) 0%, rgba(255,255,255,0.04) 100%);
  -webkit-backdrop-filter: blur(14px) saturate(160%);
          backdrop-filter: blur(14px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.22);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.32),
    inset 0 -1px 0 rgba(0,0,0,0.20),
    0 10px 28px rgba(0,0,0,0.40);
  pointer-events: auto;
  cursor: pointer;
  transform-style: preserve-3d;
  opacity: 0;
  transform: translateY(22px) scale(0.55);
  filter: blur(10px);
  animation: zm-logo-reveal 1.05s cubic-bezier(.2,.75,.2,1.05) forwards;
  transition:
    transform 0.45s cubic-bezier(.18,.85,.25,1.05),
    box-shadow 0.45s ease,
    background 0.45s ease,
    border-color 0.45s ease;
  will-change: transform, opacity, filter;
}
.zm-hero__logo img {
  width: 78%; height: 78%; display: block;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.45));
  transform: translateZ(20px);          /* slight pop-out depth for 3D */
  transition: transform 0.45s ease;
  pointer-events: none;
}

/* "Ritual" entrance — overshoots with a soft blur-to-focus + lift */
@keyframes zm-logo-reveal {
  0%   { opacity: 0; transform: translateY(28px) scale(0.50); filter: blur(12px); }
  45%  { opacity: 0.7;                          filter: blur(3px); }
  72%  { transform: translateY(-4px) scale(1.08); filter: blur(0); }
  100% { opacity: 1; transform: translateY(0) scale(1);    filter: blur(0); }
}

/* Cursor-tracked 3D tilt; --rx / --ry are set inline via onMouseMove */
.zm-hero__logo:hover {
  transform: rotateX(var(--rx)) rotateY(var(--ry)) translateZ(18px) scale(1.06);
  background:
    radial-gradient(120% 120% at var(--mx) var(--my), rgba(255,255,255,0.45), rgba(255,255,255,0.08) 62%),
    linear-gradient(135deg, rgba(255,255,255,0.22) 0%, rgba(255,255,255,0.06) 100%);
  border-color: rgba(255,255,255,0.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.55),
    inset 0 -1px 0 rgba(0,0,0,0.20),
    0 26px 50px rgba(0,0,0,0.55),
    0 0 36px rgba(0,185,85,0.30);
}
.zm-hero__logo:hover img { transform: translateZ(32px) scale(1.04); }

/* Positions — arranged as a constellation around the Cafu card */
/* Constellation around the Cafu card — 3 per side, all over photo/empty area, clear of text */
.zm-hero__logo--amazon { top:  14%; left:  12%; width: 78px; height: 78px; }
.zm-hero__logo--google { top:  18%; right: 33%; width: 74px; height: 74px; }
.zm-hero__logo--ms     { top:  40%; left:  15%; width: 78px; height: 78px; }
.zm-hero__logo--nvidia { top:  38%; right: 20%; width: 74px; height: 74px; }
.zm-hero__logo--tesla  { top:  60%; left:   7%; width: 74px; height: 74px; }
.zm-hero__logo--aapl   { top:  56%; right: 24%; width: 74px; height: 74px; }
/* Smaller windows: drop the floating logos lower so they ring Cafu, not the empty top */
@media (max-width: 1400px) {
  .zm-hero__logo--amazon { top: 28%; }
  .zm-hero__logo--google { top: 32%; }
  .zm-hero__logo--ms     { top: 52%; }
  .zm-hero__logo--nvidia { top: 50%; }
  .zm-hero__logo--tesla  { top: 74%; }
  .zm-hero__logo--aapl   { top: 70%; }
}

@media (prefers-reduced-motion: reduce) {
  .zm-hero__logo {
    animation: none; opacity: 1; transform: none; filter: none;
  }
  .zm-hero__logo:hover { transform: scale(1.04); }
}
@media (max-width: 900px) {
  /* keep them as small decorative chips on mobile; reduce count visually */
  .zm-hero__logos { display: none; }
}

/* ============ HOME EXPLORER — gold cash card (Figma) — appended last to win over legacy blocks ============ */
:root { --gold: #E0BD6E; }
.zm-prods { grid-template-columns: 300px 1fr !important; }
.zm-prods__tabs { gap: 12px !important; }
.zm-prods .zm-prods__tab {
  height: auto !important; padding: 16px 20px !important; border-radius: 16px !important;
  border: 1px solid transparent !important; background: transparent !important; color: #fff !important;
  display: flex !important; flex-direction: column !important; gap: 4px !important;
  align-items: flex-start !important; justify-content: flex-start !important; text-align: left !important;
}
.zm-prods .zm-prods__tab:hover { background: rgba(255,255,255,0.03) !important; }
.zm-prods .zm-prods__tab.is-active { background: rgba(0,185,85,0.08) !important; border-color: var(--green) !important; color: #fff !important; }
.zm-prods .zm-prods__tab[data-key="cash"].is-active { background: rgba(224,189,110,0.06) !important; border-color: var(--gold) !important; }
.zm-prods__tab-label { font: 700 22px/1.2 var(--font); color: #fff; letter-spacing: -.01em; }
.zm-prods__tab-sub { font: 400 14px/1.35 var(--font); color: var(--text-mute); }

.zm-prods__gold { color: var(--gold); }
.zm-prods__panel.is-cash .zm-btn--text,
.zm-prods__panel.is-cash .zm-btn--text-dark { color: var(--gold); }
.zm-prods__panel { min-width: 0 !important; }
.zm-prods__panel.is-cash .zm-prods__cash {
  display: grid !important; grid-template-columns: minmax(0, 1fr) 300px !important; gap: 36px !important;
  grid-template-rows: 1fr !important;
  align-items: start !important; padding: 0 !important;
  position: relative !important; margin-top: 24px;
  flex: 1 1 0 !important; min-height: 0 !important;   /* basis 0 so grid fills only free space; pins card to the 420px US ETFs height */
}
.zm-prods__panel.is-cash .zm-cash-feats { list-style: none; padding: 0; margin: 30px 0 0; display: flex; flex-direction: column; gap: 16px; max-width: 460px; align-self: start; }
.zm-prods__panel.is-cash .zm-cash-feats li { display: flex; gap: 14px; align-items: flex-start; }
.zm-prods__panel.is-cash .zm-cash-feats i { font-size: 22px; line-height: 1.45; color: var(--gold); flex-shrink: 0; }
.zm-prods__panel.is-cash .zm-cash-feats p { margin: 0; font: 400 14px/1.5 var(--font); color: var(--text-mute); }
.zm-prods__panel.is-cash .zm-cash-feats strong { display: inline; color: #fff; font-weight: 700; }

/* Line-art illustration — full composite, bottom-aligned with the bullets; rises in */
.zm-prods__panel.is-cash { gap: 0 !important; }
.zm-prods__panel.is-cash .zm-prods__stats { margin-top: 0 !important; }
/* Illustration bottom-aligned within the grown grid so its bottom sits flush on the
 * stats divider; the grid fills the panel so the card matches the US ETFs height. */
.zm-prods__panel.is-cash .zm-cash-art {
  align-self: end; justify-self: end;
  width: 250px; max-width: 250px; aspect-ratio: auto !important; height: auto; margin: 0;
  display: flex; align-items: flex-end; justify-content: flex-end;
}
.zm-cash-illus {
  width: 100%; height: auto; display: block;
  animation: zm-cash-rise 900ms cubic-bezier(.2,.7,.2,1) both;
}
@keyframes zm-cash-rise { from { transform: translateY(40px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@media (prefers-reduced-motion: reduce) { .zm-cash-illus { animation: none; } }
/* Cash subtext on one line (matches Figma) */
.zm-prods__panel.is-cash .zm-prods__head > div:first-child { max-width: 100%; }
.zm-prods__panel.is-cash .zm-prods__sub { white-space: nowrap; }
