/*
  Chauffeurize Core CSS v2
  Stable, cache-friendly foundation for all pages.

  Keep page-specific layout in:
  home.css, book.css, service.css, blog.css, legal.css
*/

@layer reset, tokens, base, layout, components, navigation, forms, animations, utilities;

[hidden] {
  display: none !important;
}

/* -----------------------------
   TOKENS
----------------------------- */
@layer tokens {
  :root {
    color-scheme: dark;

    --cz-bg: #05070c;
    --cz-bg-2: #080d14;
    --cz-bg-soft: #0b1018;
    --cz-surface: #101722;
    --cz-surface-2: #141e2c;
    --cz-surface-3: #1a2636;
    --cz-surface-glass: color-mix(in srgb, #101722 78%, transparent);

    --cz-text: #f4f7fb;
    --cz-text-soft: #c6d0de;
    --cz-text-muted: #8492a8;
    --cz-text-faint: #5f6d80;

    --cz-accent: #6f35c6;
    --cz-accent-rgb: 111 53 198;
    --cz-accent-2: #9b63ff;
    --cz-accent-2-rgb: 155 99 255;
    --cz-accent-soft: #c9adff;

    --cz-gold: #d9b66f;
    --cz-gold-rgb: 217 182 111;

    --cz-success: #35d07f;
    --cz-warning: #ffd166;
    --cz-danger: #ff5c7a;

    --cz-border: rgb(255 255 255 / 0.1);
    --cz-border-soft: rgb(255 255 255 / 0.07);
    --cz-border-strong: rgb(var(--cz-accent-rgb) / 0.34);

    --cz-gradient-brand: linear-gradient(135deg, #7d3fe0, #a06bff);
    --cz-gradient-premium: linear-gradient(135deg, var(--cz-accent), var(--cz-accent-2) 58%, var(--cz-gold));
    --cz-gradient-card: linear-gradient(180deg, rgb(255 255 255 / 0.075), rgb(255 255 255 / 0.028));
    --cz-gradient-border: linear-gradient(
      135deg,
      rgb(var(--cz-accent-rgb) / 0.55),
      rgb(var(--cz-accent-2-rgb) / 0.28),
      rgb(var(--cz-gold-rgb) / 0.18)
    );

    --cz-font-main: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --cz-font-display: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

    --cz-h1: clamp(2.35rem, 10vw, 5.8rem);
    --cz-h2: clamp(1.95rem, 6vw, 3.8rem);
    --cz-h3: clamp(1.35rem, 3.4vw, 2.05rem);
    --cz-h4: clamp(1.12rem, 2.1vw, 1.35rem);
    --cz-body-lg: clamp(1.05rem, 1.5vw, 1.25rem);
    --cz-body: 1rem;
    --cz-small: 0.875rem;
    --cz-xs: 0.78rem;

    --cz-leading-tight: 0.95;
    --cz-leading-heading: 1.08;
    --cz-leading-body: 1.7;

    --cz-container: 1180px;
    --cz-container-wide: 1360px;
    --cz-header-h: 72px;

    --cz-space-2xs: 0.35rem;
    --cz-space-xs: 0.5rem;
    --cz-space-sm: 0.75rem;
    --cz-space-md: 1rem;
    --cz-space-lg: 1.5rem;
    --cz-space-xl: 2.5rem;
    --cz-space-2xl: 4rem;
    --cz-space-3xl: clamp(4.5rem, 9vw, 7.5rem);

    --cz-radius-xs: 0.5rem;
    --cz-radius-sm: 0.75rem;
    --cz-radius-md: 1rem;
    --cz-radius-lg: 1.5rem;
    --cz-radius-xl: 2rem;
    --cz-radius-pill: 999px;

    --cz-shadow-soft: 0 24px 80px rgb(0 0 0 / 0.35);
    --cz-shadow-card: 0 18px 60px rgb(0 0 0 / 0.28);
    --cz-shadow-glow: 0 0 44px rgb(var(--cz-accent-rgb) / 0.16);
    --cz-shadow-focus: 0 0 0 4px rgb(var(--cz-accent-rgb) / 0.16);

    --cz-ease: cubic-bezier(0.2, 0.8, 0.2, 1);
    --cz-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --cz-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --cz-duration-fast: 160ms;
    --cz-duration: 260ms;
    --cz-duration-slow: 520ms;

    --cz-z-base: 1;
    --cz-z-header: 20;
    --cz-z-popover: 40;
    --cz-z-modal: 60;
    --cz-z-toast: 80;
  }
}

/* -----------------------------
   RESET
----------------------------- */
@layer reset {
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  * {
    margin: 0;
  }

  html {
    min-height: 100%;
    scroll-behavior: smooth;
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
  }

  body {
    min-height: 100svh;
  }

  img,
  picture,
  svg,
  video,
  canvas {
    display: block;
    max-width: 100%;
  }

  img {
    height: auto;
  }

  input,
  button,
  textarea,
  select {
    font: inherit;
  }

  button,
  select {
    text-transform: none;
  }

  button {
    border: 0;
    cursor: pointer;
  }

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

  ul[role="list"],
  ol[role="list"] {
    list-style: none;
    padding: 0;
  }

  table {
    border-collapse: collapse;
  }

  :target {
    scroll-margin-block: calc(var(--cz-header-h) + var(--cz-space-xl));
  }
}

/* -----------------------------
   BASE
----------------------------- */
@layer base {
  body {
    font-family: var(--cz-font-main);
    font-size: var(--cz-body);
    line-height: var(--cz-leading-body);
    color: var(--cz-text);
    background:
      radial-gradient(circle at 18% -10%, rgb(var(--cz-accent-rgb) / 0.18), transparent 28rem),
      radial-gradient(circle at 85% 8%, rgb(var(--cz-accent-2-rgb) / 0.14), transparent 30rem),
      radial-gradient(circle at 50% 110%, rgb(var(--cz-gold-rgb) / 0.06), transparent 34rem),
      linear-gradient(180deg, var(--cz-bg), var(--cz-bg-2) 45%, var(--cz-bg));
    background-attachment: fixed;
    overflow-x: clip;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
  }

  body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    pointer-events: none;
    opacity: 0.34;
    background-image:
      linear-gradient(rgb(255 255 255 / 0.035) 1px, transparent 1px),
      linear-gradient(90deg, rgb(255 255 255 / 0.03) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: linear-gradient(to bottom, black, transparent 82%);
  }

  body::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    opacity: 0.5;
    background:
      linear-gradient(120deg, transparent, rgb(var(--cz-accent-rgb) / 0.045), transparent 35%),
      radial-gradient(circle at 70% 20%, rgb(255 255 255 / 0.045), transparent 18rem);
  }

  ::selection {
    color: var(--cz-bg);
    background: var(--cz-accent-soft);
  }

  h1,
  h2,
  h3,
  h4 {
    font-family: var(--cz-font-display);
    color: var(--cz-text);
    letter-spacing: -0.045em;
    line-height: var(--cz-leading-heading);
  }

  h1 {
    font-size: var(--cz-h1);
    line-height: var(--cz-leading-tight);
  }

  h2 {
    font-size: var(--cz-h2);
  }

  h3 {
    font-size: var(--cz-h3);
  }

  h4 {
    font-size: var(--cz-h4);
  }

  p {
    color: var(--cz-text-soft);
  }

  small {
    font-size: var(--cz-small);
    color: var(--cz-text-muted);
  }

  strong {
    color: var(--cz-text);
    font-weight: 750;
  }

  a:not([class]) {
    color: var(--cz-accent-soft);
    text-decoration: underline;
    text-decoration-color: rgb(var(--cz-accent-2-rgb) / 0.38);
    text-underline-offset: 0.22em;
    transition:
      color var(--cz-duration-fast) var(--cz-ease),
      text-decoration-color var(--cz-duration-fast) var(--cz-ease);
  }

  a:not([class]):hover {
    color: var(--cz-text);
    text-decoration-color: var(--cz-accent-soft);
  }

  :focus-visible {
    outline: 2px solid var(--cz-accent-2);
    outline-offset: 4px;
  }
}

/* -----------------------------
   LAYOUT
----------------------------- */
@layer layout {
  .cz-container,
  .cz-container-wide {
    width: min(100% - 2rem, var(--cz-container));
    margin-inline: auto;
  }

  .cz-container-wide {
    width: min(100% - 2rem, var(--cz-container-wide));
  }

  .cz-section {
    padding-block: var(--cz-space-3xl);
  }

  .cz-section-sm {
    padding-block: var(--cz-space-2xl);
  }

  .cz-stack {
    display: grid;
    gap: var(--cz-stack-gap, var(--cz-space-md));
  }

  .cz-flow > * + * {
    margin-block-start: var(--cz-flow-space, var(--cz-space-md));
  }

  .cz-cluster {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--cz-cluster-gap, var(--cz-space-sm));
  }

  .cz-grid {
    display: grid;
    gap: var(--cz-grid-gap, var(--cz-space-lg));
  }

  .cz-auto-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--cz-grid-min, 17rem)), 1fr));
    gap: var(--cz-grid-gap, var(--cz-space-lg));
  }

  .cz-split {
    display: grid;
    gap: var(--cz-space-xl);
    align-items: center;
  }

  @media (min-width: 880px) {
    .cz-container,
    .cz-container-wide {
      width: min(100% - 3rem, var(--cz-container));
    }

    .cz-container-wide {
      width: min(100% - 3rem, var(--cz-container-wide));
    }

    .cz-split {
      grid-template-columns: minmax(0, 1fr) minmax(340px, 0.74fr);
    }
  }
}

/* -----------------------------
   COMPONENTS
----------------------------- */
@layer components {
  .cz-skip-link {
    position: fixed;
    inset-block-start: 1rem;
    inset-inline-start: 1rem;
    z-index: var(--cz-z-toast);
    transform: translateY(-140%);
    padding: 0.75rem 1rem;
    border-radius: var(--cz-radius-pill);
    background: var(--cz-text);
    color: var(--cz-bg);
    font-weight: 800;
    transition: transform var(--cz-duration) var(--cz-ease);
  }

  .cz-skip-link:focus {
    transform: translateY(0);
  }

  .cz-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    width: fit-content;
    padding: 0.42rem 0.72rem;
    border: 1px solid rgb(var(--cz-accent-2-rgb) / 0.34);
    border-radius: var(--cz-radius-pill);
    background: rgb(var(--cz-accent-rgb) / 0.16);
    color: var(--cz-accent-soft);
    font-size: var(--cz-xs);
    font-weight: 850;
    letter-spacing: 0.14em;
    line-height: 1;
    text-transform: uppercase;
  }

  .cz-text-gradient {
    background: var(--cz-gradient-premium);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }

  .cz-muted {
    color: var(--cz-text-muted);
  }

  .cz-section-head {
    display: grid;
    gap: var(--cz-space-md);
    max-width: 760px;
    margin-block-end: var(--cz-space-xl);
  }

  .cz-section-head[data-align="center"] {
    margin-inline: auto;
    text-align: center;
    justify-items: center;
  }

  .cz-btn {
    --_btn-bg: rgb(255 255 255 / 0.08);
    --_btn-color: var(--cz-text);
    --_btn-border: rgb(255 255 255 / 0.12);
    --_btn-shadow: none;

    position: relative;
    isolation: isolate;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    min-height: 48px;
    padding: 0.82rem 1.1rem;
    overflow: clip;
    border: 1px solid var(--_btn-border);
    border-radius: var(--cz-radius-pill);
    background: var(--_btn-bg);
    color: var(--_btn-color);
    box-shadow: var(--_btn-shadow);
    font-weight: 850;
    line-height: 1;
    white-space: nowrap;
    user-select: none;
    transition:
      transform var(--cz-duration) var(--cz-ease),
      border-color var(--cz-duration) var(--cz-ease),
      background var(--cz-duration) var(--cz-ease),
      box-shadow var(--cz-duration) var(--cz-ease),
      color var(--cz-duration) var(--cz-ease);
  }

  .cz-btn:hover {
    transform: translateY(-2px);
    border-color: rgb(255 255 255 / 0.22);
  }

  .cz-btn:active {
    transform: translateY(0) scale(0.99);
  }

  .cz-btn-primary {
    --_btn-bg: var(--cz-gradient-brand);
    --_btn-color: #fff;
    --_btn-border: rgb(var(--cz-accent-2-rgb) / 0.62);
    --_btn-shadow: 0 16px 44px rgb(var(--cz-accent-rgb) / 0.34);

    color: #fff;
    text-shadow: 0 1px 10px rgb(0 0 0 / 0.18);
  }

  .cz-btn-primary:hover {
    box-shadow: 0 18px 54px rgb(var(--cz-accent-rgb) / 0.45);
  }

  .cz-btn-secondary {
    --_btn-bg: rgb(255 255 255 / 0.075);
    --_btn-border: rgb(255 255 255 / 0.13);
  }

  .cz-btn-ghost {
    --_btn-bg: transparent;
    --_btn-border: transparent;
    padding-inline: 0.4rem;
  }

  .cz-btn-block {
    width: 100%;
  }

  .cz-card,
  .cz-glass-card {
    container-type: inline-size;
    position: relative;
    overflow: clip;
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-lg);
    background: var(--cz-gradient-card), var(--cz-surface);
    box-shadow: var(--cz-shadow-card);
  }

  .cz-card {
    padding: clamp(1rem, 4cqw, 1.5rem);
  }

  .cz-glass-card {
    padding: clamp(1rem, 4cqw, 1.75rem);
    background: var(--cz-gradient-card), var(--cz-surface-glass);
    backdrop-filter: blur(18px) saturate(130%);
    -webkit-backdrop-filter: blur(18px) saturate(130%);
  }

  .cz-card::before,
  .cz-glass-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    border-radius: inherit;
    padding: 1px;
    background: var(--cz-gradient-border);
    opacity: 0.28;
    mask:
      linear-gradient(#000 0 0) content-box,
      linear-gradient(#000 0 0);
    mask-composite: exclude;
  }

  .cz-card:hover,
  .cz-glass-card:hover {
    border-color: rgb(255 255 255 / 0.16);
  }

  .cz-icon-wrap {
    display: grid;
    place-items: center;
    width: 2.65rem;
    aspect-ratio: 1;
    border: 1px solid rgb(var(--cz-accent-2-rgb) / 0.24);
    border-radius: var(--cz-radius-md);
    background:
      radial-gradient(circle at 35% 25%, rgb(255 255 255 / 0.13), transparent 38%), rgb(var(--cz-accent-rgb) / 0.14);
    color: var(--cz-accent-soft);
    box-shadow:
      inset 0 1px 0 rgb(255 255 255 / 0.09),
      0 14px 34px rgb(var(--cz-accent-rgb) / 0.14);
  }

  .cz-icon-wrap i,
  .cz-icon-wrap svg {
    display: block;
    width: 1.05rem;
    height: 1.05rem;
    font-size: 1.05rem;
    line-height: 1;
  }

  .cz-icon {
    width: 1.15em;
    height: 1.15em;
    flex: 0 0 auto;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .cz-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    width: fit-content;
    padding: 0.42rem 0.65rem;
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-pill);
    background: rgb(255 255 255 / 0.06);
    color: var(--cz-text-soft);
    font-size: var(--cz-xs);
    font-weight: 750;
    line-height: 1;
  }

  .cz-badge[data-tone="accent"] {
    border-color: rgb(var(--cz-accent-2-rgb) / 0.34);
    background: rgb(var(--cz-accent-rgb) / 0.16);
    color: var(--cz-accent-soft);
  }

  .cz-badge[data-tone="gold"] {
    border-color: rgb(var(--cz-gold-rgb) / 0.28);
    background: rgb(var(--cz-gold-rgb) / 0.08);
    color: var(--cz-gold);
  }

  .cz-trust-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 12rem), 1fr));
    gap: 0.75rem;
  }

  .cz-trust-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-height: 64px;
    padding: 0.85rem 1rem;
    border: 1px solid var(--cz-border-soft);
    border-radius: var(--cz-radius-lg);
    background: rgb(255 255 255 / 0.045);
  }

  .cz-trust-item .cz-icon-wrap {
    flex: 0 0 2.65rem;
  }

  .cz-trust-item strong {
    display: block;
    font-size: 0.92rem;
    line-height: 1.25;
  }

  .cz-trust-item > div > span {
    display: block;
    color: var(--cz-text-muted);
    font-size: var(--cz-xs);
    line-height: 1.35;
  }

  .cz-tabs {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.35rem;
    padding: 0.35rem;
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-pill);
    background: rgb(255 255 255 / 0.055);
  }

  .cz-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0.65rem 0.85rem;
    border-radius: var(--cz-radius-pill);
    color: var(--cz-text-muted);
    font-size: var(--cz-small);
    font-weight: 850;
    transition:
      background var(--cz-duration) var(--cz-ease),
      color var(--cz-duration) var(--cz-ease),
      box-shadow var(--cz-duration) var(--cz-ease);
  }

  .cz-tab[aria-selected="true"],
  .cz-tab.is-active {
    background: var(--cz-gradient-brand);
    color: #fff;
    box-shadow: 0 12px 34px rgb(var(--cz-accent-rgb) / 0.34);
  }

  .cz-pill-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
  }

  .cz-divider {
    height: 1px;
    border: 0;
    background: linear-gradient(90deg, transparent, rgb(255 255 255 / 0.16), transparent);
  }
}

/* -----------------------------
   NAVIGATION
----------------------------- */
@layer navigation {
  .cz-header {
    position: sticky;
    inset-block-start: 0;
    z-index: var(--cz-z-header);
    min-height: var(--cz-header-h);
    border-block-end: 1px solid rgb(255 255 255 / 0.08);
    background: rgb(5 7 12 / 0.76);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
  }

  .cz-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: var(--cz-header-h);
  }

  .cz-logo {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    font-weight: 900;
    letter-spacing: -0.035em;
  }

  .cz-logo-mark {
    width: 2.25rem;
    aspect-ratio: 1;
    border-radius: 0.82rem;
    background: var(--cz-gradient-brand);
    box-shadow: 0 12px 34px rgb(var(--cz-accent-rgb) / 0.24);
  }

  .cz-logo-image {
    display: block;
    width: auto;
    height: 50px;
  }

  .cz-nav {
    display: none;
    align-items: center;
    gap: 0.35rem;
  }

  .cz-nav-link {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 0.6rem 0.85rem;
    border-radius: var(--cz-radius-pill);
    color: var(--cz-text-soft);
    font-size: var(--cz-small);
    font-weight: 800;
    transition:
      background var(--cz-duration) var(--cz-ease),
      color var(--cz-duration) var(--cz-ease);
  }

  .cz-nav-link:hover,
  .cz-nav-link[aria-current="page"] {
    background: rgb(255 255 255 / 0.07);
    color: var(--cz-text);
  }

  .cz-header-actions {
    display: flex;
    align-items: center;
    gap: 0.6rem;
  }

  .cz-menu-btn {
    display: inline-flex;
  }

  .cz-mobile-menu {
    position: fixed;
    inset: calc(var(--cz-header-h) + 0.6rem) 1rem auto;
    z-index: var(--cz-z-popover);
    display: grid;
    gap: 0.5rem;
    padding: 0.85rem;
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-lg);
    background: rgb(10 15 24 / 0.94);
    box-shadow: var(--cz-shadow-soft);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
  }

  .cz-mobile-menu:not(.is-open) {
    display: none;
  }

  .cz-mobile-menu .cz-nav-link {
    justify-content: space-between;
    width: 100%;
    border-radius: var(--cz-radius-md);
  }

  .cz-footer {
    padding-block: var(--cz-space-3xl) var(--cz-space-xl);
    border-block-start: 1px solid var(--cz-border-soft);
    background:
      radial-gradient(circle at 50% 0%, rgb(var(--cz-accent-rgb) / 0.18), transparent 30rem), rgb(0 0 0 / 0.2);
  }

  .cz-footer-main {
    display: grid;
    justify-items: center;
    gap: var(--cz-space-lg);
    max-width: 820px;
    margin-inline: auto;
    text-align: center;
  }

  .cz-footer-logo-image {
    display: block;
    width: auto;
    height: 160px;
  }

  .cz-footer-main h2 {
    font-size: clamp(2.25rem, 6vw, 4.5rem);
  }

  .cz-footer-main p {
    max-width: 58ch;
  }

  .cz-footer-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--cz-space-sm);
  }

  .cz-footer-grid {
    display: grid;
    gap: var(--cz-space-xl);
    margin-block-start: var(--cz-space-2xl);
    padding-block-start: var(--cz-space-xl);
    border-block-start: 1px solid var(--cz-border-soft);
  }

  .cz-footer-links {
    display: grid;
    gap: 0.55rem;
  }

  .cz-footer-link {
    color: var(--cz-text-muted);
    font-size: var(--cz-small);
    transition:
      transform var(--cz-duration-fast) var(--cz-ease),
      color var(--cz-duration-fast) var(--cz-ease);
  }

  .cz-footer-link:hover {
    color: var(--cz-text);
    transform: translateX(0.18rem);
  }

  .cz-footer-bottom {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
    margin-block-start: var(--cz-space-xl);
    padding-block-start: var(--cz-space-lg);
    border-block-start: 1px solid var(--cz-border-soft);
    color: var(--cz-text-muted);
    font-size: var(--cz-small);
  }

  @media (min-width: 840px) {
    .cz-nav {
      display: flex;
    }

    .cz-menu-btn,
    .cz-mobile-menu {
      display: none !important;
    }

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

  @media (max-width: 640px) {
    .cz-logo-image {
      height: 28px;
    }
  }
}

/* -----------------------------
   FORMS
----------------------------- */
@layer forms {
  .cz-form {
    display: grid;
    gap: var(--cz-space-md);
  }

  .cz-form-grid {
    display: grid;
    gap: var(--cz-space-md);
  }

  .cz-field {
    display: grid;
    gap: 0.45rem;
  }

  .cz-label {
    color: var(--cz-text-soft);
    font-size: var(--cz-small);
    font-weight: 800;
    line-height: 1.2;
  }

  .cz-help {
    color: var(--cz-text-muted);
    font-size: var(--cz-xs);
    line-height: 1.45;
  }

  .cz-control,
  .cz-choice {
    position: relative;
  }

  .cz-input,
  .cz-select,
  .cz-textarea,
  .cz-choice-button {
    width: 100%;
    min-height: 52px;
    padding: 0.92rem 1rem;
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-md);
    background: rgb(255 255 255 / 0.055);
    color: var(--cz-text);
    box-shadow: inset 0 1px 0 rgb(255 255 255 / 0.045);
    transition:
      border-color var(--cz-duration) var(--cz-ease),
      background var(--cz-duration) var(--cz-ease),
      box-shadow var(--cz-duration) var(--cz-ease),
      transform var(--cz-duration) var(--cz-ease);
  }

  .cz-input,
  .cz-select,
  .cz-textarea {
    caret-color: var(--cz-accent-2);
  }

  .cz-textarea {
    min-height: 132px;
    resize: vertical;
  }

  .cz-select {
    appearance: none;
    padding-inline-end: 2.75rem;
    background-image:
      linear-gradient(45deg, transparent 50%, var(--cz-text-muted) 50%),
      linear-gradient(135deg, var(--cz-text-muted) 50%, transparent 50%);
    background-position:
      calc(100% - 1.25rem) 50%,
      calc(100% - 0.95rem) 50%;
    background-size:
      0.35rem 0.35rem,
      0.35rem 0.35rem;
    background-repeat: no-repeat;
  }

  .cz-input::placeholder,
  .cz-textarea::placeholder {
    color: var(--cz-text-faint);
  }

  .cz-input:hover,
  .cz-select:hover,
  .cz-textarea:hover,
  .cz-choice-button:hover,
  .cz-choice.is-open .cz-choice-button {
    border-color: rgb(var(--cz-accent-2-rgb) / 0.55);
    background: rgb(255 255 255 / 0.078);
  }

  .cz-input:focus,
  .cz-select:focus,
  .cz-textarea:focus {
    outline: 0;
    border-color: var(--cz-accent-2);
    box-shadow:
      var(--cz-shadow-focus),
      inset 0 1px 0 rgb(255 255 255 / 0.07);
  }

  .cz-choice.is-open .cz-choice-button {
    box-shadow:
      0 0 0 4px rgb(var(--cz-accent-rgb) / 0.14),
      inset 0 1px 0 rgb(255 255 255 / 0.07);
  }

  .cz-input[aria-invalid="true"],
  .cz-select[aria-invalid="true"],
  .cz-textarea[aria-invalid="true"] {
    border-color: var(--cz-danger);
    box-shadow: 0 0 0 4px rgb(255 92 122 / 0.12);
  }

  .cz-control[data-icon] .cz-input,
  .cz-control[data-icon] .cz-select {
    padding-inline-start: 2.8rem;
  }

  .cz-field-icon {
    position: absolute;
    inset-block-start: 50%;
    inset-inline-start: 1rem;
    width: 1.05rem;
    height: 1.05rem;
    color: var(--cz-text-muted);
    transform: translateY(-50%);
    pointer-events: none;
  }

  .cz-choice-button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    text-align: start;
  }

  .cz-choice-button i {
    color: var(--cz-text-muted);
    transition: transform var(--cz-duration) var(--cz-ease);
  }

  .cz-choice.is-open .cz-choice-button i {
    transform: rotate(180deg);
  }

  .cz-choice-menu {
    position: absolute;
    inset-block-start: calc(100% + 0.45rem);
    inset-inline: 0;
    z-index: var(--cz-z-popover);
    display: grid;
    gap: 0.25rem;
    max-height: 15rem;
    overflow: auto;
    padding: 0.45rem;
    border: 1px solid rgb(var(--cz-accent-2-rgb) / 0.28);
    border-radius: var(--cz-radius-md);
    background: rgb(14 18 29 / 0.98);
    box-shadow:
      0 24px 70px rgb(0 0 0 / 0.5),
      0 0 34px rgb(var(--cz-accent-rgb) / 0.2);
    backdrop-filter: blur(18px) saturate(150%);
    -webkit-backdrop-filter: blur(18px) saturate(150%);
    opacity: 0;
    transform: translateY(-0.25rem) scale(0.98);
    pointer-events: none;
    transition:
      opacity var(--cz-duration-fast) var(--cz-ease),
      transform var(--cz-duration-fast) var(--cz-ease);
  }

  .cz-choice.is-open .cz-choice-menu {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
  }

  .cz-choice-menu button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 42px;
    padding: 0.7rem 0.75rem;
    border-radius: var(--cz-radius-sm);
    background: transparent;
    color: var(--cz-text-soft);
    font-weight: 750;
    text-align: start;
    transition:
      background var(--cz-duration-fast) var(--cz-ease),
      color var(--cz-duration-fast) var(--cz-ease);
  }

  .cz-choice-menu button:hover,
  .cz-choice-menu button[aria-selected="true"] {
    background: rgb(var(--cz-accent-rgb) / 0.22);
    color: #fff;
  }

  .cz-choice-menu button[aria-selected="true"]::after {
    content: "\f00c";
    font-family: "Font Awesome 6 Pro";
    font-weight: 900;
    color: var(--cz-accent-soft);
  }

  .cz-booking-panel {
    container-type: inline-size;
    display: grid;
    gap: var(--cz-space-md);
  }

  .cz-booking-panel.is-active {
    animation: cz-panel-in 260ms var(--cz-ease-out) both;
  }

  .cz-booking-actions {
    display: grid;
    gap: 0.75rem;
  }

  @container (min-width: 560px) {
    .cz-form-grid[data-cols="2"] {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .cz-form-grid[data-cols="3"] {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
}

/* -----------------------------
   ANIMATIONS
----------------------------- */
@layer animations {
  @keyframes cz-float-glow {
    0%,
    100% {
      transform: translate3d(0, 0, 0) scale(1);
      opacity: 0.72;
    }

    50% {
      transform: translate3d(1.2rem, -0.9rem, 0) scale(1.05);
      opacity: 1;
    }
  }

  @keyframes cz-fade-up {
    from {
      opacity: 0;
      transform: translateY(18px);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  @keyframes cz-scale-in {
    from {
      opacity: 0;
      transform: scale(0.96);
    }

    to {
      opacity: 1;
      transform: scale(1);
    }
  }

  @keyframes cz-panel-in {
    from {
      opacity: 0;
      transform: translateY(0.5rem) scale(0.985);
    }

    to {
      opacity: 1;
      transform: translateY(0) scale(1);
    }
  }

  @keyframes cz-shimmer {
    from {
      background-position: -180% 0;
    }

    to {
      background-position: 180% 0;
    }
  }

  .cz-animate-in {
    animation: cz-fade-up var(--cz-duration-slow) var(--cz-ease-out) both;
  }

  .cz-animate-scale {
    animation: cz-scale-in var(--cz-duration-slow) var(--cz-ease-out) both;
  }

  .cz-delay-1 {
    animation-delay: 80ms;
  }

  .cz-delay-2 {
    animation-delay: 160ms;
  }

  .cz-delay-3 {
    animation-delay: 240ms;
  }

  .cz-delay-4 {
    animation-delay: 320ms;
  }

  .cz-shimmer {
    background-image: linear-gradient(90deg, rgb(255 255 255 / 0.04), rgb(255 255 255 / 0.12), rgb(255 255 255 / 0.04));
    background-size: 220% 100%;
    animation: cz-shimmer 1.6s linear infinite;
  }

  @supports (animation-timeline: view()) {
    .cz-reveal {
      opacity: 0;
      transform: translateY(22px);
      animation: cz-fade-up both var(--cz-ease-out);
      animation-timeline: view();
      animation-range: entry 12% cover 30%;
    }
  }

  @media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
      scroll-behavior: auto !important;
      animation-duration: 0.001ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.001ms !important;
    }
  }
}

/* -----------------------------
   UTILITIES
----------------------------- */
@layer utilities {
  .cz-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .cz-hidden {
    display: none !important;
  }

  .cz-center {
    text-align: center;
    justify-items: center;
  }

  .cz-full-bleed {
    width: 100vw;
    margin-inline-start: 50%;
    transform: translateX(-50%);
  }

  .cz-nowrap {
    white-space: nowrap;
  }

  .cz-balance {
    text-wrap: balance;
  }

  .cz-pretty {
    text-wrap: pretty;
  }

  .cz-max-sm {
    max-width: 42rem;
  }

  .cz-max-md {
    max-width: 56rem;
  }

  .cz-max-lg {
    max-width: 72rem;
  }

  .cz-mt-sm {
    margin-block-start: var(--cz-space-sm);
  }

  .cz-mt-md {
    margin-block-start: var(--cz-space-md);
  }

  .cz-mt-lg {
    margin-block-start: var(--cz-space-lg);
  }

  .cz-mt-xl {
    margin-block-start: var(--cz-space-xl);
  }

  .cz-hide-mobile {
    display: none !important;
  }

  @media (min-width: 760px) {
    .cz-hide-mobile {
      display: initial !important;
    }

    .cz-hide-desktop {
      display: none !important;
    }
  }

  @media (hover: none) {
    .cz-btn:hover {
      transform: none;
    }
  }
}

.cz-nav-link.is-active {
  border: 1px solid rgb(var(--cz-accent-2-rgb) / 0.34);
  background: rgb(var(--cz-accent-rgb) / 0.16);
  color: var(--cz-accent-soft);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.07),
    0 12px 30px rgb(var(--cz-accent-rgb) / 0.16);
}

.cz-nav-link.is-active:hover {
  color: #fff;
  background: rgb(var(--cz-accent-rgb) / 0.22);
}
