/**
 * Rask public site primitives
 *
 * Purpose:
 * - keep public pages token-first
 * - provide a reusable editorial/trust layer for rask.au
 * - distinguish public marketing surfaces from the calmer app shell
 */

:root {
  /*
   * Font families + public-site type scale + 8-tier semantic colour system
   * live in rask-tokens.css (generated from frontend/lib/design-tokens.ts →
   * publicSiteTypographyTokens). Don't redefine --font-display / --font-body
   * here — keep the token file as the single source so we don't drift.
   * Figma "Typography - Public Site" node 2138:8339.
   * Spec: docs/code-docs/frontend/design-system/rask-au-public-design-system.md
   */

  /* Page-level type colours alias the canonical light-theme tier tokens. */
  --rask-heading: var(--public-color-text-primary);
  --rask-text: var(--public-color-text-tertiary);
  --rask-muted: var(--public-color-text-quaternary);
  --rask-border-soft: color-mix(in srgb, var(--neutral-200) 58%, transparent);
  --rask-border-strong: color-mix(in srgb, var(--rask-blue) 12%, transparent);
  --rask-surface: var(--rask-white);
  --rask-surface-soft: color-mix(in srgb, var(--rask-white) 72%, var(--neutral-100));
  --rask-surface-accent: color-mix(in srgb, var(--info-50) 68%, var(--rask-white));
  --rask-surface-warm: color-mix(in srgb, var(--warning-50) 72%, var(--rask-white));

  --rask-public-radius-button: var(--radius-button-cta);
  --rask-public-radius-control: var(--radius-control-pill);
  --rask-public-radius-field: var(--radius-field-pill);
  --rask-public-radius-field-multiline: var(--radius-field-multiline);
  --rask-public-radius-card: 18px;
  --rask-public-radius-panel: 26px;
  --rask-public-radius-hero: 30px;
  --rask-public-shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --rask-public-shadow-md: 0 14px 40px color-mix(in srgb, var(--public-color-text-primary) 10%, transparent);
  --rask-public-shadow-lg: 0 24px 60px color-mix(in srgb, var(--public-color-text-primary) 13%, transparent);
  --rask-public-section-gap: clamp(4.5rem, 7vw, 7rem);
  /* Per Figma header annotation: 1440px page container, 1420px section, 32px padding */
  --rask-public-container-width: 1420px;
  --rask-public-reading-width: 840px;
  --rask-global-header-height: 81px;

  --membership-premium-ink: #191722;
  --membership-premium-panel: #2B2932;
  --membership-premium-wine: #410016;
  --membership-premium-purple: #C3AAF5;
  --membership-premium-lavender: #ECE9FF;
  --membership-premium-cream: #FFFAF0;
  --membership-premium-stat: #F1E5CD;
  --membership-premium-copy: #4A4A4A;
  --membership-premium-subheading: #333333;
  --membership-premium-supporting: #6B6B6B;
  --membership-premium-heading: #111111;
  --membership-premium-action-ink: #191919;
  --membership-premium-action-border: #033B21;
  /*
   * Tier accent palette per Figma node 2091:9191 (Free landing page,
   * May 2026). Free has flipped from the legacy light-blue palette
   * (accent #B8D6EE / surface #E9F6FF / ink #023057) to a maroon-on-yellow
   * combination — the maroon `--membership-tier-free-accent` is the active
   * tier-pill background and the primary CTA fill, the yellow
   * `--membership-tier-free-surface` is the hero panel surface, and the
   * cream `--membership-tier-free-ink` is the colour the maroon prints
   * back onto (active pill text, decoration accents).
   */
  --membership-tier-free-accent: #410016;
  --membership-tier-free-surface: #EADE8A;
  --membership-tier-free-ink: #EADE8A;
  --membership-tier-pro-accent: #FF9676;
  --membership-tier-pro-surface: #FFF0FA;
  --membership-tier-pro-ink: #410016;
  --membership-tier-super-accent: #F4D876;
  --membership-tier-super-surface: color-mix(in srgb, var(--membership-tier-super-accent) 20%, var(--membership-premium-cream));
  --membership-tier-super-ink: #191919;
  --membership-tier-ultra-accent: #C3AAF5;
  --membership-tier-ultra-surface: #E9E9FF;
  --membership-tier-ultra-badge: #C7C6FF;
  --membership-tier-ultra-ink: #410016;
  --membership-annotation-accent: #BC31EA;
  --membership-annotation-surface: #F1ECFF;
  --membership-premium-glow: 0 0 7px 2px color-mix(in srgb, var(--membership-premium-purple) 76%, transparent);
  --membership-premium-inner-glow: inset 0 2px 50px color-mix(in srgb, var(--membership-premium-purple) 20%, transparent);
}

* {
  box-sizing: border-box;
}

html,
body {
  height: 100%;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--rask-bg);
  color: var(--rask-text);
  /* Body Default line-height per spec (was 1.6). */
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
}

main {
  display: block;
}

.font-display {
  font-family: var(--font-display);
}

.rask-public-main {
  overflow-x: clip;
}

/*
 * The previous era had a `.mv3-page .rask-site-*` override block here that
 * forced a dark header (membership-premium-ink), inverted the logo to white,
 * stripped the Login surface, and inverted the Join CTA — for pages whose body
 * carried `mv3-page` (the homepage, /ultra, every /membership/**).
 *
 * Deleted in the post-spec-v2 cleanup. The canonical header (Figma node
 * 2088:8954) is paper #FFFAF0 on every page — no per-body-class chrome
 * variants. If a page wants a dark hero band immediately under the header,
 * that's a section-level surface concern, not a header concern.
 */

.mv3-container {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 clamp(1.25rem, 4vw, 2rem);
}

.mv3-kicker {
  margin: 0;
  color: var(--mv3-accent, var(--membership-premium-purple));
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.mv3-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.35rem;
  padding: 0.95rem 1.35rem;
  border-radius: var(--rask-public-radius-button);
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
  text-decoration: none;
  transition: opacity 0.2s ease, transform 0.2s ease, background 0.2s ease;
}

.mv3-btn:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

.mv3-btn--primary {
  background: var(--mv3-accent, var(--membership-premium-purple));
  color: var(--mv3-accent-ink, var(--membership-premium-wine));
  box-shadow: 0 12px 32px color-mix(in srgb, var(--mv3-accent, var(--membership-premium-purple)) 25%, transparent);
}

.mv3-btn--secondary {
  border: 1px solid color-mix(in srgb, var(--rask-white) 22%, transparent);
  color: var(--rask-white);
}

.rask-public-container,
.container {
  width: min(var(--rask-public-container-width), 100%);
  margin: 0 auto;
  padding-inline: clamp(1.25rem, 3vw, 2rem);
}

.rask-public-container--narrative {
  width: min(var(--rask-public-reading-width), 100%);
}

.rask-public-section,
.section {
  position: relative;
  padding-block: var(--rask-public-section-gap);
}

.rask-public-band {
  position: relative;
  isolation: isolate;
}

.rask-public-band--paper {
  background: var(--rask-bg);
}

.rask-public-band--ice {
  background: color-mix(in srgb, var(--neutral-100) 74%, var(--rask-bg));
}

.rask-public-band--lavender {
  background: color-mix(in srgb, var(--info-50) 58%, var(--rask-bg));
}

.rask-public-band--warm {
  background: color-mix(in srgb, var(--warning-50) 60%, var(--rask-bg));
}

.rask-public-band--peach {
  background: color-mix(in srgb, var(--rask-peach) 52%, var(--rask-bg));
}

.rask-public-band--ink {
  background: var(--rask-primary);
  color: color-mix(in srgb, var(--rask-white) 90%, transparent);
}

.rask-public-band--ink .rask-public-kicker,
.rask-public-band--ink .rask-public-heading,
.rask-public-band--ink .rask-public-display,
.rask-public-band--ink .rask-public-card-title,
.rask-public-band--ink .rask-public-stat-value,
.rask-public-band--ink .footer-links h4,
.rask-public-band--ink .copyright {
  color: var(--rask-white);
}

.rask-public-band--ink .rask-public-lead,
.rask-public-band--ink .rask-public-copy,
.rask-public-band--ink .rask-public-card-copy,
.rask-public-band--ink .footer-links a,
.rask-public-band--ink .copyright p {
  color: color-mix(in srgb, var(--rask-white) 76%, transparent);
}

.rask-public-band--ink .rask-public-card,
.rask-public-band--ink .feature-card,
.rask-public-band--ink .promise-card,
.rask-public-band--ink .pathway-card,
.rask-public-band--ink .team-platform-card,
.rask-public-band--ink .team-member {
  background: color-mix(in srgb, var(--rask-white) 10%, transparent);
  border-color: color-mix(in srgb, var(--rask-white) 14%, transparent);
  box-shadow: none;
}

/*
 * Eyebrow Kicker — rebuilt against spec v2:
 * mixed-case (no uppercase), no tracking, weight 600, 16px, text-secondary.
 */
.rask-public-kicker {
  margin: 0 0 0.9rem;
  font-family: var(--font-body);
  font-size: var(--public-text-eyebrow-size);
  line-height: var(--public-text-eyebrow-lh);
  font-weight: var(--public-text-eyebrow-weight);
  letter-spacing: var(--public-text-eyebrow-ls);
  color: var(--public-color-text-secondary);
}

/*
 * Display/heading group — only sets family + colour now. The previous
 * `letter-spacing: -0.02em` was applied to every heading uniformly; per
 * spec, tracking is set per-style (Display Hero / Heading Section: -1%;
 * everything else: 0). Each style below sets its own letter-spacing.
 */
.rask-public-display,
.rask-public-heading,
.rask-public-card-title,
.rask-public-quote-text,
.hero-title,
.section-title,
.booking-title,
.step-title,
.checklist-shell h2,
.education-section-header h2,
.landing-hero h1,
.hero-profile-name,
.hero-panel h1,
.pathway-name,
.team-member h4,
.team-platform-card h3,
.promise-card h3,
.feature-card h3,
footer h4,
.stat-item h2 {
  font-family: var(--font-display);
  font-weight: 400;
  color: var(--public-color-text-primary);
}

/* Display Hero — fluid clamp 36→70px, lh 1, tracking -1% */
.rask-public-display {
  margin: 0;
  font-size: var(--public-text-display-hero-size);
  line-height: var(--public-text-display-hero-lh);
  letter-spacing: var(--public-text-display-hero-ls);
}

/* Heading Section — fluid clamp 26→48px, lh 1.125, tracking -1% */
.rask-public-heading,
.section-title,
.booking-title,
.checklist-shell h2,
.education-section-header h2 {
  margin: 0;
  font-size: var(--public-text-heading-section-size);
  line-height: var(--public-text-heading-section-lh);
  letter-spacing: var(--public-text-heading-section-ls);
}

.rask-public-copy,
.rask-public-lead,
.hero-summary,
.booking-intro,
.section-subtitle,
.hero-note,
.checklist-shell > p,
.education-section-header p,
.landing-hero p {
  color: var(--rask-muted);
}

/* Body Lead — 20px / lh 1.5 / 400 / text-tertiary (inherited from body) */
.rask-public-lead {
  margin: 1.25rem 0 0;
  font-size: var(--public-text-body-lead-size);
  line-height: var(--public-text-body-lead-lh);
  font-weight: var(--public-text-body-lead-weight);
  letter-spacing: var(--public-text-body-lead-ls);
  max-width: 62ch;
}

.rask-public-copy {
  margin: 0;
  font-size: 1rem;
}

.rask-public-actions,
.hero-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  align-items: center;
}

.rask-public-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin: 1.5rem 0 0;
  padding: 0;
  list-style: none;
}

.rask-public-chip,
.process-chip,
.hero-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.65rem 0.95rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background: color-mix(in srgb, var(--rask-white) 84%, var(--info-50));
  color: var(--rask-heading);
  font-size: 0.95rem;
  font-weight: 600;
}

.rask-public-grid {
  display: grid;
  gap: 1.4rem;
}

.rask-public-grid--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.rask-public-grid--3,
.features-grid,
.promise-grid,
.pathways-grid,
.team-platform-grid,
.footer-grid,
.stats-grid {
  display: grid;
  gap: 1.4rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.rask-public-grid--4,
.team-grid {
  display: grid;
  gap: 1.35rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.rask-public-card,
.feature-card,
.promise-card,
.pathway-card,
.team-platform-card,
.hero-panel,
.hero-profile-panel,
.booking-shell,
.booking-meta-card,
.service-card,
.checklist-item,
.team-member {
  position: relative;
  overflow: hidden;
  background: var(--rask-surface);
  border: 1px solid var(--rask-border-soft);
  border-radius: var(--rask-public-radius-card);
  box-shadow: var(--rask-public-shadow-sm);
}

.rask-public-card--soft,
.rask-public-card--accent,
.rask-public-card--warm,
.promise-card,
.booking-meta-card,
.service-card,
.hero-profile-panel,
.team-platform-card {
  border-color: transparent;
}

.rask-public-card {
  padding: 1.5rem;
}

.rask-public-card--soft,
.promise-card,
.booking-meta-card,
.service-card {
  background: var(--rask-surface-soft);
}

.rask-public-card--accent,
.hero-profile-panel,
.team-platform-card {
  background: var(--rask-surface-accent);
}

.rask-public-card--warm {
  background: var(--rask-surface-warm);
}

/* Heading Card — 26px desktop / 22px mobile / lh 1.25 / 500 / text-primary */
.rask-public-card-title {
  margin: 0 0 0.65rem;
  font-family: var(--font-body);
  font-size: var(--public-text-heading-card-size);
  line-height: var(--public-text-heading-card-lh);
  font-weight: var(--public-text-heading-card-weight);
  letter-spacing: var(--public-text-heading-card-ls);
}

@media (max-width: 720px) {
  .rask-public-card-title {
    font-size: var(--public-text-heading-card-size-mobile);
  }
}

.rask-public-card-copy {
  margin: 0;
  color: var(--rask-muted);
}

.rask-public-card-link {
  text-decoration: none;
  color: inherit;
}

.rask-public-card-link:hover .rask-public-card,
.feature-card:hover,
.promise-card:hover,
.pathway-card:hover,
.team-member:hover,
.team-platform-card:hover,
.service-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--rask-public-shadow-md);
  border-color: var(--rask-border-strong);
}

.rask-public-card-link:hover .rask-public-card--soft,
.rask-public-card-link:hover .rask-public-card--accent,
.rask-public-card-link:hover .rask-public-card--warm,
.promise-card:hover,
.team-platform-card:hover,
.service-card:hover,
.booking-meta-card:hover {
  border-color: transparent;
}

.rask-public-card,
.feature-card,
.promise-card,
.pathway-card,
.team-member,
.team-platform-card,
.service-card {
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.rask-public-eyebrow,
.hero-kicker,
.booking-meta-title,
.service-best-for,
.pathway-fee strong,
.pathway-who strong {
  color: var(--rask-heading);
}

/*
 * Button typography — Source Sans 3 / 700 / 18px / lh 1.5 / +1% tracking.
 * Surface (background, padding, radius) is preserved from the existing CTA
 * shape token; per spec §11, button surface is out of scope for the typography
 * spec and is owned separately.
 */
.rask-public-button,
.btn,
.rask-site-cta,
.rask-site-login,
.hero-primary-cta,
.hero-secondary-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 3.15rem;
  padding: 0.9rem 1.45rem;
  border: 1px solid transparent;
  border-radius: var(--rask-public-radius-button);
  font-family: var(--font-body);
  font-size: var(--public-text-button-size);
  font-weight: var(--public-text-button-weight);
  line-height: var(--public-text-button-lh);
  letter-spacing: var(--public-text-button-ls);
  text-decoration: none;
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease, border-color 180ms ease, color 180ms ease;
}

.rask-public-button:hover,
.btn:hover,
.rask-site-cta:hover,
.rask-site-login:hover,
.hero-primary-cta:hover,
.hero-secondary-cta:hover {
  transform: translateY(-2px);
}

/*
 * Primary CTA — surface + label flip with theme mode (Layout Spec §16.5 +
 * dark-header variant). Light pages: dark surface / paper label. Dark
 * pages (currently only /membership/ultra): paper surface / dark label.
 * The .rask-site-cta inherits the same flip via the mode tokens.
 * --public-color-surface-true-dark is preserved for non-header CTAs that
 * want the fixed-dark treatment regardless of theme.
 */
.rask-public-button--primary,
.btn-primary,
.hero-primary-cta {
  background: var(--public-color-surface-true-dark);
  color: var(--public-color-text-primary-dark);
  box-shadow: var(--rask-public-shadow-sm);
}

.rask-site-cta {
  background: var(--surface-button-primary);
  color: var(--text-button-primary);
  box-shadow: var(--rask-public-shadow-sm);
}

.rask-public-button--primary:hover,
.btn-primary:hover,
.hero-primary-cta:hover {
  background: color-mix(in srgb, var(--public-color-surface-true-dark) 88%, var(--rask-black));
  box-shadow: var(--rask-public-shadow-md);
}

.rask-site-cta:hover {
  background: color-mix(in srgb, var(--surface-button-primary) 88%, var(--rask-black));
  box-shadow: var(--rask-public-shadow-md);
}

/*
 * Secondary CTA / Login — white surface, light text-primary label.
 *
 * Per the May 2026 design pass, the site-wide Login chip in the canonical
 * header is rendered borderless (the subtle grey hairline is not part of
 * the design). We keep the optional border on the generic
 * .rask-public-button--secondary / .btn-secondary / .hero-secondary-cta
 * surfaces (some marketing pages still rely on a faint outline for
 * legibility on cream cards) but explicitly null it out for the header
 * Login chip just below.
 */
.rask-public-button--secondary,
.btn-secondary,
.hero-secondary-cta {
  background: var(--public-color-surface-white);
  color: var(--public-color-text-primary);
  border-color: color-mix(in srgb, var(--public-color-text-primary) 8%, transparent);
}

/*
 * Login chip uses mode-aware text colour — flips with `theme-dark` so it
 * stays readable on Ultra's dark canvas. Transparent surface + border per
 * May 2026 design call (no chip outline in the canonical header).
 */
.rask-site-login {
  background: transparent;
  color: var(--text-button-secondary);
  border-color: transparent;
}

.rask-public-button--secondary:hover,
.btn-secondary:hover,
.hero-secondary-cta:hover {
  background: color-mix(in srgb, var(--public-color-text-primary) 4%, var(--public-color-surface-white));
  border-color: color-mix(in srgb, var(--public-color-text-primary) 14%, transparent);
}

.rask-site-login:hover {
  background: color-mix(in srgb, var(--text-button-secondary) 8%, transparent);
}

.rask-public-button--blue {
  background: var(--rask-blue);
  color: var(--rask-white);
}

.rask-public-button--blue:hover {
  background: color-mix(in srgb, var(--rask-blue) 92%, var(--info-900));
  box-shadow: var(--rask-public-shadow-md);
}

.rask-public-button--ink-outline {
  background: transparent;
  color: var(--rask-heading);
  border-color: color-mix(in srgb, var(--rask-primary) 14%, transparent);
}

/*
 * §17 Public Button Spec v1.0 (May 2026).
 *
 * Source: docs/code-docs/frontend/design-system/rask-au-public-design-system.md §17.
 * Figma node: 2244:10906 (Public / Button — 56-variant set).
 *
 * Adds the canonical surface system on top of the .rask-public-button base
 * rule above. The base rule (lines ~533–555) keeps its geometry / typography /
 * transition; this block overrides geometry on the spec modifier classes
 * (--primary / --secondary / --ghost) to land 55px height and 30/14 padding,
 * then sets each variant's surface + label + shadow per §17.3 / §17.4.
 *
 * Legacy class aliases (.btn / .rask-site-cta / .rask-site-login /
 * .hero-primary-cta / .hero-secondary-cta) remain wired to the older block
 * above — they pre-date the §17 surface system and the rendered values differ
 * (alpha / hover bg / height). Migrating them is a separate ticket per the
 * Changelog conflict note; this block intentionally does not touch them.
 */

.rask-public-button--primary,
.rask-public-button--secondary,
.rask-public-button--ghost {
  min-height: var(--public-button-height);
  height: var(--public-button-height);
  padding: var(--public-button-padding-y) var(--public-button-padding-x);
  gap: var(--public-button-gap);
  border: 0;
}

.rask-public-button--primary {
  background: var(--public-surface-button-primary);
  color: var(--public-text-button-primary);
  box-shadow: var(--public-shadow-button);
}

.rask-public-button--primary:hover {
  background: var(--public-surface-button-primary-hover);
}

.rask-public-button--primary.rask-public-button--dark {
  background: var(--public-surface-button-primary-dark);
  color: var(--public-text-button-primary-dark);
}

.rask-public-button--primary.rask-public-button--dark:hover {
  background: var(--public-surface-button-primary-hover-dark);
}

/* Tier-Primary — surface flips per .tier-* ancestor class. Light theme uses
   accent-dark (#410016) as the surface; Dark theme inverts to the tier accent. */
.rask-public-button--primary.rask-public-button--tier {
  background: var(--rask-tier-accent-dark);
  color: var(--public-text-button-primary);
  box-shadow: var(--rask-tier-button-shadow);
}

.rask-public-button--primary.rask-public-button--tier:hover {
  background: var(--rask-tier-accent-dark-hover);
}

.rask-public-button--primary.rask-public-button--tier.rask-public-button--dark {
  background: var(--rask-tier-accent);
  color: var(--rask-tier-accent-dark);
  box-shadow: var(--rask-tier-button-shadow-dark);
}

.rask-public-button--primary.rask-public-button--tier.rask-public-button--dark:hover {
  background: var(--rask-tier-accent-hover);
}

.rask-public-button--secondary {
  background: var(--public-surface-button-secondary);
  color: var(--public-text-button-secondary);
  box-shadow: var(--public-shadow-button);
}

.rask-public-button--secondary:hover {
  background: var(--public-surface-button-secondary-hover);
}

.rask-public-button--secondary.rask-public-button--dark {
  background: var(--public-surface-button-secondary-dark);
  color: var(--public-text-button-secondary-dark);
}

.rask-public-button--secondary.rask-public-button--dark:hover {
  background: var(--public-surface-button-secondary-hover-dark);
}

.rask-public-button--ghost {
  background: transparent;
  color: var(--public-text-button-secondary);
  box-shadow: none;
}

.rask-public-button--ghost.rask-public-button--dark {
  color: var(--public-text-button-secondary-dark);
}

.rask-public-button--icon-trailing > .rask-public-button__icon {
  width: var(--public-button-icon-size);
  height: var(--public-button-icon-size);
  flex-shrink: 0;
}

/*
 * §18 Section closer — full-bleed CTA band before the global footer.
 *
 * Source: docs/code-docs/frontend/design-system/rask-au-public-design-system.md §18.
 *
 * Canonical primitive for the "Ready for X?" panel that sits between page
 * content and the footer. Full-bleed via the negative-margin escape (works
 * inside any constrained ancestor — `<main class="mv3">`, layout container,
 * etc.). Content centred in a Text-container-width column. Top corners
 * rounded; bottom flush so the dark fill flows seamlessly into the footer.
 *
 * Compose CTA buttons with `.rask-public-button--primary.rask-public-button--dark`
 * (Primary) and `.rask-public-button--secondary.rask-public-button--dark`
 * (Secondary) per §17.4 — the closer's surface is always dark, so the buttons
 * always need the `--dark` modifier.
 */
.rask-public-closer {
  /*
   * Surface + label exposed as CSS variables so callers can override per
   * page/tier without re-declaring the full ruleset. Defaults are provided
   * via the var() fallback chain — true-dark surface with paper text per
   * §18 canonical treatment.
   *
   * To tint per-tier (e.g. membership pages where the closer matches the
   * hero panel surface), set `--closer-surface` / `--closer-label` /
   * `--closer-label-soft` / `--closer-eyebrow` on an ancestor element.
   * Don't declare these on `.rask-public-closer` itself — an element-level
   * declaration here has higher cascade precedence than the ancestor
   * override and would lock the default in.
   */
  position: relative;
  width: 100vw;
  /*
   * Horizontal-escape trick. `margin-inline: calc(50% - 50vw)` pulls the
   * element's edges out to the viewport's edges regardless of the ancestor's
   * width. The element stays in normal block flow vertically — no negative
   * top/bottom margins, no absolute positioning.
   */
  margin-inline: calc(50% - 50vw);
  background: var(--closer-surface, var(--public-color-surface-true-dark));
  color: var(--closer-label, var(--public-color-text-primary-dark));
  border-radius: var(--layout-radius-closer);
  padding-block: var(--layout-section-padding-lg);
  margin-bottom: 0;
}

.rask-public-closer__content {
  max-width: var(--layout-container-text-max);
  margin-inline: auto;
  padding-inline: var(--layout-container-gutter);
  text-align: center;
}

.rask-public-closer__eyebrow {
  margin: 0 0 var(--layout-gap-md);
  font-family: var(--font-body);
  font-size: var(--public-text-eyebrow-size);
  line-height: var(--public-text-eyebrow-lh);
  font-weight: var(--public-text-eyebrow-weight);
  letter-spacing: var(--public-text-eyebrow-ls);
  color: var(--closer-eyebrow, var(--public-color-text-secondary-dark));
}

.rask-public-closer__heading {
  margin: 0 0 var(--layout-gap-md);
  font-family: var(--font-display);
  font-size: var(--public-text-heading-section-size);
  line-height: var(--public-text-heading-section-lh);
  font-weight: var(--public-text-heading-section-weight);
  letter-spacing: var(--public-text-heading-section-ls);
  color: var(--closer-label, var(--public-color-text-primary-dark));
}

.rask-public-closer__lead {
  margin: 0 0 var(--layout-gap-lg);
  font-family: var(--font-body);
  font-size: var(--public-text-body-lead-size);
  line-height: var(--public-text-body-lead-lh);
  font-weight: var(--public-text-body-lead-weight);
  color: var(--closer-label-soft, var(--public-color-text-tertiary-dark));
}

.rask-public-closer__actions {
  display: flex;
  justify-content: center;
  gap: var(--layout-gap-sm);
  flex-wrap: wrap;
}

@media (max-width: 720px) {
  .rask-public-closer {
    padding-block: var(--layout-section-padding-lg-mobile);
  }
  .rask-public-closer__actions .rask-public-button {
    width: 100%;
  }
}

/*
 * §16.7 cream-gutter fix — global footer.
 *
 * The .site-footer already has a dark background (line ~910 above) but if it
 * renders inside a constrained ancestor (e.g. <main class="mv3"> on the
 * membership pages), the dark fill clips at the ancestor's max-width and
 * the page shows cream wings at viewport widths > 1440px. Force full-bleed
 * via the same horizontal-escape trick used by .rask-public-closer above.
 *
 * Safe everywhere because every page's footer should be edge-to-edge by
 * design — no page wants a constrained footer.
 */
.site-footer,
footer.site-footer,
.rask-public-footer {
  width: 100vw;
  margin-inline: calc(50% - 50vw);
}

/*
 * §19 Page theme — data-page-theme="dark" flips header chrome surfaces.
 *
 * Source: docs/code-docs/frontend/design-system/rask-au-public-design-system.md §19.
 *
 * Orthogonal to tier. Applied to <body> by PublicLayout.astro when its
 * `pageTheme="dark"` prop is set. Flips header surface + label + logo +
 * nav-link hover state without touching body content or tier accents.
 *
 * Default Light theme rules live above (line ~1023 .rask-site-header).
 */

/* Logo dual-rendering — both <img> tags ship, CSS hides the wrong one. */
.rask-site-logo--dark {
  display: none;
}

[data-page-theme="dark"] .rask-site-logo--light {
  display: none;
}

[data-page-theme="dark"] .rask-site-logo--dark {
  display: inline-block;
}

[data-page-theme="dark"] .rask-site-header {
  background: var(--public-color-surface-true-dark);
  border-bottom-color: color-mix(in srgb, var(--public-color-text-primary-dark) 8%, transparent);
  color: var(--public-color-text-primary-dark);
}

[data-page-theme="dark"] .rask-site-nav-link {
  color: var(--public-color-text-secondary-dark);
}

[data-page-theme="dark"] .rask-site-nav-link:hover {
  background: color-mix(in srgb, var(--public-color-text-primary-dark) 8%, transparent);
  color: var(--public-color-text-primary-dark);
}

/* Login chip — Secondary surface treatment; consume the §17 Secondary Dark tokens
   so the chip reads as a translucent white wash against the dark header. */
[data-page-theme="dark"] .rask-site-login {
  background: var(--public-surface-button-secondary-dark);
  color: var(--public-text-button-secondary-dark);
  border-color: transparent;
}

[data-page-theme="dark"] .rask-site-login:hover {
  background: var(--public-surface-button-secondary-hover-dark);
}

/* Join CTA — Primary surface inverts. On Light theme it's dark-on-paper;
   on Dark theme it inverts to paper-on-dark per §17.3 Primary Dark. */
[data-page-theme="dark"] .rask-site-cta {
  background: var(--public-surface-button-primary-dark);
  color: var(--public-text-button-primary-dark);
}

[data-page-theme="dark"] .rask-site-cta:hover {
  background: var(--public-surface-button-primary-hover-dark);
}

/* Mobile nav panel — match the dark header surface so the drop-down reads
   as part of the same chrome. */
[data-page-theme="dark"] .rask-site-nav-mobile {
  background: var(--public-color-surface-true-dark);
  color: var(--public-color-text-primary-dark);
}

[data-page-theme="dark"] .rask-site-nav-toggle {
  color: var(--public-color-text-primary-dark);
}

[data-page-theme="dark"] .rask-site-nav-toggle__bar {
  background: var(--public-color-text-primary-dark);
}

.rask-public-link {
  color: var(--rask-blue);
  text-decoration: none;
  font-weight: 700;
}

.rask-public-link:hover {
  text-decoration: underline;
}

.rask-public-hero {
  padding-top: clamp(3.5rem, 7vw, 5.75rem);
}

.rask-public-hero__grid,
.hero-grid,
.education-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: 1.5rem;
  align-items: stretch;
}

.rask-public-hero__content {
  padding: clamp(1.75rem, 3vw, 2.5rem);
  border-radius: var(--rask-public-radius-hero);
  background: color-mix(in srgb, var(--rask-white) 84%, var(--neutral-100));
  border: 1px solid var(--rask-border-soft);
  box-shadow: var(--rask-public-shadow-md);
}

.rask-public-hero__media {
  min-height: 100%;
  padding: 1rem;
  border-radius: var(--rask-public-radius-hero);
  background: color-mix(in srgb, var(--warning-50) 66%, var(--rask-white));
  border: 1px solid transparent;
  box-shadow: var(--rask-public-shadow-md);
}

.rask-public-hero__media img,
.hero-profile-image-wrap img,
.referral-hero-image,
.team-image-wrapper img,
.education-image-panel img {
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: calc(var(--rask-public-radius-panel) - 10px);
}

.rask-public-media-frame {
  padding: 1rem;
  border-radius: var(--rask-public-radius-panel);
  background: color-mix(in srgb, var(--warning-50) 72%, var(--rask-white));
  border: 1px solid transparent;
  box-shadow: var(--rask-public-shadow-md);
}

.rask-public-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.rask-public-stat,
.stat-item {
  padding: 1.4rem;
  border-radius: var(--rask-public-radius-card);
  background: color-mix(in srgb, var(--rask-white) 9%, transparent);
  border: 1px solid transparent;
}

.rask-public-stat-value,
.stat-item h2 {
  margin: 0 0 0.35rem;
  font-size: var(--public-text-heading-section-size);
  line-height: 1;
}

.rask-public-stat-label,
.stat-item p {
  margin: 0;
  font-size: 0.94rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: color-mix(in srgb, currentColor 72%, transparent);
}

.rask-public-process,
.hero-process-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.85rem;
}

.rask-public-process--inline,
.hero-process-list {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.rask-public-process-step,
.process-chip {
  min-height: 100%;
}

.rask-public-step-number,
.step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9rem;
  height: 1.9rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--rask-blue) 12%, transparent);
  color: var(--rask-blue);
  font-size: 0.82rem;
  font-weight: 700;
}

.rask-public-quote {
  padding: clamp(1.75rem, 3vw, 2.4rem);
  border-radius: var(--rask-public-radius-panel);
  background: color-mix(in srgb, var(--rask-peach) 48%, var(--rask-white));
  border: 1px solid transparent;
  box-shadow: var(--rask-public-shadow-sm);
}

.rask-public-quote-text {
  margin: 0 0 1rem;
  font-size: var(--public-text-heading-section-size);
  line-height: 1.08;
}

.rask-public-quote-meta {
  margin: 0;
  color: var(--rask-muted);
  font-size: 1rem;
}

.rask-public-team-grid,
.team-grid {
  display: grid;
  gap: 1.35rem;
}

.team-member {
  padding: 1rem;
}

.team-image-wrapper {
  margin-bottom: 1rem;
}

.team-member h4 {
  margin: 0 0 0.25rem;
  font-size: 1.3rem;
}

.team-member .title,
.hero-profile-title,
.hero-profile-copy,
.pathway-description,
.pathway-extra,
.pathway-who,
.booking-meta-copy,
.service-description,
.footer-links a {
  color: var(--rask-muted);
}

/*
 * Site footer — runs on the dark public-site canvas. Surface is a deeper
 * Rask Black tint, copy is cream, links carry a quiet cream-on-dark hover.
 * Disclaimer copy stays a touch dimmer than navigation links so the regulatory
 * block reads as supporting context, not primary navigation.
 */
.rask-public-footer,
footer,
.site-footer {
  padding-block: clamp(3.25rem, 5vw, 4.5rem) 2.5rem;
  background: color-mix(in srgb, var(--rask-black) 25%, var(--rask-primary));
  border-top: 1px solid color-mix(in srgb, var(--rask-bg) 12%, transparent);
  color: color-mix(in srgb, var(--rask-bg) 80%, transparent);
}

.footer-grid {
  align-items: start;
  /* Four columns: brand block + Start here + Legal + Help. Collapses below. */
  grid-template-columns: minmax(0, 1.4fr) repeat(3, minmax(0, 1fr));
  margin-bottom: 2rem;
}

.footer-brand {
  max-width: 34ch;
}

.footer-tagline {
  margin: 0;
  color: color-mix(in srgb, var(--rask-bg) 72%, transparent);
}

.footer-logo {
  display: inline-block;
  margin-bottom: 1rem;
}

.site-footer .footer-links h4 {
  margin: 0 0 0.85rem;
  font-size: 1rem;
  line-height: 1.2;
  color: var(--rask-bg);
  font-family: var(--font-body);
  font-weight: 700;
}

.site-footer .footer-links a {
  display: block;
  margin-bottom: 0.65rem;
  text-decoration: none;
  color: color-mix(in srgb, var(--rask-bg) 78%, transparent);
}

.site-footer .footer-links a:hover {
  color: var(--rask-bg);
  text-decoration: underline;
}

.copyright,
.footer-legal {
  padding-top: 1.5rem;
  border-top: 1px solid color-mix(in srgb, var(--rask-bg) 14%, transparent);
}

.copyright p,
.footer-legal p {
  margin: 0.65rem 0 0;
  color: color-mix(in srgb, var(--rask-bg) 70%, transparent);
  font-size: 0.92rem;
  line-height: 1.55;
  /* Disclaimer fills the footer container — the four-column link grid above
   * already provides the rhythm; constraining the legal paragraph to a
   * reading measure made it look stranded under the wider grid. */
}

.copyright a,
.footer-legal a {
  color: var(--rask-bg);
  text-decoration: underline;
}

.copyright a:hover,
.footer-legal a:hover {
  color: color-mix(in srgb, var(--rask-bg) 85%, var(--rask-accent-purple));
}

/* Footer disclaimer title — Heading Small (22px / 500 / lh 1.25) on dark surface. */
.footer-disclaimer-title {
  margin: 0 0 0.65rem;
  font-family: var(--font-body);
  font-size: var(--public-text-heading-small-size);
  line-height: var(--public-text-heading-small-lh);
  font-weight: var(--public-text-heading-small-weight);
  letter-spacing: var(--public-text-heading-small-ls);
  color: var(--public-color-text-primary-dark);
}

/*
 * Footer credit — Caption (12px / 400 / lh 1.5) on dark surface.
 * Higher specificity (.copyright p.footer-credit) wins over the generic
 * .copyright p rule above without resorting to !important (which the
 * typography guardrail rejects on principle).
 */
.copyright p.footer-credit,
.footer-legal p.footer-credit {
  margin-top: 1.25rem;
  font-size: var(--public-text-caption-size);
  line-height: var(--public-text-caption-lh);
  color: var(--public-color-text-quaternary-dark);
}

/*
 * Site header — matches Figma node 2088:8954.
 * - Surface: paper #FFFAF0 (solid, no transparency)
 * - Backdrop blur: 6px
 * - Border-bottom: 1px solid rgba(82,80,245,0.08)
 * - Container: 1420px max width, 32px horizontal padding, 81px row height
 * - Grid: 168px (logo) / 1fr (primary nav, centered) / auto (actions, shrink-to-fit)
 *   Figma's actions column was nominally 179.38px but the actions div itself
 *   was 199px and overflowed via justify-self-end. `auto` for the actions
 *   column keeps Login + Join side-by-side at any natural width.
 */
.rask-site-header {
  position: sticky;
  top: 0;
  z-index: 120;
  width: 100%;
  /*
   * Mode-aware: paper on light pages, true-dark on `theme-dark` pages
   * (/membership/ultra only, per Sophie 2026-05-09). See
   * frontend/lib/design-tokens.ts → publicSiteThemeTokens for the value
   * matrix; the cascade does the swap, no JS.
   */
  background: var(--surface-canvas);
  backdrop-filter: blur(6px);
  /*
   * No border-bottom. The header sits flush on the cream canvas so the
   * paper surface flows seamlessly from the chrome into whatever section
   * paints first below (hero on the homepage, paper-on-paper on most
   * inner pages). Removed May 2026 per design call — the previous
   * 1px Rask-blue-tint hairline created a visible seam above the hero.
   */
}

.rask-site-nav {
  width: min(var(--rask-public-container-width), 100%);
  margin: 0 auto;
  padding: 15.2px 32px;
  display: grid;
  grid-template-columns: 168px 1fr auto;
  align-items: center;
  gap: 16px 20px;
  min-height: 81px;
}

.rask-site-brand {
  display: inline-flex;
  align-items: center;
  /*
   * Gap derived from Figma node 2203:4101: mark width 35.465px + wordmark
   * left-offset 49.26px = 13.795px gap. Rounded to 13.8px to match the
   * Figma spec; do not change without re-reading the Figma node.
   */
  gap: 13.8px;
  text-decoration: none;
}

/*
 * Mark + wordmark are rendered as a pair. Each pair (light and dark) lives
 * in the DOM; the inactive pair is hidden via the cascade rules below.
 *
 * Intrinsic dimensions come from Figma:
 *   mark      35.465 × 35.662  (square-ish R-icon)
 *   wordmark  106.593 × 33.494 ("rask" lettering)
 * We render both at 36px height so the brand block sits on a single
 * baseline.
 */
.rask-site-logo-mark,
.rask-site-logo-wordmark {
  height: 36px;
  width: auto;
  display: block;
}

/* Light pair shows by default; dark pair is hidden. */
.rask-site-logo--dark { display: none; }

/* On `theme-dark` bodies, swap which pair renders. */
body.theme-dark .rask-site-logo--light { display: none; }
body.theme-dark .rask-site-logo--dark { display: block; }

.rask-site-nav-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6.4px;
}

/* Header Nav-Labels — Source Sans 3 / 500 / 16px / lh 1.25 / 0 / text-secondary */
.rask-site-nav-link {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0.45rem 0.85rem;
  border-radius: 999px;
  text-decoration: none;
  font-family: var(--font-body);
  font-size: var(--public-text-header-nav-size);
  line-height: var(--public-text-header-nav-lh);
  font-weight: var(--public-text-header-nav-weight);
  letter-spacing: var(--public-text-header-nav-ls);
  color: var(--public-color-text-secondary);
}

.rask-site-nav-link:hover {
  background: color-mix(in srgb, var(--public-color-text-primary) 6%, transparent);
  color: var(--public-color-text-primary);
}

/*
 * Nav-link colours flip on `theme-dark` pages so they stay readable on
 * the dark canvas. Uses the dark-theme text tiers (still legacy
 * `*-dark` suffix tokens for now — see publicSiteTypographyTokens).
 */
body.theme-dark .rask-site-nav-link {
  color: var(--public-color-text-secondary-dark);
}

body.theme-dark .rask-site-nav-link:hover {
  background: color-mix(in srgb, var(--public-color-text-primary-dark) 8%, transparent);
  color: var(--public-color-text-primary-dark);
}

.rask-site-nav-actions {
  display: flex;
  /* 11.2px gap per Figma (was 0.7rem ≈ 11.2px — leaving the px form to match
   * the Figma frame's other 11.2px values exactly). */
  gap: 11.2px;
  align-items: center;
  justify-content: flex-end;
  /* Don't wrap — Login + Join must stay side-by-side at every viewport.
   * The grid actions column is `auto`, so the row width grows to fit. */
  flex-wrap: nowrap;
}

/*
 * Mobile hamburger toggle. Hidden above the 720px breakpoint via the
 * media query at the bottom of this file — the inline .rask-site-nav-actions
 * carries Login + Join on desktop. Below 720px, the inline actions hide
 * and this toggle button appears. Click handler lives in PublicSiteHeader.astro.
 *
 * Three bars stacked with 4px gap; collapse into an X when the parent
 * .rask-site-header carries .is-open (set by the runtime script).
 */
.rask-site-nav-toggle {
  display: none;
  appearance: none;
  border: 0;
  background: transparent;
  width: 44px;
  height: 44px;
  padding: 10px;
  border-radius: 8px;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 4px;
  color: var(--public-color-text-primary);
  transition: background 180ms ease;
}

.rask-site-nav-toggle:hover,
.rask-site-nav-toggle:focus-visible {
  background: color-mix(in srgb, var(--public-color-text-primary) 6%, transparent);
}

.rask-site-nav-toggle__bar {
  display: block;
  width: 22px;
  height: 2px;
  background: currentColor;
  border-radius: 999px;
  transition: transform 180ms ease, opacity 180ms ease;
}

.rask-site-header.is-open .rask-site-nav-toggle__bar:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}

.rask-site-header.is-open .rask-site-nav-toggle__bar:nth-child(2) {
  opacity: 0;
}

.rask-site-header.is-open .rask-site-nav-toggle__bar:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

/*
 * Mobile drop-panel — stacks the four mobileMenuLinks (Memberships,
 * Advice, Log in, Join) as plain text nav-label anchors under the
 * header bar. Hidden everywhere by default; only revealed inside the
 * @media (max-width: 720px) block below WHEN the parent
 * .rask-site-header carries `.is-open`.
 *
 * `display: none` here is what enforces the hidden state — the [hidden]
 * attribute on the markup is an accessibility hint only and would be
 * silently overridden by any explicit `display:` rule. Don't remove this
 * default rule; the visible state lives further down in the mobile block.
 *
 * No button chrome on the mobile items: per the May 2026 design call,
 * the Login + Join chips collapse into the same plain nav-label
 * treatment as Memberships + Advice. CTA chrome is desktop-only.
 */
.rask-site-nav-mobile {
  display: none;
  width: min(var(--rask-public-container-width), 100%);
  margin: 0 auto;
  padding: 0.5rem 20px 1rem;
  /*
   * No border-top. Companion to the header's removed border-bottom —
   * keeps the mobile drop-panel feeling like a continuation of the
   * paper canvas rather than a panel sliding out of a divided chrome.
   */
}

.rask-site-nav-mobile__link {
  /*
   * Plain Header Nav-Labels treatment per spec §6.2: Source Sans 3 / 500
   * / 16px / lh 1.25 / 0 / text-secondary on light surface. No background,
   * no border, no underline. The base .rask-site-nav-link class already
   * supplies the typography tokens — we override layout (full-width row,
   * RIGHT-aligned, taller hit target) for the mobile stack.
   *
   * text-align: right so each link's label hugs the right edge of the
   * panel — directly under where the hamburger toggle sits in the
   * header bar. Left-aligned felt visually disconnected from the
   * trigger that opened the menu.
   */
  display: block;
  width: 100%;
  padding: 0.85rem 0.5rem;
  border-radius: 8px;
  text-align: right;
  background: transparent;
}

.text-center {
  text-align: center;
}

.membership-page {
  --membership-accent: var(--rask-blue);
  --membership-accent-strong: var(--info-700);
  --membership-accent-soft: color-mix(in srgb, var(--info-100) 52%, var(--rask-white));
  --membership-accent-surface: color-mix(in srgb, var(--info-50) 78%, var(--rask-white));
  --membership-accent-surface-strong: color-mix(in srgb, var(--info-100) 74%, var(--rask-white));
  --membership-accent-border: color-mix(in srgb, var(--info-700) 14%, transparent);
  --membership-heading: var(--rask-heading);
  --membership-copy: var(--rask-text);
  --membership-muted: var(--rask-muted);
}

.membership-page--free {
  --membership-accent: var(--info-700);
  --membership-accent-strong: var(--info-800);
  --membership-accent-soft: color-mix(in srgb, var(--info-100) 54%, var(--rask-white));
  --membership-accent-surface: color-mix(in srgb, var(--info-50) 78%, var(--rask-white));
  --membership-accent-surface-strong: color-mix(in srgb, var(--info-100) 78%, var(--rask-white));
  --membership-accent-border: color-mix(in srgb, var(--info-700) 16%, transparent);
}

.membership-page--pro {
  --membership-accent: var(--success-700);
  --membership-accent-strong: var(--success-800);
  --membership-accent-soft: color-mix(in srgb, var(--success-100) 58%, var(--rask-white));
  --membership-accent-surface: color-mix(in srgb, var(--success-50) 80%, var(--rask-white));
  --membership-accent-surface-strong: color-mix(in srgb, var(--success-100) 80%, var(--rask-white));
  --membership-accent-border: color-mix(in srgb, var(--success-700) 16%, transparent);
}

.membership-page--super {
  --membership-accent: var(--warning-700);
  --membership-accent-strong: var(--warning-800);
  --membership-accent-soft: color-mix(in srgb, var(--warning-100) 56%, var(--rask-white));
  --membership-accent-surface: color-mix(in srgb, var(--warning-50) 80%, var(--rask-white));
  --membership-accent-surface-strong: color-mix(in srgb, var(--warning-100) 80%, var(--rask-white));
  --membership-accent-border: color-mix(in srgb, var(--warning-700) 18%, transparent);
}

.membership-page--ultra {
  --membership-accent: var(--rask-peach);
  --membership-accent-strong: color-mix(in srgb, var(--rask-peach) 84%, var(--rask-white));
  --membership-accent-soft: color-mix(in srgb, var(--rask-peach) 38%, var(--rask-primary));
  --membership-accent-surface: color-mix(in srgb, var(--rask-white) 10%, var(--rask-primary));
  --membership-accent-surface-strong: color-mix(in srgb, var(--rask-white) 16%, var(--rask-primary));
  --membership-accent-border: color-mix(in srgb, var(--rask-white) 14%, transparent);
  --membership-heading: var(--rask-white);
  --membership-copy: color-mix(in srgb, var(--rask-white) 86%, transparent);
  --membership-muted: color-mix(in srgb, var(--rask-white) 68%, transparent);
}

.membership-offer-hero {
  background:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--membership-accent) 18%, transparent) 0%, transparent 38%),
    radial-gradient(circle at 96% 10%, color-mix(in srgb, var(--membership-accent) 14%, transparent) 0%, transparent 34%),
    linear-gradient(180deg, color-mix(in srgb, var(--membership-accent-surface) 78%, var(--rask-white)) 0%, color-mix(in srgb, var(--rask-white) 92%, transparent) 100%);
}

.membership-page--ultra .membership-offer-hero {
  background:
    radial-gradient(circle at 8% 12%, color-mix(in srgb, var(--rask-peach) 24%, transparent) 0%, transparent 34%),
    radial-gradient(circle at 96% 8%, color-mix(in srgb, var(--rask-white) 12%, transparent) 0%, transparent 28%),
    linear-gradient(180deg, color-mix(in srgb, var(--rask-primary) 94%, transparent) 0%, color-mix(in srgb, var(--rask-primary) 82%, var(--rask-black)) 100%);
}

.membership-offer-hero__grid {
  grid-template-columns: minmax(0, 1.12fr) minmax(20rem, 0.88fr);
  align-items: stretch;
  gap: clamp(1.5rem, 3vw, 2.5rem);
}

.membership-offer-hero__content {
  display: grid;
  gap: 1.25rem;
}

.membership-offer-hero__title {
  max-width: 8.8ch;
  font-size: var(--public-text-display-hero-size);
  line-height: 0.96;
  color: var(--membership-heading);
}

.membership-offer-hero__lead {
  color: var(--membership-copy);
  max-width: 46ch;
  font-size: 1.15rem;
}

.membership-inline-note {
  margin: 0;
  color: var(--membership-muted);
  font-size: 0.85rem;
  max-width: 58ch;
}

.membership-chip {
  background: color-mix(in srgb, var(--membership-accent-surface) 88%, var(--rask-white));
  border-color: color-mix(in srgb, var(--membership-accent) 14%, transparent);
  color: var(--membership-heading);
}

.membership-offer-hero__aside {
  display: grid;
  gap: 1rem;
  align-content: start;
  width: 100%;
  max-width: 25rem;
  justify-self: end;
}

.membership-hero-card,
.membership-boundary-card,
.membership-cta-shell,
.membership-feature-card,
.membership-evidence-card,
.membership-pricing-card,
.membership-team-card,
.membership-tier-card,
.membership-testimonial-card,
.membership-solution-card,
.membership-onboarding-card,
.membership-reassurance-card {
  position: relative;
  overflow: hidden;
  padding: clamp(1.35rem, 2.6vw, 1.85rem);
  border-radius: var(--rask-public-radius-panel);
  border: 1px solid var(--membership-accent-border);
  box-shadow: var(--rask-public-shadow-md);
  background: color-mix(in srgb, var(--rask-white) 92%, var(--membership-accent-surface));
}

.membership-page--ultra .membership-hero-card,
.membership-page--ultra .membership-feature-card,
.membership-page--ultra .membership-evidence-card,
.membership-page--ultra .membership-pricing-card,
.membership-page--ultra .membership-team-card,
.membership-page--ultra .membership-tier-card,
.membership-page--ultra .membership-testimonial-card,
.membership-page--ultra .membership-solution-card,
.membership-page--ultra .membership-onboarding-card,
.membership-page--ultra .membership-reassurance-card,
.membership-page--ultra .membership-boundary-card,
.membership-page--ultra .membership-cta-shell {
  background: color-mix(in srgb, var(--rask-white) 10%, var(--rask-primary));
  border-color: color-mix(in srgb, var(--rask-white) 14%, transparent);
}

.membership-hero-card__body,
.membership-feature-card__header {
  display: grid;
  gap: 0.8rem;
}

.membership-card-eyebrow,
.membership-column-label,
.membership-why-card__eyebrow {
  margin: 0 0 0.6rem;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--membership-accent-strong);
}

.membership-hero-card__title,
.membership-pricing-card__title,
.membership-tier-price {
  margin: 0;
  font-family: var(--font-display);
  color: var(--membership-heading);
}

.membership-hero-card__title {
  font-size: var(--public-text-heading-card-size);
  line-height: 1.05;
}

.membership-hero-card__title--compact {
  font-size: var(--public-text-heading-card-size);
}

.membership-hero-card__price,
.membership-pricing-card__price,
.membership-tier-price {
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--public-text-heading-section-size);
  line-height: 0.98;
  color: var(--membership-heading);
}

.membership-tier-price {
  font-size: var(--public-text-heading-card-size);
}

.membership-hero-card__copy,
.membership-hero-card__subtext,
.membership-pricing-card__subtext,
.membership-founder-copy__body,
.membership-evidence-card__text,
.membership-why-card__copy,
.membership-tier-stage,
.membership-tier-card .rask-public-card-copy,
.membership-team-card__copy p,
.membership-testimonial-card__meta span,
.membership-testimonial-card__meta em {
  margin: 0;
  color: var(--membership-muted);
}

.membership-hero-card__note,
.membership-pricing-card__note,
.membership-pricing-card__highlight {
  margin: 0;
  display: inline-flex;
  width: fit-content;
  align-items: center;
  padding: 0.38rem 0.72rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--membership-accent) 14%, transparent);
  color: var(--membership-accent-strong);
  font-size: 0.82rem;
  font-weight: 700;
}

.membership-hero-card__image {
  width: 100%;
  aspect-ratio: 4 / 4.5;
  object-fit: cover;
  object-position: center top;
  border-radius: calc(var(--rask-public-radius-panel) - 10px);
}

.membership-section-intro {
  margin-bottom: clamp(2rem, 3.5vw, 2.8rem);
}

.membership-section-intro .rask-public-lead,
.membership-founder-copy__body,
.membership-feature-card .rask-public-card-copy,
.membership-tier-card .rask-public-card-copy {
  max-width: 62ch;
}

.membership-trust-strip,
.membership-team-grid,
.membership-testimonial-grid,
.membership-feature-grid,
.membership-tier-grid,
.membership-pricing-grid,
.membership-proof-pills,
.membership-evidence-grid {
  display: grid;
  gap: 1.2rem;
}

.membership-trust-strip {
  grid-template-columns: repeat(auto-fit, minmax(11.5rem, 1fr));
  gap: 0.9rem;
}

.membership-trust-badge {
  padding: 1.1rem 1.2rem;
  border-radius: var(--rask-public-radius-card);
  border: 1px solid var(--membership-accent-border);
  background: color-mix(in srgb, var(--membership-accent-surface) 86%, var(--rask-white));
  box-shadow: var(--rask-public-shadow-sm);
}

.membership-page--ultra .membership-trust-badge {
  background: color-mix(in srgb, var(--rask-white) 8%, var(--rask-primary));
}

.membership-trust-badge__value {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--public-text-body-lead-size);
  line-height: 1.1;
  font-weight: 700;
  color: var(--membership-accent-strong);
}

.membership-trust-badge__label {
  margin: 0.35rem 0 0;
  color: var(--membership-muted);
  font-size: 0.9rem;
}

.membership-problem-solution-grid,
.membership-founder-grid,
.membership-pricing-meta {
  display: grid;
  gap: 1.3rem;
}

.membership-evidence-card {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  align-items: stretch;
  gap: clamp(1.5rem, 3vw, 2.5rem);
}

.membership-evidence-card--reverse .membership-evidence-visual {
  order: 2;
}

.membership-problem-solution-grid {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
}

.membership-problem-list,
.membership-solution-list {
  display: grid;
  gap: 1rem;
}

.membership-problem-card {
  height: 100%;
}

.membership-solution-card {
  border-left: 3px solid var(--membership-accent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--membership-accent-surface-strong) 68%, var(--rask-white)) 0%, color-mix(in srgb, var(--rask-white) 92%, transparent) 100%);
}

.membership-page--ultra .membership-solution-card {
  border-left-color: var(--rask-peach);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--rask-white) 12%, var(--rask-primary)) 0%, color-mix(in srgb, var(--rask-white) 8%, var(--rask-primary)) 100%);
}

.membership-mini-list,
.membership-bullet-list {
  list-style: none;
  margin: 1rem 0 0;
  padding: 0;
  display: grid;
  gap: 0.65rem;
}

.membership-bullet-list--compact {
  gap: 0.55rem;
  margin-top: 0.8rem;
}

.membership-mini-list li,
.membership-bullet-list li {
  position: relative;
  padding-left: 1rem;
  color: var(--membership-copy);
}

.membership-mini-list li::before,
.membership-bullet-list li::before {
  content: "";
  position: absolute;
  top: 0.66rem;
  left: 0;
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 999px;
  background: var(--membership-accent);
}

.membership-evidence-grid {
  grid-template-columns: 1fr;
  gap: clamp(2rem, 4vw, 3rem);
}

.membership-evidence-visual {
  min-height: 18rem;
  padding: 1.5rem;
  border-radius: calc(var(--rask-public-radius-panel) - 8px);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--membership-accent) 12%, var(--rask-white)) 0%, color-mix(in srgb, var(--rask-white) 92%, transparent) 100%);
}

.membership-page--ultra .membership-evidence-visual {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--rask-peach) 12%, var(--rask-primary)) 0%, color-mix(in srgb, var(--rask-white) 8%, var(--rask-primary)) 100%);
}

.membership-evidence-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: calc(var(--rask-public-radius-panel) - 12px);
}

.membership-widget-shell {
  display: grid;
  gap: 0.9rem;
  min-height: 100%;
  padding: 1rem;
  border-radius: calc(var(--rask-public-radius-panel) - 10px);
  border: 1px solid color-mix(in srgb, var(--membership-accent) 16%, transparent);
  background: color-mix(in srgb, var(--rask-white) 90%, var(--membership-accent-surface));
}

.membership-page--ultra .membership-widget-shell {
  background: color-mix(in srgb, var(--rask-white) 8%, var(--rask-primary));
  border-color: color-mix(in srgb, var(--rask-white) 14%, transparent);
}

.membership-widget-shell__header,
.membership-widget-shell__metrics,
.membership-widget-shell__hero,
.membership-widget-shell__list-row {
  display: flex;
  align-items: center;
}

.membership-widget-shell__header {
  justify-content: space-between;
  gap: 1rem;
  color: var(--membership-muted);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.membership-widget-shell__dot {
  width: 0.72rem;
  height: 0.72rem;
  border-radius: 999px;
  background: var(--membership-accent);
}

.membership-widget-shell__hero {
  justify-content: space-between;
  gap: 1rem;
}

.membership-widget-shell__bars {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: end;
  gap: 0.5rem;
  width: 48%;
  min-height: 7rem;
}

.membership-widget-shell__bars span,
.membership-widget-shell__card,
.membership-widget-shell__metric,
.membership-widget-shell__list-row span {
  border-radius: 18px;
  background: color-mix(in srgb, var(--membership-accent) 18%, transparent);
}

.membership-widget-shell__bars span:nth-child(1) {
  height: 38%;
}

.membership-widget-shell__bars span:nth-child(2) {
  height: 62%;
}

.membership-widget-shell__bars span:nth-child(3) {
  height: 86%;
}

.membership-widget-shell__bars span:nth-child(4) {
  height: 54%;
}

.membership-widget-shell__card {
  width: 46%;
  min-height: 7.4rem;
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--membership-accent) 12%, var(--rask-white)) 0%, color-mix(in srgb, var(--rask-white) 94%, transparent) 100%);
}

.membership-widget-shell__metrics {
  gap: 0.65rem;
}

.membership-widget-shell__metric {
  flex: 1;
  display: grid;
  gap: 0.18rem;
  padding: 0.65rem 0.7rem;
}

.membership-widget-shell__metric strong,
.membership-widget-shell__metric span {
  display: block;
}

.membership-widget-shell__metric strong {
  font-size: 1rem;
  color: var(--membership-heading);
}

.membership-widget-shell__metric span {
  color: var(--membership-muted);
  font-size: 0.78rem;
}

.membership-widget-shell__list {
  display: grid;
  gap: 0.55rem;
}

.membership-widget-shell__list-row {
  gap: 0.65rem;
}

.membership-widget-shell__list-row span {
  width: 0.7rem;
  height: 0.7rem;
  flex: 0 0 0.7rem;
  background: var(--membership-accent);
}

.membership-widget-shell__list-row em {
  font-style: normal;
  color: var(--membership-muted);
}

/* Decorative chrome header — replaces old text-based header */
.membership-widget-shell__chrome {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding-bottom: 0.9rem;
  margin-bottom: 0.6rem;
  border-bottom: 1px solid color-mix(in srgb, var(--membership-accent) 12%, transparent);
}

.membership-widget-shell__chrome-bar {
  flex: 1;
  height: 0.4rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--membership-accent) 16%, transparent);
  margin-left: 0.55rem;
}

/* Abstract text-line rows replacing the data bullets */
.membership-widget-shell__lines {
  display: grid;
  gap: 0.5rem;
  margin-top: 0.85rem;
}

.membership-widget-shell__line {
  height: 0.48rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--membership-accent) 16%, transparent);
}

.membership-widget-shell__line--mid {
  width: 68%;
}

.membership-widget-shell__line--short {
  width: 42%;
  background: color-mix(in srgb, var(--membership-accent) 10%, transparent);
}

.membership-evidence-visual--cashflow .membership-widget-shell__card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--success-100) 72%, var(--rask-white)) 0%, color-mix(in srgb, var(--rask-white) 90%, transparent) 100%);
}

.membership-evidence-visual--ai .membership-widget-shell__card,
.membership-evidence-visual--community .membership-widget-shell__card,
.membership-evidence-visual--session .membership-widget-shell__card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--warning-100) 66%, var(--rask-white)) 0%, color-mix(in srgb, var(--rask-white) 90%, transparent) 100%);
}

.membership-evidence-card__copy {
  display: grid;
  gap: 0.9rem;
  align-content: center;
}

.membership-evidence-card__insight {
  margin: 0;
  padding: 0.9rem 1rem;
  border-radius: var(--rask-public-radius-card);
  border-left: 2px solid color-mix(in srgb, var(--membership-accent) 36%, transparent);
  background: color-mix(in srgb, var(--membership-accent) 7%, transparent);
  color: var(--membership-copy);
  font-size: 0.93rem;
  line-height: 1.65;
}

.membership-evidence-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--public-text-heading-card-size);
  line-height: 1.05;
  color: var(--membership-heading);
}

.membership-evidence-card__metrics,
.membership-founder-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.65rem;
}

.membership-evidence-metric,
.membership-founder-stat {
  display: grid;
  gap: 0.25rem;
  padding: 0.85rem 0.95rem;
  border-radius: var(--rask-public-radius-card);
  background: color-mix(in srgb, var(--membership-accent-surface-strong) 82%, var(--rask-white));
  box-shadow: var(--rask-public-shadow-sm);
}

.membership-page--ultra .membership-evidence-metric,
.membership-page--ultra .membership-founder-stat {
  background: color-mix(in srgb, var(--rask-white) 10%, var(--rask-primary));
}

.membership-evidence-metric strong,
.membership-founder-stat strong {
  display: block;
  font-family: var(--font-body);
  font-size: var(--public-text-body-lead-size);
  line-height: 1.1;
  font-weight: 700;
  color: var(--membership-heading);
}

.membership-evidence-metric em,
.membership-founder-stat span {
  font-style: normal;
  font-size: 0.78rem;
  color: var(--membership-muted);
}

.membership-why-card {
  padding: 0.95rem 1rem;
  border-radius: var(--rask-public-radius-card);
  background: color-mix(in srgb, var(--membership-accent) 8%, transparent);
}

.membership-founder-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(18rem, 0.92fr);
  align-items: start;
  gap: clamp(1.5rem, 3vw, 3rem);
}

.membership-founder-copy {
  display: grid;
  gap: 1rem;
  max-width: 42rem;
}

.membership-founder-media {
  width: 100%;
  max-width: 26rem;
  justify-self: end;
}

.membership-founder-media__stack {
  position: relative;
  display: grid;
  justify-items: end;
}

.membership-founder-media__primary,
.membership-founder-media__secondary {
  margin: 0;
  overflow: hidden;
  border-radius: var(--rask-public-radius-panel);
  border: 1px solid var(--membership-accent-border);
  box-shadow: var(--rask-public-shadow-md);
}

.membership-founder-media__primary {
  width: min(100%, 24rem);
}

.membership-founder-media__secondary {
  position: absolute;
  right: -0.75rem;
  bottom: 1.25rem;
  width: min(42%, 10.5rem);
}

.membership-founder-media img {
  width: 100%;
  aspect-ratio: 4 / 4.8;
  object-fit: cover;
  object-position: center top;
}

.membership-founder-quote {
  margin: 0;
  padding: 1rem 1.2rem;
  border-left: 3px solid var(--membership-accent);
  border-radius: 0 var(--rask-public-radius-card) var(--rask-public-radius-card) 0;
  background: color-mix(in srgb, var(--membership-accent) 6%, transparent);
}

.membership-founder-quote p {
  margin: 0;
  color: var(--membership-heading);
  font-family: var(--font-body);
  font-size: 1.05rem;
  line-height: 1.6;
  font-weight: 600;
}

.membership-testimonial-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.membership-testimonial-card {
  display: grid;
  gap: 1rem;
  padding: 1.35rem 1.4rem;
  background: color-mix(in srgb, var(--rask-white) 94%, var(--membership-accent-surface));
}

.membership-testimonial-card__stars {
  margin: 0;
  color: var(--membership-accent-strong);
  letter-spacing: 0.12em;
  font-size: 0.95rem;
}

.membership-testimonial-card__quote p {
  margin: 0;
  color: var(--membership-heading);
  font-family: var(--font-body);
  font-size: 1.06rem;
  line-height: 1.65;
}

.membership-testimonial-card__quote::before {
  content: '\201C';
  display: block;
  font-family: var(--font-display);
  font-size: 3rem;
  line-height: 0.6;
  color: color-mix(in srgb, var(--membership-accent) 48%, transparent);
  margin-bottom: 0.6rem;
}

.membership-testimonial-card__meta {
  display: grid;
  gap: 0.18rem;
  padding-top: 0.9rem;
  border-top: 1px solid color-mix(in srgb, var(--membership-accent) 12%, transparent);
}

.membership-testimonial-card__meta strong {
  color: var(--membership-heading);
}

.membership-team-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.membership-team-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: center;
}

.membership-team-card__image {
  width: 4.35rem;
  height: 4.35rem;
  border-radius: 22px;
  object-fit: cover;
  object-position: center top;
}

.membership-team-card__copy {
  display: grid;
  gap: 0.2rem;
}

.membership-team-card__copy h3 {
  margin: 0;
  color: var(--membership-heading);
  font-size: 1rem;
}

.membership-feature-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.membership-feature-card,
.membership-tier-card {
  display: grid;
  align-content: start;
  gap: 0.75rem;
}

.membership-tier-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.membership-tier-card--hub {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--membership-accent-surface-strong) 54%, var(--rask-white)) 0%, color-mix(in srgb, var(--rask-white) 92%, transparent) 100%);
}

.membership-page--ultra .membership-tier-card--hub {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--rask-white) 9%, var(--rask-primary)) 0%, color-mix(in srgb, var(--rask-white) 6%, var(--rask-primary)) 100%);
}

.membership-tier-link {
  margin-top: auto;
  font-weight: 700;
  color: var(--membership-accent-strong);
}

.membership-comparison-shell {
  margin-top: 2rem;
  overflow-x: auto;
  border-radius: var(--rask-public-radius-card);
  border: 1px solid var(--membership-accent-border);
  background: color-mix(in srgb, var(--rask-white) 94%, var(--membership-accent-surface));
  box-shadow: var(--rask-public-shadow-sm);
}

.membership-comparison-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
}

.membership-comparison-table thead th {
  padding: 1rem 1.1rem;
  border-bottom: 1px solid var(--membership-accent-border);
  text-align: left;
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--membership-heading);
  background: color-mix(in srgb, var(--membership-accent-surface-strong) 62%, var(--rask-white));
}

.membership-comparison-table tbody th,
.membership-comparison-table tbody td {
  padding: 0.95rem 1.1rem;
  border-bottom: 1px solid color-mix(in srgb, var(--membership-accent) 10%, transparent);
  text-align: left;
  vertical-align: top;
}

.membership-comparison-table tbody th {
  color: var(--membership-heading);
  font-weight: 600;
  width: 32%;
}

.membership-matrix-cell {
  display: inline-flex;
  align-items: center;
  min-width: 6.4rem;
  padding: 0.45rem 0.72rem;
  border-radius: 999px;
  font-size: 0.84rem;
  font-weight: 700;
}

.membership-matrix-cell--positive {
  background: color-mix(in srgb, var(--success-50) 82%, var(--rask-white));
  color: var(--success-700);
}

.membership-matrix-cell--neutral {
  background: color-mix(in srgb, var(--membership-accent) 10%, transparent);
  color: var(--membership-accent-strong);
}

.membership-matrix-cell--muted {
  background: color-mix(in srgb, var(--neutral-200) 56%, transparent);
  color: var(--neutral-500);
}

.membership-matrix-cell--negative {
  background: color-mix(in srgb, var(--danger-50) 82%, var(--rask-white));
  color: var(--danger-700);
}

.membership-pricing-grid {
  grid-template-columns: repeat(auto-fit, minmax(17rem, 1fr));
}

.membership-pricing-card {
  display: grid;
  gap: 1rem;
}

.membership-pricing-card:has(.membership-pricing-card__highlight) {
  border-top: 3px solid var(--membership-accent);
}

.membership-page--ultra .membership-pricing-card:has(.membership-pricing-card__highlight) {
  border-top-color: var(--rask-peach);
}

.membership-hero-card--pricing {
  border-top: 3px solid var(--membership-accent);
}

.membership-page--ultra .membership-hero-card--pricing {
  border-top-color: var(--rask-peach);
}

.membership-pricing-meta {
  grid-template-columns: minmax(0, 1fr);
  margin-top: 1.35rem;
}

.membership-onboarding-list {
  margin: 0;
  padding-left: 1.2rem;
  display: grid;
  gap: 0.65rem;
  color: var(--membership-copy);
}

.membership-proof-pills {
  list-style: none;
  margin: 0;
  padding: 0;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.membership-proof-pills li {
  padding: 0.72rem 0.85rem;
  border-radius: 999px;
  text-align: center;
  border: 1px solid color-mix(in srgb, var(--membership-accent) 16%, transparent);
  background: color-mix(in srgb, var(--rask-white) 82%, var(--membership-accent-surface));
  color: var(--membership-heading);
  font-weight: 700;
}

.membership-page--ultra .membership-proof-pills li {
  background: color-mix(in srgb, var(--rask-white) 10%, var(--rask-primary));
}

.membership-pricing-footnote {
  margin: 1rem 0 0;
  max-width: 68ch;
  color: var(--membership-muted);
  font-size: 0.88rem;
}

.membership-faq-list {
  display: grid;
  gap: 0.8rem;
  margin-top: 2rem;
}

.membership-faq-item {
  border: 1px solid var(--membership-accent-border);
  border-radius: var(--rask-public-radius-card);
  background: color-mix(in srgb, var(--rask-white) 86%, var(--membership-accent-surface));
  overflow: hidden;
  transition: box-shadow 0.2s ease;
}

.membership-faq-item:hover {
  box-shadow: var(--rask-public-shadow-sm);
}

.membership-faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 1rem 1.25rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--membership-heading);
  position: relative;
  padding-right: 3rem;
}

.membership-faq-item p {
  margin: 0;
  padding: 0 1.25rem 1.1rem;
  color: var(--membership-muted);
}

.membership-faq-item summary::-webkit-details-marker {
  display: none;
}

.membership-faq-item summary::after {
  content: "+";
  position: absolute;
  right: 1.2rem;
  top: 0.92rem;
  color: var(--membership-accent-strong);
  font-size: 1.25rem;
}

.membership-faq-item[open] summary::after {
  content: "−";
}

.membership-cta-shell {
  display: grid;
  gap: 1.2rem;
  justify-items: start;
  padding: clamp(2rem, 4vw, 3rem);
}

.membership-cta-shell .rask-public-lead {
  max-width: 54ch;
}

@media (max-width: 1100px) {
  .rask-public-grid--4,
  .team-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .membership-feature-grid,
  .membership-tier-grid,
  .membership-testimonial-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .membership-team-grid,
  .membership-founder-stats,
  .membership-evidence-card__metrics,
  .membership-proof-pills,
  .membership-trust-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 920px) {
  .rask-site-nav {
    grid-template-columns: auto 1fr auto;
    align-items: center;
  }

  .rask-site-brand {
    justify-content: flex-start;
  }

  .rask-site-nav-links {
    grid-column: 1 / -1;
    justify-content: flex-start;
    overflow-x: auto;
    padding-top: 0.15rem;
    scrollbar-width: none;
  }

  .rask-site-nav-links::-webkit-scrollbar {
    display: none;
  }

  .rask-site-nav-actions {
    justify-content: flex-end;
  }

  .rask-public-hero__grid,
  .hero-grid,
  .education-layout,
  .rask-public-grid--2,
  .rask-public-grid--3,
  .features-grid,
  .promise-grid,
  .pathways-grid,
  .team-platform-grid,
  .footer-grid,
  .stats-grid {
    grid-template-columns: 1fr;
  }

  .rask-public-grid--4,
  .team-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .rask-public-stat-grid {
    grid-template-columns: 1fr;
  }

  .membership-problem-solution-grid,
  .membership-pricing-meta,
  .membership-feature-grid,
  .membership-tier-grid,
  .membership-trust-strip,
  .membership-team-grid,
  .membership-testimonial-grid,
  .membership-proof-pills,
  .membership-founder-stats,
  .membership-evidence-card__metrics {
    grid-template-columns: 1fr;
  }

  .membership-comparison-table {
    min-width: 680px;
  }
}

@media (max-width: 860px) {
  .membership-founder-grid,
  .membership-evidence-card,
  .membership-offer-hero__grid {
    grid-template-columns: 1fr;
  }

  .membership-evidence-card--reverse .membership-evidence-visual {
    order: 0;
  }

  .membership-offer-hero__aside,
  .membership-founder-media {
    max-width: none;
    justify-self: stretch;
  }

  .membership-founder-media__stack {
    justify-items: start;
  }

  .membership-founder-media__secondary {
    position: static;
    width: min(42%, 11rem);
    margin-top: 1rem;
  }
}

@media (max-width: 640px) {
  .rask-site-nav-links {
    display: none;
  }

  .rask-site-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
  }

  .rask-site-brand {
    justify-content: flex-start;
    flex: 0 0 auto;
    gap: 10px;
  }

  /*
   * Mobile: shrink the mark+wordmark pair to ~30px tall so the brand block
   * fits comfortably alongside the Join CTA on narrow viewports. Aspect
   * ratios preserved by the auto width.
   */
  .rask-site-logo-mark,
  .rask-site-logo-wordmark {
    height: 30px;
  }

  .rask-site-nav-actions {
    width: auto;
    flex: 0 0 auto;
    flex-wrap: nowrap;
    justify-content: flex-end;
    gap: 0.85rem;
  }

  .rask-site-login {
    display: none;
  }

  .rask-site-cta {
    min-height: 2.6rem;
    padding: 0.65rem 1rem;
    width: auto;
  }

  /*
   * NOTE: .rask-public-display and .rask-public-heading no longer have a
   * mobile font-size override here — they consume the canonical
   * --public-text-display-hero-size and --public-text-heading-section-size
   * tokens, which are themselves fluid clamp() expressions. Mobile sizing
   * comes from the token, not from this @media block.
   */

  .rask-public-grid--4,
  .team-grid {
    grid-template-columns: 1fr;
  }

  .membership-comparison-table {
    min-width: 620px;
  }

  .membership-offer-hero__content,
  .membership-offer-hero__aside {
    gap: 1rem;
  }

  .membership-offer-hero__title {
    font-size: var(--public-text-display-hero-size);
    max-width: 8ch;
  }

  .membership-evidence-visual {
    min-height: 13rem;
  }

  .membership-team-card {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
  }

  .rask-public-actions,
  .hero-cta-row {
    width: 100%;
  }

  .rask-public-button,
  .btn,
  .hero-primary-cta,
  .hero-secondary-cta {
    width: 100%;
  }
}

/*
 * Footer responsive collapse — keep the brand block + 3 link columns on
 * desktop (set in the canonical .footer-grid rule). At tablet width drop to
 * a balanced 2x2 so no link column gets stranded on its own row; at <=640px
 * stack to a single column. Sits AFTER the wide-catch-all collapse above so
 * we override it for footer-grid specifically.
 */
@media (max-width: 920px) and (min-width: 641px) {
  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ============================================================================
 * PUBLIC SITE TYPOGRAPHY UTILITIES (rask.au) — spec v2
 *
 * Source of truth: Figma "Typography - Public Site" node 2138:8339
 *   + designer responses (May 2026)
 * Spec doc: docs/code-docs/frontend/design-system/rask-au-public-design-system.md
 *
 * 14 named text styles. Each utility maps 1:1 to a Figma style and consumes
 * tokens from frontend/lib/design-tokens.ts → publicSiteTypographyTokens.
 *
 * - Display Hero & Heading Section: fluid clamp() for size, set in tokens
 * - Heading Serif Card / Heading Card / Heading Small: discrete mobile size
 *   at <720px (handled by per-utility @media rules below)
 * - Everything else: fixed at all viewports
 * - Two families only: DM Serif Display + Source Sans 3
 * - 8-tier semantic colour system (4 light + 4 dark, see rask-tokens.css)
 *
 * Adjust values in design-tokens.ts only — never override per page.
 * ============================================================================ */

.t-display-hero {
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--public-text-display-hero-size);
  line-height: var(--public-text-display-hero-lh);
  font-weight: var(--public-text-display-hero-weight);
  letter-spacing: var(--public-text-display-hero-ls);
  color: var(--public-color-text-primary);
}

.t-heading-section {
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--public-text-heading-section-size);
  line-height: var(--public-text-heading-section-lh);
  font-weight: var(--public-text-heading-section-weight);
  letter-spacing: var(--public-text-heading-section-ls);
  color: var(--public-color-text-primary);
}

.t-heading-serif-card {
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--public-text-heading-serif-card-size);
  line-height: var(--public-text-heading-serif-card-lh);
  font-weight: var(--public-text-heading-serif-card-weight);
  letter-spacing: var(--public-text-heading-serif-card-ls);
  color: var(--public-color-text-primary);
}

.t-heading-card {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--public-text-heading-card-size);
  line-height: var(--public-text-heading-card-lh);
  font-weight: var(--public-text-heading-card-weight);
  letter-spacing: var(--public-text-heading-card-ls);
  color: var(--public-color-text-primary);
}

.t-heading-small {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--public-text-heading-small-size);
  line-height: var(--public-text-heading-small-lh);
  font-weight: var(--public-text-heading-small-weight);
  letter-spacing: var(--public-text-heading-small-ls);
  color: var(--public-color-text-secondary);
}

/*
 * Eyebrow Kicker — mixed-case (no uppercase per spec v2), no tracking,
 * weight 600, 16px, text-secondary.
 */
.t-eyebrow {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--public-text-eyebrow-size);
  line-height: var(--public-text-eyebrow-lh);
  font-weight: var(--public-text-eyebrow-weight);
  letter-spacing: var(--public-text-eyebrow-ls);
  color: var(--public-color-text-secondary);
}

.t-body-lead {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--public-text-body-lead-size);
  line-height: var(--public-text-body-lead-lh);
  font-weight: var(--public-text-body-lead-weight);
  letter-spacing: var(--public-text-body-lead-ls);
  color: var(--public-color-text-tertiary);
}

.t-body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--public-text-body-size);
  line-height: var(--public-text-body-lh);
  font-weight: var(--public-text-body-weight);
  letter-spacing: var(--public-text-body-ls);
  color: var(--public-color-text-tertiary);
}

/* Body Small — 14px / lh 1.5 / 400 / text-tertiary (NEW in spec v2) */
.t-body-small {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--public-text-body-small-size);
  line-height: var(--public-text-body-small-lh);
  font-weight: var(--public-text-body-small-weight);
  letter-spacing: var(--public-text-body-small-ls);
  color: var(--public-color-text-tertiary);
}

/* Button label typography — surface (radius/padding/colour) lives elsewhere. */
.t-button {
  font-family: var(--font-body);
  font-size: var(--public-text-button-size);
  line-height: var(--public-text-button-lh);
  font-weight: var(--public-text-button-weight);
  letter-spacing: var(--public-text-button-ls);
}

/* Header Nav-Labels — Source Sans 3 / 500 / 16px / lh 1.25 / text-secondary */
.t-header-nav-label {
  font-family: var(--font-body);
  font-size: var(--public-text-header-nav-size);
  line-height: var(--public-text-header-nav-lh);
  font-weight: var(--public-text-header-nav-weight);
  letter-spacing: var(--public-text-header-nav-ls);
  color: var(--public-color-text-secondary);
}

/* Footer Nav-Labels — Source Sans 3 / 400 / 16px / lh 2.0 / text-secondary */
.t-footer-nav-label {
  font-family: var(--font-body);
  font-size: var(--public-text-footer-nav-size);
  line-height: var(--public-text-footer-nav-lh);
  font-weight: var(--public-text-footer-nav-weight);
  letter-spacing: var(--public-text-footer-nav-ls);
  color: var(--public-color-text-secondary);
}

/* Badges — Source Sans 3 / 600 / 14px / lh 1.25 / text-secondary (NEW in spec v2) */
.t-badge {
  font-family: var(--font-body);
  font-size: var(--public-text-badge-size);
  line-height: var(--public-text-badge-lh);
  font-weight: var(--public-text-badge-weight);
  letter-spacing: var(--public-text-badge-ls);
  color: var(--public-color-text-secondary);
}

/* Caption — Source Sans 3 / 400 / 12px / lh 1.5 / text-quaternary (NEW in spec v2) */
.t-caption {
  font-family: var(--font-body);
  font-size: var(--public-text-caption-size);
  line-height: var(--public-text-caption-lh);
  font-weight: var(--public-text-caption-weight);
  letter-spacing: var(--public-text-caption-ls);
  color: var(--public-color-text-quaternary);
}

/* Divider — 1px rule above footer only (per spec §4) */
.t-divider {
  height: 1px;
  background: var(--public-color-divider);
  border: 0;
}

/*
 * Mobile breakpoint (<720px) — discrete size shrinkage for the three smaller
 * heading styles. Display Hero and Heading Section already shrink fluidly via
 * clamp() in their tokens, so they don't need an override here.
 */
@media (max-width: 720px) {
  .t-heading-serif-card {
    font-size: var(--public-text-heading-serif-card-size-mobile);
  }
  .t-heading-card {
    font-size: var(--public-text-heading-card-size-mobile);
  }
  .t-heading-small {
    font-size: var(--public-text-heading-small-size-mobile);
  }

  /*
   * Site header mobile collapse — hide the inline Login/Join row, reveal
   * the hamburger toggle. The runtime script in PublicSiteHeader.astro
   * toggles `is-open` on the .rask-site-header and opens
   * .rask-site-nav-mobile (which is `hidden` until then).
   *
   * Grid: drop the centred-nav middle column on mobile (logo + toggle).
   * Primary nav links collapse into the mobile drop-panel instead.
   */
  .rask-site-nav {
    grid-template-columns: 1fr auto;
    padding: 12px 20px;
    min-height: 64px;
  }

  .rask-site-nav-links {
    display: none;
  }

  .rask-site-nav-actions {
    display: none;
  }

  .rask-site-nav-toggle {
    display: inline-flex;
  }

  /*
   * Mobile drop-panel reveal. Default rule above hides it via display:none
   * at every viewport; this rule only fires when (a) we're on mobile AND
   * (b) the runtime script has added .is-open to the header. Above 720px
   * the panel stays display:none even if `is-open` is set, which is the
   * safety net for the resize-while-open case.
   */
  .rask-site-header.is-open .rask-site-nav-mobile {
    display: block;
  }
}
