/* ==========================================================================
   EPC Checkout Design System Tokens
   Scoped under .wag-checkout to avoid leaking into landing, account, or admin.
   Load AFTER checkout.css / plans.css to override via specificity.
   ========================================================================== */

/* --- @font-face: IBM Plex Sans (self-hosted) --- */

@font-face {
  font-family: 'IBM Plex Sans';
  src: url('../fonts/ibm-plex-sans/IBMPlexSans-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'IBM Plex Sans';
  src: url('../fonts/ibm-plex-sans/IBMPlexSans-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'IBM Plex Sans';
  src: url('../fonts/ibm-plex-sans/IBMPlexSans-SemiBold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'IBM Plex Sans';
  src: url('../fonts/ibm-plex-sans/IBMPlexSans-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* --- Design Tokens (Custom Properties) --- */

:root {
  /* Colors: Primary */
  --wag-teal-dark: #12333c;
  --wag-teal: #22484c;
  --wag-teal-accent: #125f75;
  --wag-orange: #b1523f;
  --wag-orange-hover: #9b4331;
  --wag-coral: #ee614e;

  /* Colors: Neutrals */
  --wag-charcoal: #343737;
  --wag-text: #171b1ce0;
  --wag-muted: #616767;
  --wag-placeholder: #9b9b9b;
  --wag-border: #e0e0e0;
  --wag-border-light: #e6e6e6;
  --wag-bg-grey: #f0f0f0;

  /* Colors: Warm / Cool */
  --wag-cream: #fcece2;
  --wag-cream-light: #f8f1e6;
  --wag-warm-bg: #ffefe4;
  --wag-warm-border: #e2bfa4;
  --wag-teal-light-bg: #cee0e0;
  --wag-blue-light: #f0f5f5;
  --wag-off-white: #f7f6f1;

  /* Colors: Semantic */
  --wag-success: #17b584;
  --wag-success-bg: rgba(20, 182, 133, 0.05);
  --wag-success-border: #cae3db;
  --wag-error: #b2320f;
  --wag-link: #1378d1;

  /* Typography */
  --wag-font-heading: 'Lora', Georgia, 'Times New Roman', serif;
  --wag-font-body: 'IBM Plex Sans', -apple-system, system-ui, 'Segoe UI', Helvetica, Arial, sans-serif;
  --wag-font-ui: 'Inter', var(--wag-font-body);

  /* Type Scale (desktop) */
  --wag-text-xs: 0.75rem;
  --wag-text-sm: 0.875rem;
  --wag-text-base: 1rem;
  --wag-text-md: 1.125rem;
  --wag-text-lg: 1.25rem;
  --wag-text-xl: 1.5rem;
  --wag-text-2xl: 2rem;
  --wag-text-3xl: 2.5rem;

  /* Spacing */
  --wag-space-xs: 0.25rem;
  --wag-space-sm: 0.5rem;
  --wag-space-md: 0.75rem;
  --wag-space-base: 1rem;
  --wag-space-lg: 1.5rem;
  --wag-space-xl: 2rem;
  --wag-space-2xl: 3.5rem;

  /* Border Radius */
  --wag-radius-sm: 4px;
  --wag-radius-md: 8px;
  --wag-radius-lg: 12px;
  --wag-radius-xl: 20px;
  --wag-radius-pill: 100px;

  /* Shadows */
  --wag-shadow-sm: 4px 4px 20px 5px rgba(0, 0, 0, 0.09);
  --wag-shadow-md: 0 8px 32px 0 rgba(0, 0, 0, 0.06);
  --wag-shadow-lg: 0 8px 48px rgba(0, 0, 0, 0.12);

  /* Container */
  --wag-container-max: 960px;
  --wag-container-narrow: 450px;
  --wag-container-padding: 1.5rem;
}

/* ==========================================================================
   Base Scope
   ========================================================================== */

.wag-checkout {
  font-family: var(--wag-font-body);
  color: var(--wag-text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.wag-checkout h1,
.wag-checkout h2,
.wag-checkout h3 {
  font-family: var(--wag-font-heading);
  color: var(--wag-teal-dark);
  line-height: 1.25;
  font-weight: 400;
}

.wag-checkout h1 {
  font-size: var(--wag-text-2xl);
  margin-bottom: var(--wag-space-lg);
}

.wag-checkout h2 {
  font-size: var(--wag-text-xl);
  margin-bottom: var(--wag-space-base);
}

.wag-checkout h4,
.wag-checkout p,
.wag-checkout label,
.wag-checkout span,
.wag-checkout div {
  font-family: var(--wag-font-body);
}

/* ==========================================================================
   Header + Navigation
   ========================================================================== */

.wag-checkout #header {
  background-color: #ffffff;
  border-bottom: 2px solid rgba(75, 75, 75, 0.2);
}

.wag-checkout #header nav.wrapper {
  background-color: #ffffff;
}

.wag-checkout .step-counter,
.wag-checkout .step-counter.ng-binding {
  color: var(--wag-muted);
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-sm);
  font-weight: 400;
}

.wag-checkout #footer {
  background-color: var(--wag-teal-dark);
}

.wag-checkout #footer .legal {
  color: rgba(255, 255, 255, 0.6);
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-xs);
}

.wag-checkout #footer .legal a,
.wag-checkout #footer a.legal {
  color: rgba(255, 255, 255, 0.6);
}

.wag-checkout #footer a.legal:hover {
  color: #fff;
}

/* ==========================================================================
   Progress Bar
   ========================================================================== */

.wag-checkout .step-progress-bar {
  background-color: var(--wag-border);
  height: 6px;
}

.wag-checkout .step-progress-bar .step-progress {
  background-color: var(--wag-coral);
  height: 6px;
  transition: width 0.4s ease;
}

.wag-checkout .wag-step-counter {
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-sm);
  color: rgba(255, 255, 255, 0.7);
  font-weight: 400;
}

/* ==========================================================================
   Cards
   ========================================================================== */

.wag-checkout .wag-card {
  background: #ffffff;
  border-radius: var(--wag-radius-lg);
  box-shadow: var(--wag-shadow-md);
  padding: var(--wag-space-lg);
}

.wag-checkout .wag-card--warm {
  background: var(--wag-warm-bg);
  border: 1px solid var(--wag-warm-border);
  border-radius: var(--wag-radius-md);
  padding: var(--wag-space-lg);
}

/* Override legacy .grey-background with card styling */
.wag-checkout .group.rounded.grey-background {
  background: #ffffff;
  border-radius: var(--wag-radius-lg);
  box-shadow: var(--wag-shadow-md);
  border: none;
}

/* ==========================================================================
   Section Heading (Serif)
   ========================================================================== */

.wag-checkout .wag-section-heading {
  font-family: var(--wag-font-heading);
  font-size: var(--wag-text-xl);
  font-weight: 400;
  color: var(--wag-teal-dark);
  line-height: 1.25;
  margin-bottom: var(--wag-space-base);
}

/* ==========================================================================
   Form Components
   ========================================================================== */

.wag-checkout label {
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-sm);
  font-weight: 500;
  color: var(--wag-charcoal);
  display: block;
  margin-bottom: var(--wag-space-xs);
}

.wag-checkout input[type="text"],
.wag-checkout input[type="tel"],
.wag-checkout input[type="number"],
.wag-checkout input[type="email"],
.wag-checkout select {
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-base);
  color: var(--wag-text);
  background: #ffffff;
  border: 1px solid var(--wag-border);
  border-radius: var(--wag-radius-md);
  padding: 0 var(--wag-space-base);
  height: 48px;
  line-height: 48px;
  width: 100%;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  box-sizing: border-box;
}

.wag-checkout input[type="text"]:focus,
.wag-checkout input[type="tel"]:focus,
.wag-checkout input[type="number"]:focus,
.wag-checkout input[type="email"]:focus,
.wag-checkout select:focus {
  border-color: var(--wag-teal);
  outline: 2px solid var(--wag-teal);
  outline-offset: 2px;
  box-shadow: none;
}

.wag-checkout input::placeholder {
  color: var(--wag-placeholder);
  font-weight: 400;
}

.wag-checkout select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23616767' d='M1.41 0L6 4.58 10.59 0 12 1.41l-6 6-6-6z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
}

/* Radio buttons as selectable cards */
.wag-checkout .radio label {
  display: flex;
  align-items: flex-start;
  gap: var(--wag-space-md);
  background: #ffffff;
  border: 1px solid var(--wag-border);
  border-radius: var(--wag-radius-lg);
  padding: var(--wag-space-base) var(--wag-space-lg);
  margin-bottom: var(--wag-space-sm);
  cursor: pointer;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

.wag-checkout .radio label:hover {
  border-color: var(--wag-teal-accent);
}

.wag-checkout .radio input[type="radio"]:checked + p,
.wag-checkout .radio input[type="radio"]:checked ~ p {
  color: var(--wag-teal-dark);
  font-weight: 600;
}

.wag-checkout .radio label:has(input[type="radio"]:checked) {
  border-color: var(--wag-teal);
  background-color: var(--wag-blue-light);
}

.wag-checkout .radio input[type="radio"] {
  accent-color: var(--wag-teal);
  width: 20px;
  height: 20px;
  margin-top: 2px;
  flex-shrink: 0;
}

/* Validation error styling */
.wag-checkout .error,
.wag-checkout label.error {
  color: var(--wag-error);
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-sm);
}

.wag-checkout .errorHolder label.error {
  color: var(--wag-error);
}

/* ==========================================================================
   CTA Buttons
   ========================================================================== */

.wag-checkout .wag-btn-primary,
.wag-checkout input.wag-btn-primary,
.wag-checkout button.wag-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--wag-coral);
  color: #ffffff;
  font-family: var(--wag-font-ui);
  font-size: var(--wag-text-md);
  font-weight: 600;
  padding: 20px 21px;
  border: 1px solid var(--wag-coral);
  border-radius: var(--wag-radius-lg);
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.1s ease;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  min-width: 200px;
}

.wag-checkout .wag-btn-primary:hover,
.wag-checkout input.wag-btn-primary:hover,
.wag-checkout button.wag-btn-primary:hover {
  background-color: var(--wag-orange);
  border-color: var(--wag-orange);
}

.wag-checkout .wag-btn-primary:active,
.wag-checkout input.wag-btn-primary:active,
.wag-checkout button.wag-btn-primary:active {
  background-color: var(--wag-orange-hover);
  border-color: var(--wag-orange-hover);
  transform: translateY(1px);
}

.wag-checkout .wag-btn-primary:focus-visible,
.wag-checkout input.wag-btn-primary:focus-visible,
.wag-checkout button.wag-btn-primary:focus-visible {
  outline: 2px solid var(--wag-teal);
  outline-offset: 2px;
}

.wag-checkout .wag-btn-secondary,
.wag-checkout input.wag-btn-secondary,
.wag-checkout button.wag-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--wag-teal);
  color: #ffffff;
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-md);
  font-weight: 600;
  padding: 16px 32px;
  border: 2px solid var(--wag-teal);
  border-radius: var(--wag-radius-sm);
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  min-width: 160px;
}

.wag-checkout .wag-btn-secondary:hover,
.wag-checkout input.wag-btn-secondary:hover,
.wag-checkout button.wag-btn-secondary:hover {
  background-color: var(--wag-teal-accent);
  border-color: var(--wag-teal-accent);
}

.wag-checkout .wag-btn-secondary:focus-visible,
.wag-checkout input.wag-btn-secondary:focus-visible,
.wag-checkout button.wag-btn-secondary:focus-visible {
  outline: 2px solid var(--wag-coral);
  outline-offset: 2px;
}

/* Override legacy .green button class */
.wag-checkout .purchase.green,
.wag-checkout button.green,
.wag-checkout input.purchase.green {
  background-color: var(--wag-coral);
  color: #ffffff;
  font-family: var(--wag-font-ui);
  font-size: var(--wag-text-md);
  font-weight: 600;
  padding: 20px 21px;
  border: 1px solid var(--wag-coral);
  border-radius: var(--wag-radius-lg);
  text-transform: none;
  letter-spacing: 0;
  height: auto;
  line-height: 1;
}

.wag-checkout .purchase.green:hover,
.wag-checkout button.green:hover,
.wag-checkout input.purchase.green:hover {
  background-color: var(--wag-orange);
  border-color: var(--wag-orange);
}

.wag-checkout .purchase.green:focus-visible,
.wag-checkout button.green:focus-visible,
.wag-checkout input.purchase.green:focus-visible {
  outline: 2px solid var(--wag-teal);
  outline-offset: 2px;
}

/* PleaseWait button state */
.wag-checkout .pleaseWaitButton {
  background-color: var(--wag-coral) !important;
  opacity: 0.65;
  font-family: var(--wag-font-ui);
  font-size: var(--wag-text-md);
  font-weight: 600;
  padding: 20px 21px;
  border: 1px solid var(--wag-coral);
  border-radius: var(--wag-radius-lg);
  text-transform: none;
  letter-spacing: 0;
  height: auto;
  line-height: 1;
  cursor: wait;
}

/* ==========================================================================
   Action Block — centers CTAs + guarantee banners at consistent width
   ========================================================================== */

.wag-checkout .wag-action-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 450px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.wag-checkout .wag-action-block .wag-btn-primary,
.wag-checkout .wag-action-block input.wag-btn-primary,
.wag-checkout .wag-action-block button.wag-btn-primary,
.wag-checkout .wag-action-block .wag-btn-secondary,
.wag-checkout .wag-action-block input.wag-btn-secondary,
.wag-checkout .wag-action-block button.wag-btn-secondary,
.wag-checkout .wag-action-block .purchase.green,
.wag-checkout .wag-action-block input.purchase.green {
  width: 100%;
  max-width: 100% !important;
}

.wag-checkout .wag-action-block .wag-guarantee-banner {
  width: 100%;
}

.wag-checkout .wag-action-block .btns-row {
  width: 100%;
  display: flex;
  gap: var(--wag-space-md);
}

.wag-checkout .wag-action-block .btns-row .wag-btn-primary,
.wag-checkout .wag-action-block .btns-row .wag-btn-secondary {
  flex: 1;
  min-width: 0;
}

/* Legacy btn-wrapper centering for product select */
.wag-checkout .btn-wrapper.text-center {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.wag-checkout .btn-wrapper.text-center form {
  width: 100%;
  max-width: 450px;
}

.wag-checkout .btn-wrapper.text-center .wag-btn-primary,
.wag-checkout .btn-wrapper.text-center button.wag-btn-primary,
.wag-checkout .btn-wrapper.text-center input.wag-btn-primary,
.wag-checkout .btn-wrapper.text-center .purchase.green {
  width: 100%;
  max-width: 100% !important;
}

.wag-checkout .btn-wrapper.text-center .wag-guarantee-banner {
  width: 100%;
  max-width: 450px;
}

/* ==========================================================================
   Trust Strip
   ========================================================================== */

.wag-checkout .wag-trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--wag-space-base);
  justify-content: center;
  padding: var(--wag-space-lg) var(--wag-space-base);
  margin: var(--wag-space-lg) 0;
}

.wag-checkout .wag-trust-badge {
  display: flex;
  align-items: center;
  gap: var(--wag-space-sm);
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-sm);
  font-weight: 500;
  color: var(--wag-teal-dark);
  white-space: nowrap;
}

.wag-checkout .wag-trust-badge .wag-trust-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

/* ==========================================================================
   Guarantee Banner
   ========================================================================== */

.wag-checkout .wag-guarantee-banner {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--wag-space-sm);
  background-color: var(--wag-success-bg);
  border: 1px solid var(--wag-success-border);
  border-radius: var(--wag-radius-lg);
  padding: var(--wag-space-md) var(--wag-space-lg);
  margin: var(--wag-space-base) 0;
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-sm);
  font-weight: 500;
  color: var(--wag-teal-dark);
  text-align: center;
  line-height: 1.4;
}

.wag-checkout .wag-guarantee-banner svg {
  flex-shrink: 0;
  color: var(--wag-success);
}

/* ==========================================================================
   Microcopy (helper text below fields)
   ========================================================================== */

.wag-checkout .wag-microcopy {
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-xs);
  color: var(--wag-muted);
  margin-top: var(--wag-space-xs);
  line-height: 1.5;
}

/* ==========================================================================
   Order Summary
   ========================================================================== */

.wag-checkout .summary-content h4 {
  font-family: var(--wag-font-body);
  font-weight: 400;
  color: var(--wag-text);
}

.wag-checkout .summary-content .total h4 {
  font-family: var(--wag-font-ui);
  font-weight: 600;
  color: var(--wag-teal-dark);
}

.wag-checkout .summary-content .bold {
  font-weight: 600;
}

/* ==========================================================================
   Page-level heading overrides
   ========================================================================== */

.wag-checkout .subheader h1,
.wag-checkout .section-heading h1 {
  font-family: var(--wag-font-heading);
  color: var(--wag-teal-dark);
  font-weight: 400;
}

.wag-checkout .group-content h2 {
  font-family: var(--wag-font-heading);
  color: var(--wag-teal-dark);
  font-size: var(--wag-text-lg);
  font-weight: 400;
}

/* ==========================================================================
   Product Select Overrides
   ========================================================================== */

.wag-checkout #plan-container .section-heading h1 {
  font-family: var(--wag-font-heading);
  font-size: var(--wag-text-2xl);
  color: var(--wag-teal-dark);
}

.wag-checkout .pricing-term-toggle {
  border-radius: var(--wag-radius-pill);
}

/* ==========================================================================
   Prequalification Page Overrides
   ========================================================================== */

.wag-checkout .prequalify-wrapper .section-heading h1 {
  font-family: var(--wag-font-heading);
  color: var(--wag-teal-dark);
  font-size: var(--wag-text-xl);
  font-weight: 400;
}

.wag-checkout .prequalify-wrapper .section-heading h2 {
  font-family: var(--wag-font-body);
  color: var(--wag-muted);
  font-size: var(--wag-text-base);
  font-weight: 400;
}

/* Therapist availability count: warm urgency, not error red */
.wag-checkout #divTherapistsOnline {
  color: var(--wag-coral) !important;
  font-weight: 600;
}

/* ==========================================================================
   ESA Acceptance Protection Overrides (standalone page)
   ========================================================================== */

.wag-checkout .pr-box {
  background: var(--wag-warm-bg);
  border: 1px solid var(--wag-warm-border);
  border-radius: var(--wag-radius-md);
  padding: var(--wag-space-lg);
}

.wag-checkout .pr-box .pr {
  font-family: var(--wag-font-ui);
  font-weight: 700;
  color: var(--wag-teal-dark);
}

/* ==========================================================================
   Thank You Page
   ========================================================================== */

.wag-checkout .wag-success-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  background-color: var(--wag-success-bg);
  border-radius: 50%;
  margin: 0 auto var(--wag-space-lg);
}

.wag-checkout .wag-success-icon svg {
  width: 32px;
  height: 32px;
  color: var(--wag-success);
}

/* ==========================================================================
   PrequalifyCompleteV4 (Scoring Animation)
   ========================================================================== */

.wag-checkout .title h1 {
  font-family: var(--wag-font-heading);
  color: var(--wag-teal-dark);
}

.wag-checkout .loader-text {
  font-family: var(--wag-font-body);
  font-size: var(--wag-text-md);
  color: var(--wag-text);
}

.wag-checkout .loader-bg {
  background-color: var(--wag-coral) !important;
}

/* ==========================================================================
   Responsive: Mobile-First Overrides
   ========================================================================== */

/* Base: mobile (0-767px) — body text LARGER (16px), headings shrink 20-25% */
@media (max-width: 767px) {
  .wag-checkout {
    font-size: var(--wag-text-base);
  }

  .wag-checkout h1 {
    font-size: var(--wag-text-xl);
  }

  .wag-checkout h2 {
    font-size: var(--wag-text-lg);
  }

  .wag-checkout .group-content h2 {
    font-size: var(--wag-text-md);
  }

  .wag-checkout .wag-section-heading {
    font-size: var(--wag-text-lg);
  }

  /* CTAs go full-width on mobile */
  .wag-checkout .wag-btn-primary,
  .wag-checkout input.wag-btn-primary,
  .wag-checkout button.wag-btn-primary,
  .wag-checkout .purchase.green,
  .wag-checkout button.green,
  .wag-checkout input.purchase.green {
    width: 100%;
    max-width: 100%;
    font-size: var(--wag-text-base);
    padding: 16px 24px;
    min-height: 52px;
  }

  .wag-checkout .wag-btn-secondary,
  .wag-checkout input.wag-btn-secondary,
  .wag-checkout button.wag-btn-secondary {
    width: 100%;
    max-width: 100%;
    font-size: var(--wag-text-base);
    min-height: 52px;
  }

  .wag-checkout .pleaseWaitButton {
    width: 100%;
    max-width: 100%;
    font-size: var(--wag-text-base);
    padding: 16px 24px;
    min-height: 52px;
  }

  /* Trust strip stacks vertically */
  .wag-checkout .wag-trust-strip {
    flex-direction: column;
    align-items: center;
    gap: var(--wag-space-md);
  }

  .wag-checkout .wag-guarantee-banner {
    width: 100%;
    font-size: var(--wag-text-xs);
    padding: var(--wag-space-sm) var(--wag-space-base);
  }

  .wag-checkout .radio label {
    padding: var(--wag-space-md) var(--wag-space-base);
  }

  /* Container padding tightens on mobile */
  .wag-checkout .wrapper {
    padding-left: var(--wag-space-lg);
    padding-right: var(--wag-space-lg);
  }

  /* Sidebar collapses below form on mobile (handled by legacy CSS) */
  .wag-checkout .col.one-third {
    display: none;
  }

  /* Ensure mobile summary is visible */
  .wag-checkout #summary.mobile {
    display: block;
  }

  /* Cards fill width */
  .wag-checkout .wag-card,
  .wag-checkout .wag-card--warm {
    border-radius: var(--wag-radius-md);
  }

  /* Form input touch targets */
  .wag-checkout input[type="text"],
  .wag-checkout input[type="tel"],
  .wag-checkout input[type="number"],
  .wag-checkout input[type="email"],
  .wag-checkout select {
    height: 52px;
    line-height: 52px;
    font-size: var(--wag-text-base);
  }

  /* ESA page buttons stack */
  .wag-checkout .btns-row {
    flex-direction: column;
    gap: var(--wag-space-md);
  }
}

/* Tablet/Desktop: 768px+ */
@media (min-width: 768px) {
  .wag-checkout h1 {
    font-size: var(--wag-text-2xl);
  }

  .wag-checkout h2 {
    font-size: var(--wag-text-xl);
  }
}

/* Desktop: 992px+ — body text at Pettable design-spec size (13.3px) */
@media (min-width: 992px) {
  .wag-checkout {
    font-size: 13.3px;
  }

  .wag-checkout h1 {
    font-size: var(--wag-text-2xl);
  }
}

/* ==========================================================================
   Reference ALIAS LAYER
   Maps existing --wag-* tokens to the canonical Reference token values from
   tokens/wag-tokens.css. This way all the mockup component CSS keeps working
   while the design tokens are correct. Source: DESIGN.md (Reference Clinical Funnel).
   ========================================================================== */

:root {
  /* Re-point every --wag-* color to the real Reference value */
  --wag-coral:         #ff5c39;   /* was #ee614e */
  --wag-orange:        #ff5c39;
  --wag-orange-hover:  #e8462b;   /* coral-deep */
  --wag-teal-dark:     #1d3a44;   /* navy-deep, used as primary ink-on-light */
  --wag-teal:          #05727a;   /* primary teal */
  --wag-teal-accent:   #0d6e75;   /* primary-deep */
  --wag-text:          #191717;   /* ink */
  --wag-muted:         #2e3644;   /* ink-slate */
  --wag-cream:         #f6f4ee;   /* surface */
  --wag-cream-light:   #f6f4ee;
  --wag-warm-bg:       #f6f4ee;
  --wag-warm-border:   #d3c9b4;   /* surface-warm-tan */
  --wag-teal-light-bg: #dcf5f0;   /* mint-pale */
  --wag-blue-light:    #dcf5f0;
  --wag-off-white:     #f6f4ee;
  --wag-success:       #799f2d;   /* success-green */
  --wag-success-bg:    rgba(121,159,45,0.08);
  --wag-success-border:#cae3db;
  --wag-mint:          #b4e0d8;   /* surface-mint */

  /* Fonts — Reference uses Source Serif 4 for display, Inter for everything else */
  --wag-font-heading:  'Source Serif 4', 'Newsreader', 'Tiempos Headline', Georgia, serif;
  --wag-font-body:     'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --wag-font-ui:       'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;

  /* Radius — Reference tab-card shape */
  --wag-radius-tab:    32px 32px 0 0;
}
