    :root {
      --color-bg: #fff9f2;
      --color-surface: #fffdf9;
      --color-surface-soft: #fff4ea;
      --color-line: #f2ded0;
      --color-line-strong: #e9b9a4;
      --color-primary: #CC4E00;
      --color-primary-hover: #B94F2D;
      --color-primary-strong: #B94F2D;
      --color-primary-soft: #ffe2d8;
      --color-primary-muted: #f28b69;
      --color-ink: #321f20;
      --color-muted: #6f5c58;
      --color-secondary: #A78E92;
      --color-secondary-soft: rgba(191, 162, 164, 0.18);
      --shadow-card: 0 28px 80px rgba(117, 64, 38, 0.12);
      --shadow-button: 0 16px 30px rgba(223, 95, 64, 0.22);
      --radius-card: 20px;
      --radius-panel: 28px;
      --radius-control: 12px;
      --section-icon-size: 66px;
      --section-icon-font-size: 31px;
      --space-page: clamp(16px, 3vw, 56px);
      --font-display: "Plus Jakarta Sans", system-ui, sans-serif;
      --font-body: "Be Vietnam Pro", system-ui, sans-serif;
    }

    * {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      margin: 0;
      background:
        radial-gradient(circle at 12% 18%, rgba(223, 95, 64, 0.08), transparent 24%),
        linear-gradient(180deg, #fffaf5 0%, #fff7ef 52%, #fffdf9 100%);
      color: var(--color-ink);
      font-family: var(--font-body);
      min-height: 100vh;
    }

    a {
      color: inherit;
      text-decoration: none;
    }

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

    .material-symbols-outlined {
      font-variation-settings: "FILL" 0, "wght" 500, "GRAD" 0, "opsz" 24;
    }

    .page-shell {
      width: 100%;
      margin: 0;
      border: 0;
      border-radius: 0;
      overflow: hidden;
      background: rgba(255, 253, 249, 0.86);
      box-shadow: var(--shadow-card);
    }

    doggo-banner {
      display: block;
    }

    .beta-strip {
      position: relative;
      min-height: 72px;
      display: flex;
      align-items: center;
      justify-content: flex-start;
      gap: 18px;
      padding: 16px var(--space-page);
      background: var(--color-primary);
      color: white;
      font-family: var(--font-display);
      font-size: clamp(17px, 2vw, 22px);
      font-weight: 800;
      letter-spacing: -0.01em;
    }

    .beta-strip .banner-brand {
      flex: 0 0 auto;
      margin: 0;
      color: white;
      font-size: 22px;
      line-height: 1;
      gap: 12px;
    }

    .beta-strip .banner-brand .brand-mark {
      width: 42px;
      height: 42px;
      box-shadow: none;
      background: rgba(255, 255, 255, 0.18);
    }

    .beta-strip .banner-brand .brand-mark .material-symbols-outlined {
      font-size: 22px;
    }

    .banner-message {
      display: block;
      flex: 1 1 auto;
      min-width: 0;
      text-align: center;
      width: auto;
      max-width: none;
      margin: 0;
      padding: 0;
      line-height: 1.2;
    }

    .pill {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 36px;
      padding: 0 16px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.58);
      color: var(--color-primary-strong);
      font-size: 18px;
      font-weight: 800;
      text-transform: uppercase;
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.46);
    }

    .cookie-consent {
      position: fixed;
      left: 16px;
      right: 16px;
      bottom: 16px;
      z-index: 1000;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
      width: min(980px, calc(100% - 32px));
      margin: 0 auto;
      padding: 18px;
      border: 1px solid rgba(233, 185, 164, 0.82);
      border-radius: var(--radius-control);
      background: rgba(255, 253, 249, 0.98);
      box-shadow: 0 18px 52px rgba(50, 31, 32, 0.18);
      color: var(--color-ink);
    }

    .cookie-consent-copy {
      display: grid;
      gap: 6px;
      min-width: 0;
    }

    .cookie-consent-copy strong {
      font-family: var(--font-display);
      font-size: 17px;
      font-weight: 800;
    }

    .cookie-consent-copy p {
      max-width: 68ch;
      margin: 0;
      color: var(--color-muted);
      font-size: 14px;
      line-height: 1.45;
    }

    .cookie-consent-actions {
      display: flex;
      flex: 0 0 auto;
      gap: 10px;
    }

    .cookie-consent-button {
      min-height: 42px;
      padding: 0 18px;
      border: 1px solid var(--color-line-strong);
      border-radius: var(--radius-control);
      background: var(--color-surface);
      color: var(--color-primary-strong);
      font: 800 14px/1 var(--font-display);
      cursor: pointer;
    }

    .cookie-consent-button:hover {
      border-color: var(--color-primary);
      color: var(--color-primary-hover);
    }

    .cookie-consent-accept {
      border-color: var(--color-primary);
      background: var(--color-primary);
      color: white;
      box-shadow: var(--shadow-button);
    }

    .cookie-consent-accept:hover {
      background: var(--color-primary-hover);
      color: white;
    }

    .hero {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
      gap: clamp(24px, 4vw, 64px);
      align-items: center;
      width: 100%;
      min-height: calc(100svh - 72px);
      height: auto;
      padding: clamp(16px, 5vh, 64px) clamp(24px, 10vw, 160px) clamp(24px, 10vh, 120px);
      overflow: visible;
    }

    .hero-copy {
      display: grid;
      align-content: center;
      gap: 28px;
      min-width: 0;
    }

    .brand {
      display: inline-flex;
      align-items: center;
      gap: 18px;
      margin: 0;
      font-family: var(--font-display);
      color: var(--color-primary);
      font-size: clamp(32px, 3.5vw, 44px);
      font-weight: 800;
      letter-spacing: -0.03em;
    }

    .brand-mark,
    .mini-mark {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex: 0 0 auto;
      background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
      color: white;
      box-shadow: 0 14px 26px rgba(223, 95, 64, 0.24);
    }

    .brand-mark {
      width: 88px;
      height: 88px;
      border-radius: 50%;
    }

    .brand-mark .material-symbols-outlined {
      font-size: 42px;
      font-variation-settings: "FILL" 1, "wght" 650, "GRAD" 0, "opsz" 40;
    }

    h1 {
      margin: 0;
      max-width: 13ch;
      font-family: var(--font-display);
      font-size: clamp(36px, 4.4vw, 60px);
      line-height: 1.02;
      letter-spacing: -0.04em;
      font-weight: 800;
    }

    .hero-title-accent {
      color: var(--color-primary);
    }

    .city {
      display: inline-block;
      position: relative;
      width: 5.15em;
      height: 1.28em;
      color: var(--color-primary);
      vertical-align: -0.14em;
      overflow: hidden;
    }

    .city span {
      position: absolute;
      inset: 0 0 auto 0;
      line-height: 1.18;
      white-space: nowrap;
      animation: city-roll 9s cubic-bezier(0.76, 0, 0.24, 1) infinite;
      transform: translateY(115%);
      opacity: 0;
    }

    .city span:nth-child(2) {
      animation-delay: 3s;
    }

    .city span:nth-child(3) {
      animation-delay: 6s;
    }

    @keyframes city-roll {
      0% {
        transform: translateY(115%);
        opacity: 0;
      }
      8%, 30% {
        transform: translateY(0);
        opacity: 1;
      }
      38%, 100% {
        transform: translateY(-115%);
        opacity: 0;
      }
    }

    .lead {
      max-width: 62ch;
      margin: 0;
      color: var(--color-muted);
      font-size: clamp(16px, 1.35vw, 18px);
      line-height: 1.44;
      font-weight: 500;
    }

    .lead strong {
      color: var(--color-secondary);
      font-weight: 800;
    }

    .available-routes {
      display: grid;
      gap: 14px;
      width: 100%;
      max-width: 680px;
      margin-top: 10px;
      padding: 24px 26px;
      border: 1px solid rgba(214, 101, 58, 0.34);
      border-radius: var(--radius-card);
      background: white;
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      color: var(--color-primary-strong);
      font-family: var(--font-display);
      font-size: 15px;
      font-weight: 800;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }

    .eyebrow .material-symbols-outlined {
      font-size: 24px;
      font-variation-settings: "FILL" 0, "wght" 650, "GRAD" 0, "opsz" 24;
    }

    .routes-heading,
    .routes-note {
      margin: 0;
    }

    .routes-heading {
      color: var(--color-ink);
      font-family: var(--font-display);
      font-size: clamp(19px, 1.8vw, 24px);
      font-weight: 800;
      letter-spacing: -0.02em;
    }

    .route-list {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
    }

    .route-pill {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      min-height: 44px;
      padding: 0 20px;
      border: 1px solid rgba(214, 101, 58, 0.2);
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.82);
      color: var(--color-ink);
      font-family: var(--font-display);
      font-size: 17px;
      font-weight: 800;
      box-shadow: 0 10px 22px rgba(117, 64, 38, 0.08);
    }

    .route-pill .material-symbols-outlined {
      color: var(--color-primary-strong);
      font-size: 21px;
      font-variation-settings: "FILL" 0, "wght" 650, "GRAD" 0, "opsz" 24;
    }

    .routes-note {
      color: var(--color-muted);
      font-size: 15px;
      line-height: 1.4;
    }

    .trust-badges {
      display: grid;
      gap: 12px;
      margin: 4px 0 0;
      padding: 0;
      list-style: none;
      color: var(--color-ink);
      font-size: clamp(16px, 1.35vw, 18px);
      font-weight: 500;
    }

    .trust-badges li {
      display: flex;
      align-items: center;
      gap: 14px;
      min-width: 0;
    }

    .trust-icon {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex: 0 0 auto;
      width: 42px;
      height: 42px;
      border-radius: 50%;
      background: var(--color-primary);
      color: white;
    }

    .trust-icon .material-symbols-outlined {
      font-size: 24px;
      font-variation-settings: "FILL" 0, "wght" 650, "GRAD" 0, "opsz" 24;
    }

    .date-flexible-checkbox {
      margin-bottom: 18px;
    }

    .date-flexible-copy {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      min-width: 0;
    }

    .field-help {
      position: relative;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex: 0 0 auto;
      width: 18px;
      height: 18px;
      color: var(--color-muted);
      font-size: 16px;
      line-height: 1;
      cursor: help;
      outline: none;
      #font-variation-settings: "FILL" 0, "wght" 650, "GRAD" 0, "opsz" 20;
    }

    .field-help::after {
      content: "Nous vous proposerons aussi les trajets proches de cette date.";
      position: absolute;
      left: 50%;
      bottom: calc(100% + 10px);
      z-index: 5;
      padding: 10px 12px;
      border: 1px solid var(--color-line);
      border-radius: 10px;
      background: var(--color-ink);
      color: white;
      font-family: var(--font-body);
      font-size: 12px;
      font-weight: 600;
      line-height: 1.4;
      text-align: left;
      text-transform: none;
      letter-spacing: 0;
      box-shadow: 0 12px 28px rgba(50, 31, 32, 0.18);
      opacity: 0;
      pointer-events: none;
      transform: translate(-50%, 4px);
      transition: opacity 160ms ease, transform 160ms ease;
    }

    .field-help:hover::after,
    .field-help:focus-visible::after {
      opacity: 1;
      transform: translate(-50%, 0);
    }

    .field-help:focus-visible {
      box-shadow: 0 0 0 3px rgba(214, 101, 58, 0.18);
    }

    .actions {
      display: grid;
      gap: 14px;
      max-width: 560px;
      margin-top: 8px;
    }

    .button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 18px;
      min-height: 56px;
      padding: 0 36px;
      border-radius: var(--radius-control);
      border: 1px solid transparent;
      font-family: var(--font-display);
      font-size: clamp(16px, 1.3vw, 18px);
      font-weight: 800;
      transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
    }

    .button:hover {
      transform: translateY(-2px);
    }

    .button:disabled {
      cursor: wait;
      opacity: 0.72;
      transform: none;
    }

    .button-primary {
      color: white;
      background: linear-gradient(180deg, var(--color-primary) 0%, var(--color-primary-hover) 100%);
      box-shadow: var(--shadow-button);
    }

    .button-primary:hover {
      background: linear-gradient(180deg, var(--color-primary-hover) 0%, var(--color-primary-hover) 100%);
    }

    .button-secondary {
      color: var(--color-ink);
      background: rgba(255, 253, 249, 0.72);
      border-color: var(--color-line-strong);
    }

    .button-secondary .material-symbols-outlined {
      color: #9a6b53;
    }

    .visual {
      position: relative;
      justify-self: stretch;
      width: 100%;
      height: auto;
      min-height: 0;
      max-height: none;
      border: 1px solid rgba(79, 49, 35, 0.12);
      border-radius: var(--radius-panel);
      overflow: hidden;
      background: #d8b082;
      box-shadow: 0 30px 60px rgba(70, 42, 24, 0.2);
      isolation: isolate;
    }

    .visual img {
      width: 100%;
      height: 100%;
      min-height: 0;
      object-fit: contain;
      object-position: center center;
      background: linear-gradient(180deg, #f8f3ef 0%, #efe3db 100%);
      filter: saturate(1.06) contrast(1.03) brightness(1.02);
    }

    .visual::after {
      content: "";
      position: absolute;
      inset: auto 0 0;
      height: 28%;
      background: linear-gradient(180deg, transparent 0%, rgba(40, 24, 18, 0.44) 100%);
      z-index: 1;
      pointer-events: none;
    }

    .notice {
      position: absolute;
      left: 18px;
      right: 18px;
      bottom: 18px;
      z-index: 2;
      display: grid;
      grid-template-columns: 52px minmax(0, 1fr);
      gap: 18px;
      align-items: center;
      padding: 22px 28px;
      border: 1px solid rgba(122, 84, 199, 0.15);
      border-radius: 18px;
      background: rgba(250, 244, 255, 0.92);
      color: var(--color-ink);
      box-shadow: 0 18px 36px rgba(38, 23, 23, 0.18);
      backdrop-filter: blur(16px);
    }

    .mini-mark {
      width: 44px;
      height: 44px;
      border-radius: 50%;
      background: var(--color-secondary-soft);
      color: var(--color-secondary);
      box-shadow: none;
    }

    .mini-mark .material-symbols-outlined {
      font-variation-settings: "FILL" 1, "wght" 650, "GRAD" 0, "opsz" 24;
    }

    .notice-title {
      margin: 0 0 6px;
      font-family: var(--font-display);
      font-size: clamp(18px, 2vw, 22px);
      font-weight: 800;
      letter-spacing: -0.02em;
    }

    .notice p:last-child {
      margin: 0;
      color: #5e5356;
      font-size: clamp(15px, 1.6vw, 18px);
      line-height: 1.55;
      font-weight: 500;
    }

    .section {
      padding: clamp(64px, 8vw, 96px) var(--space-page);
      border-top: 1px solid var(--color-line);
    }

    .signup-section {
      background: var(--color-surface);
    }

    .signup-section .section-title,
    #faq .section-title {
      text-align: center;
    }

    .signup-section .section-copy {
      text-align: center;
    }

    .section-inner {
      width: min(100%, 1440px);
      margin: 0 auto;
    }

    .section-title {
      margin: 0 0 14px;
      font-family: var(--font-display);
      font-size: clamp(32px, 4vw, 48px);
      line-height: 1.1;
      letter-spacing: -0.035em;
    }

    .section-kicker {
      margin: 0 0 16px;
      color: var(--color-primary-strong);
      font-family: var(--font-display);
      font-size: 14px;
      font-weight: 800;
      letter-spacing: 0.12em;
      text-align: center;
      text-transform: uppercase;
    }

    .section-copy {
      margin: 0;
      color: var(--color-muted);
      font-size: 18px;
      line-height: 1.7;
    }

    .confidence-section {
      background: var(--color-surface);
      text-align: center;
    }

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

    .confidence-section .section-title {
      margin-bottom: 0;
    }

    .benefits-section .section-title {
      margin-bottom: 0;
    }

    .process-section .section-title {
      margin-bottom: 0;
      text-align: center;
    }

    .confidence-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 22px;
      margin-top: clamp(42px, 5vw, 72px);
      text-align: left;
    }

    .benefits-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 22px;
      margin-top: clamp(42px, 5vw, 72px);
      text-align: left;
    }

    .confidence-card {
      min-height: 300px;
      padding: 34px 28px;
      border: 1px solid rgba(214, 101, 58, 0.18);
      border-radius: var(--radius-card);
      background: white;
      box-shadow: 0 18px 44px rgba(117, 64, 38, 0.08);
    }

    .benefit-card {
      min-height: 300px;
      padding: 40px 34px;
      border: 1px solid var(--color-line);
      border-radius: var(--radius-card);
      background: white;
      box-shadow: 0 18px 44px rgba(117, 64, 38, 0.08);
    }

    .section-icon {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: var(--section-icon-size);
      height: var(--section-icon-size);
      margin-bottom: 36px;
      border-radius: 50%;
      background: var(--color-primary);
      color: white;
    }

    .section-icon .material-symbols-outlined {
      font-size: var(--section-icon-font-size);
      font-variation-settings: "FILL" 0, "wght" 650, "GRAD" 0, "opsz" 30;
    }

    .confidence-card h3,
    .benefit-card h3 {
      margin: 0 0 18px;
      color: var(--color-ink);
      font-family: var(--font-display);
      font-size: clamp(20px, 2vw, 26px);
      line-height: 1.15;
      letter-spacing: -0.02em;
    }

    .confidence-card p,
    .benefit-card p {
      margin: 0;
      color: var(--color-muted);
      font-size: 18px;
      line-height: 1.65;
    }

    .legal-hero {
      border-top: 0;
      padding-top: clamp(44px, 6vw, 72px);
      padding-bottom: clamp(28px, 4vw, 48px);
      background: linear-gradient(180deg, rgba(255, 249, 242, 0.96) 0%, rgba(255, 245, 236, 0.84) 100%);
    }

    .legal-hero-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
      gap: clamp(20px, 3vw, 36px);
      align-items: start;
    }

    .legal-hero-copy {
      max-width: 760px;
    }

    .legal-hero .brand {
      margin-bottom: 18px;
    }

    .legal-hero .section-title {
      margin-bottom: 16px;
    }

    .legal-summary {
      padding: 28px;
      border: 1px solid var(--color-line);
      border-radius: 18px;
      background: rgba(255, 253, 249, 0.82);
      box-shadow: var(--shadow-card);
    }

    .legal-summary p {
      margin: 0 0 14px;
      color: var(--color-muted);
      font-size: 16px;
      line-height: 1.55;
    }

    .legal-summary p:last-child {
      margin-bottom: 0;
    }

    .legal-content {
      background: var(--color-surface);
    }

    .legal-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 22px;
    }

    .legal-card {
      padding: 28px;
      border: 1px solid var(--color-line);
      border-radius: 18px;
      background: rgba(255, 253, 249, 0.78);
      box-shadow: var(--shadow-card);
    }

    .legal-card-wide {
      grid-column: 1 / -1;
    }

    .legal-card-title {
      margin: 0 0 16px;
      font-family: var(--font-display);
      font-size: 22px;
      line-height: 1.15;
      letter-spacing: -0.02em;
      color: var(--color-text-primary);
    }

    .legal-card p {
      margin: 0;
      color: var(--color-muted);
      font-size: 16px;
      line-height: 1.7;
    }

    .legal-page footer {
      background: rgba(255, 253, 249, 0.9);
    }

    .confirmation-page {
      background:
        linear-gradient(135deg, rgba(255, 244, 234, 0.96), rgba(255, 253, 249, 0.92)),
        var(--color-surface);
    }

    .confirmation-hero {
      position: relative;
      display: grid;
      grid-template-columns: minmax(320px, 0.85fr) minmax(0, 1fr);
      gap: clamp(28px, 5vw, 84px);
      align-items: center;
      min-height: calc(100svh - 72px);
      padding: clamp(34px, 8vh, 96px) clamp(24px, 10vw, 160px);
      overflow: hidden;
    }

    .confirmation-copy {
      position: relative;
      z-index: 1;
      display: grid;
      gap: 18px;
      justify-items: start;
    }

    .confirmation-copy h1 {
      max-width: 12ch;
    }

    .confirmation-kicker {
      display: inline-flex;
      align-items: center;
      min-height: 34px;
      margin: 6px 0 0;
      padding: 0 14px;
      border: 1px solid var(--color-line-strong);
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.72);
      color: var(--color-primary-strong);
      font-size: 13px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.03em;
    }

    .confirmation-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      margin-top: 8px;
    }

    .confirmation-art {
      position: relative;
      min-height: 520px;
      border: 1px solid rgba(214, 101, 58, 0.16);
      border-radius: var(--radius-panel);
      background:
        radial-gradient(circle at 52% 45%, rgba(255, 226, 216, 0.96), rgba(255, 250, 245, 0.4) 42%, transparent 60%),
        linear-gradient(160deg, rgba(255, 253, 249, 0.92), rgba(255, 244, 234, 0.88));
      box-shadow: 0 34px 90px rgba(117, 64, 38, 0.18);
      overflow: hidden;
      isolation: isolate;
    }

    .confirmation-art::before,
    .confirmation-art::after {
      content: "";
      position: absolute;
      border-radius: 999px;
      background: repeating-linear-gradient(90deg, var(--color-primary), var(--color-primary) 14px, var(--color-primary-muted) 14px, var(--color-primary-muted) 28px);
      opacity: 0.16;
      transform: rotate(-18deg);
    }

    .confirmation-art::before {
      width: 380px;
      height: 90px;
      left: -90px;
      top: 66px;
    }

    .confirmation-art::after {
      width: 460px;
      height: 120px;
      right: -170px;
      bottom: 56px;
      transform: rotate(16deg);
    }

    .confirmation-orbit {
      position: absolute;
      inset: 50%;
      display: grid;
      place-items: center;
      width: 180px;
      height: 180px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
      color: white;
      box-shadow: 0 26px 54px rgba(214, 101, 58, 0.28);
      transform: translate(-50%, -50%);
    }

    .confirmation-orbit::before {
      content: "";
      position: absolute;
      inset: -54px;
      border: 2px dashed rgba(214, 101, 58, 0.28);
      border-radius: 50%;
      animation: confirmation-spin 22s linear infinite;
    }

    .confirmation-orbit .material-symbols-outlined {
      font-size: 76px;
      font-variation-settings: "FILL" 1, "wght" 650, "GRAD" 0, "opsz" 48;
    }

    .celebration-card {
      position: absolute;
      z-index: 1;
      display: flex;
      align-items: center;
      gap: 12px;
      min-height: 74px;
      padding: 18px 22px;
      border: 1px solid rgba(214, 101, 58, 0.16);
      border-radius: 18px;
      background: rgba(255, 253, 249, 0.88);
      color: var(--color-ink);
      font-family: var(--font-display);
      font-size: 18px;
      box-shadow: 0 18px 40px rgba(117, 64, 38, 0.16);
      backdrop-filter: blur(12px);
    }

    .celebration-card .material-symbols-outlined {
      color: var(--color-primary);
      font-size: 30px;
      font-variation-settings: "FILL" 1, "wght" 650, "GRAD" 0, "opsz" 28;
    }

    .celebration-card-primary {
      left: 34px;
      top: 58px;
      transform: rotate(-4deg);
    }

    .celebration-card-secondary {
      right: 32px;
      bottom: 58px;
      transform: rotate(5deg);
    }

    .confirmation-next {
      background: rgba(255, 253, 249, 0.74);
    }

    .confirmation-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 22px;
    }

    .confirmation-grid .feature-card p {
      margin: 0;
      color: var(--color-muted);
      font-size: 16px;
      line-height: 1.65;
    }

    @keyframes confirmation-spin {
      to {
        transform: rotate(360deg);
      }
    }

    .feature-grid,
    .form-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 22px;
      margin-top: 36px;
    }

    .feature-card,
    .form-card {
      border: 1px solid var(--color-line);
      border-radius: var(--radius-card);
      background: white;
    }

    .feature-card {
      padding: 28px;
    }

    .feature-card h3 {
      margin: 0 0 18px;
      font-family: var(--font-display);
      font-size: 24px;
      letter-spacing: -0.02em;
    }

    .step-list {
      display: grid;
      gap: 18px;
      margin: 0;
      padding: 0;
      list-style: none;
      color: var(--color-muted);
      line-height: 1.55;
    }

    .step-list li {
      display: grid;
      grid-template-columns: 34px minmax(0, 1fr);
      gap: 14px;
      align-items: center;
    }

    .step-list p {
      margin: 0;
    }

    .step-list span {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 34px;
      height: 34px;
      border-radius: 50%;
      background: var(--color-primary-soft);
      color: var(--color-primary-strong);
      font-family: var(--font-display);
      font-weight: 800;
    }

    .form-card {
      padding: 28px;
    }

    .form-card h3 {
      margin: 0 0 22px;
      font-family: var(--font-display);
      font-size: 25px;
      letter-spacing: -0.02em;
    }

    form {
      display: grid;
      gap: 16px;
    }

    .field-row {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
    }

    label {
      display: grid;
      gap: 8px;
      color: var(--color-muted);
      font-size: 13px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.03em;
    }

    .label-copy {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      min-height: 16px;
    }

    .required-mark {
      color: var(--color-primary);
      font-size: 15px;
      line-height: 1;
    }

    input,
    select {
      display: block;
      width: 100%;
      min-width: 0;
      min-height: 54px;
      padding: 0 36px 0 16px;
      border: 1px solid var(--color-line);
      border-radius: 12px;
      background: white;
      color: var(--color-ink);
      font: 500 15px var(--font-body);
      outline: none;
      transition: border-color 160ms ease, box-shadow 160ms ease;
    }

    input[type="date"] {
      -webkit-appearance: auto;
      appearance: auto;
      box-sizing: border-box;
      line-height: 54px;
      padding-top: 0;
      padding-bottom: 0;
    }

    input[type="date"]::-webkit-date-and-time-value {
      text-align: left;
      line-height: 54px;
    }

    input[type="date"]::-webkit-calendar-picker-indicator {
      margin: 0;
      padding: 0 12px 0 0;
      opacity: 0.72;
      cursor: pointer;
    }

    .consent-checkbox {
      display: flex;
      align-items: center;
      gap: 10px;
      color: var(--color-muted);
      font-size: 12px;
      font-weight: 700;
      line-height: 1.45;
      text-transform: none;
      letter-spacing: 0;
    }

    .consent-checkbox input {
      flex: 0 0 auto;
      width: 18px;
      min-height: 18px;
      height: 18px;
      margin: 0;
      padding: 0;
      accent-color: var(--color-primary);
      cursor: pointer;
    }

    .form-status {
      margin: 0;
      padding: 12px 14px;
      border: 1px solid var(--color-line-strong);
      border-radius: var(--radius-control);
      background: var(--color-primary-soft);
      color: var(--color-primary-strong);
      font-size: 13px;
      font-weight: 800;
      line-height: 1.45;
    }

    select {
      appearance: none;
      background-image:
        linear-gradient(45deg, transparent 50%, var(--color-muted) 50%),
        linear-gradient(135deg, var(--color-muted) 50%, transparent 50%),
        linear-gradient(to right, transparent, transparent);
      background-position:
        calc(100% - 18px) 55%,
        calc(100% - 12px) 55%,
        100% 0;
      background-size: 6px 6px, 6px 6px, 2.5em 100%;
      background-repeat: no-repeat;
    }

    .multi-field {
      display: grid;
      gap: 8px;
    }

    .multiselect {
      position: relative;
    }

    .multiselect-trigger {
      width: 100%;
      min-height: 54px;
      padding: 10px 16px;
      border: 1px solid var(--color-line);
      border-radius: 12px;
      background: white;
      color: var(--color-ink);
      font: 500 15px var(--font-body);
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      cursor: pointer;
      text-align: left;
      transition: border-color 160ms ease, box-shadow 160ms ease;
    }

    .multiselect-trigger:focus,
    .multiselect-trigger:hover {
      border-color: var(--color-primary);
      box-shadow: 0 0 0 4px rgba(223, 95, 64, 0.14);
      outline: none;
    }

    .multiselect-summary {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      align-items: center;
      min-width: 0;
    }

    .multiselect-placeholder {
      color: var(--color-muted);
      font-size: 15px;
      line-height: 1.2;
    }

    .multiselect-chip {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      min-height: 28px;
      padding: 0 8px 0 10px;
      border-radius: 999px;
      background: var(--color-primary-soft);
      color: var(--color-primary-strong);
      font-size: 13px;
      font-weight: 700;
      line-height: 1;
      white-space: nowrap;
    }

    .multiselect-chip-remove {
      position: relative;
      width: 18px;
      height: 18px;
      border: 0;
      border-radius: 50%;
      background: rgba(255, 255, 255, 0.64);
      color: var(--color-primary-strong);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      padding: 0;
      flex: 0 0 auto;
    }

    .multiselect-chip-remove::before,
    .multiselect-chip-remove::after {
      content: "";
      position: absolute;
      width: 8px;
      height: 1.5px;
      background: currentColor;
      border-radius: 1px;
    }

    .multiselect-chip-remove::before {
      transform: rotate(45deg);
    }

    .multiselect-chip-remove::after {
      transform: rotate(-45deg);
    }

    .multiselect-caret {
      flex: 0 0 auto;
      width: 10px;
      height: 10px;
      margin-right: 4px;
      border-right: 2px solid var(--color-muted);
      border-bottom: 2px solid var(--color-muted);
      transform: rotate(45deg);
      transition: transform 160ms ease;
    }

    .multiselect.is-open .multiselect-caret {
      transform: rotate(225deg);
      margin-top: 6px;
    }

    .multiselect-panel {
      position: absolute;
      left: 0;
      right: 0;
      top: calc(100% + 10px);
      z-index: 10;
      padding: 10px;
      border: 1px solid var(--color-line);
      border-radius: 16px;
      background: rgba(255, 253, 249, 0.98);
      box-shadow: 0 18px 36px rgba(38, 23, 23, 0.12);
    }

    .multiselect-options {
      display: grid;
      gap: 8px;
    }

    .multiselect-option {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      min-height: 46px;
      padding: 0 14px;
      border: 1px solid transparent;
      border-radius: 12px;
      background: transparent;
      color: var(--color-ink);
      cursor: pointer;
      text-align: left;
      font: 500 15px var(--font-body);
      transition: background 140ms ease, border-color 140ms ease, color 140ms ease;
    }

    .multiselect-option:hover,
    .multiselect-option.is-selected {
      background: rgba(223, 95, 64, 0.08);
      border-color: rgba(223, 95, 64, 0.16);
      color: var(--color-ink);
    }

    .multiselect-check {
      flex: 0 0 auto;
      width: 18px;
      height: 18px;
      border-radius: 5px;
      border: 1.5px solid var(--color-line-strong);
      background: white;
      position: relative;
    }

    .multiselect-option.is-selected .multiselect-check {
      border-color: var(--color-primary);
      background: var(--color-primary);
    }

    .multiselect-option.is-selected .multiselect-check::after {
      content: "";
      position: absolute;
      left: 50%;
      top: 48%;
      width: 5px;
      height: 9px;
      border-right: 2px solid white;
      border-bottom: 2px solid white;
      transform: translate(-50%, -60%) rotate(40deg);
    }

    input:focus,
    select:focus {
      border-color: var(--color-primary);
      box-shadow: 0 0 0 4px rgba(223, 95, 64, 0.14);
    }

    .form-card .button {
      min-height: 58px;
      width: 100%;
      font-size: 17px;
      cursor: pointer;
    }

    .faq-list {
      display: grid;
      gap: 12px;
      margin-top: 32px;
    }

    .faq-item {
      border: 1px solid var(--color-line);
      border-radius: var(--radius-card);
      background: white;
      box-shadow: var(--shadow-soft);
      overflow: hidden;
    }

    .faq-toggle {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
      padding: 22px 24px;
      border: 0;
      background: transparent;
      color: var(--color-text-primary);
      font-family: var(--font-display);
      font-size: 18px;
      font-weight: 800;
      text-align: left;
      cursor: pointer;
    }

    .faq-toggle:focus {
      outline: none;
      box-shadow: inset 0 0 0 3px rgba(223, 95, 64, 0.14);
    }

    .faq-toggle-icon {
      flex: 0 0 auto;
      width: 28px;
      height: 28px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      color: var(--color-primary);
      font-size: 22px;
      font-weight: 700;
      line-height: 1;
      transition: transform 160ms ease;
    }

    .faq-item.is-open .faq-toggle-icon {
      transform: rotate(45deg);
    }

    .faq-answer {
      padding: 0 24px 22px;
      color: var(--color-muted);
      font-size: 16px;
      line-height: 1.65;
    }

    footer {
      display: flex;
      justify-content: space-between;
      gap: 24px;
      flex-wrap: wrap;
      padding: 32px var(--space-page);
      border-top: 1px solid var(--color-line);
      color: var(--color-muted);
      font-size: 14px;
    }

    footer strong {
      color: var(--color-primary);
      font-family: var(--font-display);
      font-size: 20px;
    }

    footer nav {
      display: flex;
      flex-wrap: wrap;
      gap: 18px;
    }

    @media (max-width: 960px) {
      .hero {
        grid-template-columns: 1fr;
        min-height: auto;
        height: auto;
        max-height: none;
        overflow: visible;
      }

      .confirmation-hero {
        grid-template-columns: 1fr;
        min-height: auto;
      }

      .hero-copy {
        justify-items: start;
      }

      .visual {
        justify-self: center;
        width: 100%;
        height: auto;
      }

      .brand {
        margin-bottom: 0;
      }

      .visual,
      .visual img {
        min-height: 420px;
      }

      .confirmation-art {
        order: 2;
        min-height: 440px;
      }

      .confirmation-copy {
        order: 1;
      }

      .confirmation-grid {
        grid-template-columns: 1fr;
      }

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

      .benefits-grid {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 700px) {
      .page-shell {
        width: 100%;
        margin-top: 0;
        border-width: 0;
        border-radius: 0;
      }

      .beta-strip {
        justify-content: flex-start;
        min-height: 66px;
        font-size: 16px;
      }

      .pill {
        min-height: 30px;
        padding: 0 12px;
        font-size: 14px;
      }

      .cookie-consent {
        left: 10px;
        right: 10px;
        bottom: 10px;
        width: calc(100% - 20px);
        flex-direction: column;
        align-items: stretch;
        padding: 16px;
      }

      .cookie-consent-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
      }

      .hero {
        height: auto;
        min-height: auto;
        max-height: none;
        overflow: visible;
        padding: 16px 20px 28px;
        gap: 24px;
      }

      .confirmation-hero {
        padding: 28px 20px 34px;
        gap: 26px;
      }

      .confirmation-art {
        min-height: 360px;
        border-radius: 22px;
      }

      .confirmation-orbit {
        width: 138px;
        height: 138px;
      }

      .confirmation-orbit::before {
        inset: -38px;
      }

      .confirmation-orbit .material-symbols-outlined {
        font-size: 58px;
      }

      .celebration-card {
        min-height: 62px;
        padding: 14px 16px;
        font-size: 15px;
      }

      .celebration-card-primary {
        left: 18px;
        top: 32px;
      }

      .celebration-card-secondary {
        right: 18px;
        bottom: 32px;
      }

      .brand {
        gap: 14px;
        margin-bottom: 0;
      }

      .brand-mark {
        width: 58px;
        height: 58px;
      }

      .brand-mark .material-symbols-outlined {
        font-size: 30px;
      }

      .lead {
        margin-bottom: 0;
      }

      .available-routes {
        padding: 20px;
        border-radius: var(--radius-card);
      }

      .eyebrow {
        align-items: flex-start;
        font-size: 13px;
        line-height: 1.25;
      }

      .route-list {
        display: grid;
        grid-template-columns: 1fr;
      }

      .route-pill {
        width: 100%;
        min-height: 42px;
        padding: 0 16px;
        font-size: 16px;
      }

      .trust-badges {
        gap: 10px;
      }

      .trust-icon {
        width: 38px;
        height: 38px;
      }

      .button {
        min-height: 52px;
        padding: 0 18px;
      }

      .visual,
      .visual img {
        min-height: 360px;
      }

      .notice {
        left: 14px;
        right: 14px;
        bottom: 16px;
        grid-template-columns: 38px minmax(0, 1fr);
        gap: 12px;
        padding: 16px;
      }

      .mini-mark {
        width: 38px;
        height: 38px;
      }

      .feature-grid,
      .confidence-grid,
      .form-grid,
      .field-row {
        grid-template-columns: 1fr;
      }

      .confidence-section,
      .benefits-section,
      .process-section {
        text-align: left;
      }

      .process-section .section-title {
        text-align: left;
      }

      .section-kicker {
        text-align: left;
      }

      .confidence-grid {
        margin-top: 30px;
      }

      .benefits-grid {
        margin-top: 30px;
      }

      .confidence-card {
        min-height: auto;
        padding: 24px;
      }

      .benefit-card {
        min-height: auto;
        padding: 26px 24px;
      }

      .section-icon {
        --section-icon-size: 56px;
        --section-icon-font-size: 28px;
        margin-bottom: 24px;
      }

      .legal-hero-grid,
      .legal-grid,
      .confirmation-grid {
        grid-template-columns: 1fr;
      }

      .legal-summary,
      .legal-card {
        padding: 22px;
      }

      footer {
        flex-direction: column;
      }
    }
