@layer pages.home {
  .home-main {
    position: relative;
    overflow: clip;
  }

  .home-main::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    pointer-events: none;
    background:
      radial-gradient(circle at 22% 15%, rgb(var(--cz-accent-rgb) / 0.26), transparent 28rem),
      radial-gradient(circle at 80% 12%, rgb(var(--cz-accent-2-rgb) / 0.2), transparent 30rem),
      linear-gradient(
        120deg,
        rgb(255 255 255 / 0.035),
        transparent 36%,
        rgb(var(--cz-accent-rgb) / 0.08),
        transparent 72%
      );
    animation: homeBgShift 12s var(--cz-ease) infinite alternate;
  }

  .home-hero {
    display: grid;
    align-items: center;
    min-height: calc(100svh - var(--cz-header-h));
    padding-block: clamp(4rem, 9vw, 8rem);
  }

  .home-hero-inner {
    display: grid;
    justify-items: center;
    text-align: center;
  }

  .home-hero-copy {
    display: grid;
    justify-items: center;
    gap: var(--cz-space-lg);
    max-width: 940px;
  }

  .home-hero-title {
    max-width: 12ch;
    font-size: clamp(3.4rem, 11vw, 8.8rem);
    letter-spacing: -0.075em;
  }

  .home-hero-title span {
    background: linear-gradient(
      110deg,
      #ffffff 0%,
      #ffffff 18%,
      #efe7ff 34%,
      #c9adff 48%,
      #9f62f2 58%,
      #d8c5ff 72%,
      #ffffff 88%,
      #ffffff 100%
    );
    background-size: 180% 100%;
    background-position: 0% 50%;
    -webkit-background-clip: text;
    background-clip: text;
    padding: 0 15px;
    color: transparent;
    animation: homeTextShine 8s ease-in-out infinite alternate;
    will-change: background-position;
  }

  .home-hero-lede {
    max-width: 760px;
    font-size: clamp(1.05rem, 2vw, 1.35rem);
  }

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

  .home-trust {
    margin-block-start: calc(var(--cz-space-xl) * -1);
    padding-block-end: var(--cz-space-2xl);
  }

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

  .home-booking-shell {
    display: grid;
    gap: var(--cz-space-lg);
    align-items: stretch;
    padding: clamp(1rem, 3vw, 1.5rem);
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-xl);
    background: linear-gradient(135deg, rgb(255 255 255 / 0.07), rgb(255 255 255 / 0.025)), rgb(16 23 34 / 0.72);
    box-shadow: var(--cz-shadow-card);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  }

  .home-booking-choice {
    display: grid;
    align-content: start;
    gap: var(--cz-space-md);
  }

  .home-booking-choice h2 {
    max-width: 11ch;
  }

  .home-service-picker {
    display: grid;
    gap: var(--cz-space-sm);
  }

  .home-service-option {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    align-items: center;
    padding: 1rem;
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-lg);
    background: rgb(255 255 255 / 0.045);
    color: var(--cz-text);
    text-align: start;
    transition:
      border-color var(--cz-duration) var(--cz-ease),
      background var(--cz-duration) var(--cz-ease),
      transform var(--cz-duration) var(--cz-ease);
  }

  .home-service-option:hover,
  .home-service-option.is-active {
    border-color: rgb(var(--cz-accent-2-rgb) / 0.95);
    background: rgb(var(--cz-accent-rgb) / 0.16);
    transform: translateY(-2px);
  }

  .home-service-option-icon {
    display: grid;
    place-items: center;
    width: 3rem;
    aspect-ratio: 1;
    border-radius: var(--cz-radius-md);
    background: rgb(var(--cz-accent-rgb) / 0.18);
    color: #c9adff;
    font-size: 1.25rem;
  }

  .home-service-option strong,
  .home-service-option em {
    display: block;
  }

  .home-service-option em {
    margin-block-start: 0.25rem;
    color: var(--cz-text-muted);
    font-size: var(--cz-small);
    font-style: normal;
  }

  .home-booking-form-card {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 34rem;
    padding: clamp(1.25rem, 3vw, 2rem);
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-xl);
    background: rgb(5 7 12 / 0.35);
  }

  .cz-booking-panel {
    display: flex;
    flex-direction: column;
    gap: clamp(1.25rem, 2.4vw, 1.75rem);
    width: 100%;
    opacity: 1;
    transform: translateY(0);
  }

  .cz-booking-panel.is-leaving {
    opacity: 0;
    transform: translateY(0.35rem);
    transition:
      opacity 160ms var(--cz-ease),
      transform 160ms var(--cz-ease);
  }

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

  .cz-booking-panel[hidden] {
    display: none !important;
  }

  .home-booking-form-head {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding-block-end: var(--cz-space-md);
    border-block-end: 1px solid var(--cz-border-soft);
  }

  .home-booking-form-icon {
    display: grid;
    place-items: center;
    flex: 0 0 3.25rem;
    width: 3.25rem;
    aspect-ratio: 1;
    border: 1px solid rgb(var(--cz-accent-2-rgb) / 0.32);
    border-radius: var(--cz-radius-lg);
    background:
      radial-gradient(circle at 32% 22%, rgb(255 255 255 / 0.18), transparent 38%), rgb(var(--cz-accent-rgb) / 0.18);
    color: #c9adff;
    font-size: 1.35rem;
    box-shadow: 0 16px 40px rgb(var(--cz-accent-rgb) / 0.18);
  }

  .home-booking-form-head h3 {
    font-size: clamp(1.25rem, 2vw, 1.65rem);
    letter-spacing: -0.035em;
  }

  .home-booking-form-head p {
    margin-block-start: 0.25rem;
    color: var(--cz-text-muted);
    font-size: var(--cz-small);
    line-height: 1.5;
  }

  .home-booking-fields {
    display: flex;
    flex-wrap: wrap;
    gap: clamp(1rem, 2vw, 1.25rem);
  }

  .home-booking-fields > .cz-field {
    flex: 1 1 min(100%, 18rem);
  }

  .home-booking-fields .cz-input,
  .home-booking-fields .cz-choice-button {
    min-height: 58px;
  }

  .home-steps-flow {
    position: relative;
    display: grid;
    gap: var(--cz-space-lg);
  }

  .home-step-card {
    position: relative;
    z-index: 1;
    display: grid;
    gap: var(--cz-space-sm);
    border: 1px solid rgb(255 255 255 / 0.08);
    box-shadow: 0 18px 48px rgb(0 0 0 / 0.26);
    animation: homeStepBorderPulse 6s ease-in-out infinite;
  }

  .home-step-card:nth-child(1) {
    animation-delay: 0s;
  }

  .home-step-card:nth-child(2) {
    animation-delay: 2s;
  }

  .home-step-card:nth-child(3) {
    animation-delay: 4s;
  }

  .home-step-icon {
    display: grid;
    place-items: center;
    width: 3rem;
    aspect-ratio: 1;
    border-radius: var(--cz-radius-md);
    background: rgb(var(--cz-accent-rgb) / 0.14);
    color: #c9adff;
    font-size: 1.2rem;
  }

  .home-step-number {
    color: #c9adff;
    font-size: var(--cz-xs);
    font-weight: 900;
    letter-spacing: 0.16em;
  }

  .home-vehicles .cz-section-head {
    margin-inline: auto;
    text-align: center;
    justify-items: center;
  }

  .home-vehicle-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.5rem;
  }

  .home-vehicle-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 1.15rem;
    min-height: 100%;
    padding: 1.5rem 1.45rem 1.55rem;
    border: 1px solid rgb(255 255 255 / 0.11);
    border-radius: 1.6rem;
    background:
      linear-gradient(180deg, rgb(255 255 255 / 0.04), rgb(255 255 255 / 0.02)),
      linear-gradient(135deg, rgb(22 28 42 / 0.96), rgb(17 22 34 / 0.92));
    box-shadow:
      inset 0 1px 0 rgb(255 255 255 / 0.04),
      0 18px 44px rgb(0 0 0 / 0.24);
    transition:
      border-color 220ms ease,
      box-shadow 220ms ease,
      transform 220ms ease,
      background 220ms ease;
  }

  .home-vehicle-card:hover {
    transform: translateY(-4px);
    border-color: rgb(var(--cz-accent-2-rgb) / 0.82);
    box-shadow:
      inset 0 1px 0 rgb(255 255 255 / 0.05),
      0 20px 50px rgb(0 0 0 / 0.28),
      0 0 0 1px rgb(var(--cz-accent-rgb) / 0.14),
      0 0 26px rgb(var(--cz-accent-rgb) / 0.12);
  }

  .home-vehicle-top,
  .home-vehicle-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
  }

  .home-vehicle-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 4.1rem;
    width: 4.1rem;
    height: 4.1rem;
    border: 1px solid rgb(var(--cz-accent-rgb) / 0.26);
    border-radius: 1.15rem;
    background: rgb(var(--cz-accent-rgb) / 0.11);
    color: rgb(var(--cz-accent-2-rgb) / 0.96);
    font-size: 1.5rem;
  }

  .home-vehicle-chip {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.42rem 0.8rem;
    border: 1px solid rgb(255 255 255 / 0.12);
    border-radius: 999px;
    background: rgb(255 255 255 / 0.05);
    color: rgb(255 255 255 / 0.78);
    font-size: 0.84rem;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
  }

  .home-vehicle-chip--gold {
    border-color: rgb(255 208 102 / 0.28);
    background: rgb(255 208 102 / 0.08);
    color: rgb(255 220 140 / 0.96);
  }

  .home-vehicle-card h3 {
    margin: 0;
    font-size: clamp(2rem, 1.6vw, 2.6rem);
    line-height: 1;
    letter-spacing: -0.03em;
  }

  .home-vehicle-copy {
    max-width: 30ch;
    margin: 0;
    color: rgb(255 255 255 / 0.78);
    font-size: 1rem;
    line-height: 1.62;
  }

  .home-vehicle-card ul,
  .home-vehicle-points {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .home-vehicle-card li,
  .home-vehicle-points li {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    color: rgb(255 255 255 / 0.84);
    line-height: 1.45;
  }

  .home-vehicle-card li i,
  .home-vehicle-points li i {
    width: 1.1rem;
    min-width: 1.1rem;
    margin-block-start: 0.15rem;
    color: rgb(var(--cz-accent-2-rgb) / 0.95);
    font-size: 0.98rem;
    text-align: center;
  }

  .home-vehicle-points li span {
    display: block;
    flex: 1;
  }

  .home-coverage-card {
    display: grid;
    gap: var(--cz-space-xl);
    align-items: center;
    padding: clamp(1.25rem, 4vw, 2rem);
  }

  .home-city-rotator {
    position: relative;
    min-height: 12rem;
    overflow: hidden;
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-xl);
    background:
      radial-gradient(circle at 50% 50%, rgb(var(--cz-accent-rgb) / 0.22), transparent 60%), rgb(255 255 255 / 0.04);
  }

  .home-city-slide {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 0.45rem;
    opacity: 0;
    transform: translateY(0.75rem);
    animation: cityRotate 21s infinite;
  }

  .home-city-slide:nth-child(1) {
    animation-delay: 0s;
  }

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

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

  .home-city-slide:nth-child(4) {
    animation-delay: 9s;
  }

  .home-city-slide:nth-child(5) {
    animation-delay: 12s;
  }

  .home-city-slide:nth-child(6) {
    animation-delay: 15s;
  }

  .home-city-slide:nth-child(7) {
    animation-delay: 18s;
  }

  .home-city-slide .fi {
    font-size: 2rem;
    border-radius: 0.2rem;
  }

  .home-city-slide strong {
    font-size: clamp(1.7rem, 4vw, 2.6rem);
    line-height: 1;
  }

  .home-city-slide em {
    color: var(--cz-text-muted);
    font-style: normal;
  }

  .home-keyword-grid {
    display: grid;
    gap: var(--cz-space-sm);
  }

  .home-keyword-grid a {
    color: var(--cz-text);
    font-weight: 850;
    transition:
      transform var(--cz-duration) var(--cz-ease),
      border-color var(--cz-duration) var(--cz-ease);
  }

  .home-keyword-grid a:hover {
    transform: translateY(-2px);
    border-color: rgb(var(--cz-accent-2-rgb) / 0.4);
  }

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

  .home-testimonial-card,
  .home-blog-card {
    display: grid;
    gap: var(--cz-space-md);
  }

  .home-testimonial-stars {
    display: flex;
    gap: 0.28rem;
    color: var(--cz-gold);
    font-size: 0.9rem;
  }

  .home-testimonial-card p {
    color: var(--cz-text-soft);
    font-size: var(--cz-body-lg);
    line-height: 1.6;
  }

  .home-testimonial-card footer {
    display: grid;
    gap: 0.15rem;
    margin-block-start: auto;
  }

  .home-testimonial-card footer span {
    color: var(--cz-text-muted);
    font-size: var(--cz-small);
  }

  .home-blog-card h3 {
    max-width: 14ch;
  }

  .home-blog-card p {
    color: var(--cz-text-muted);
  }

  .home-blog-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    width: fit-content;
    margin-block-start: auto;
    color: #c9adff;
    font-weight: 850;
  }

  .home-blog-link i {
    transition: transform var(--cz-duration) var(--cz-ease);
  }

  .home-blog-link:hover i {
    transform: translateX(0.25rem);
  }

  .home-blog-actions {
    display: flex;
    justify-content: center;
    margin-block-start: var(--cz-space-xl);
  }

  .home-faq-list {
    display: grid;
    gap: 0.85rem;
  }

  .home-faq-item {
    overflow: clip;
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-lg);
    background: rgb(255 255 255 / 0.045);
  }

  .home-faq-item summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 64px;
    padding: 1rem 1.15rem;
    color: var(--cz-text);
    font-weight: 850;
    cursor: pointer;
    list-style: none;
  }

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

  .home-faq-item summary::after {
    content: "+";
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    width: 1.75rem;
    aspect-ratio: 1;
    border: 1px solid var(--cz-border);
    border-radius: 999px;
    color: #c9adff;
    line-height: 1;
  }

  .home-faq-item[open] summary::after {
    content: "−";
    background: rgb(var(--cz-accent-rgb) / 0.14);
  }

  .home-faq-answer {
    padding: 0 1.15rem 1.15rem;
    color: var(--cz-text-muted);
    font-size: var(--cz-small);
    line-height: 1.65;
  }

  @media (min-width: 860px) {
    .home-booking-shell {
      grid-template-columns: minmax(280px, 0.42fr) minmax(0, 1fr);
    }

    .home-steps-flow {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .home-steps-flow::before {
      content: "";
      position: absolute;
      left: 12%;
      right: 12%;
      top: 3.75rem;
      z-index: 0;
      height: 1px;
      border-radius: 999px;
      background: linear-gradient(
        90deg,
        rgb(var(--cz-accent-rgb) / 0.1),
        rgb(var(--cz-accent-2-rgb) / 0.22),
        rgb(var(--cz-accent-rgb) / 0.1)
      );
      pointer-events: none;
    }

    .home-coverage-card {
      grid-template-columns: minmax(0, 0.9fr) minmax(260px, 0.6fr);
    }

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

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

  @media (max-width: 1180px) {
    .home-vehicle-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (max-width: 760px) {
    .home-booking-form-card {
      min-height: auto;
    }

    .home-booking-form-head {
      display: none;
    }

    .home-booking-fields {
      display: grid;
      gap: var(--cz-space-md);
    }
  }

  @media (max-width: 640px) {
    .home-hero {
      min-height: auto;
      padding-block: var(--cz-space-3xl);
    }

    .home-hero-title {
      font-size: clamp(3rem, 16vw, 4.5rem);
    }

    .home-booking-choice > p {
      display: none;
    }

    .home-service-option em {
      display: none;
    }

    .home-keyword-grid,
    .home-vehicle-grid {
      grid-template-columns: 1fr;
    }

    .home-vehicle-card {
      padding: 1.35rem 1.2rem;
    }

    .home-vehicle-top,
    .home-vehicle-head {
      align-items: flex-start;
    }

    .home-vehicle-copy {
      max-width: none;
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .home-main::before,
    .home-hero-title span,
    .home-city-slide,
    .home-step-card,
    .cz-booking-panel.is-active {
      animation: none !important;
    }

    .home-hero-title span {
      background-position: 50% 0;
      padding: 0 15px;
    }
  }

  @keyframes homeTextShine {
    from {
      background-position: 0% 50%;
    }

    to {
      background-position: 100% 50%;
    }
  }

  @keyframes homeBgShift {
    from {
      transform: scale(1);
      opacity: 0.72;
    }

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

  @keyframes cityRotate {
    0%,
    10% {
      opacity: 0;
      transform: translateY(0.75rem) scale(0.98);
    }

    14%,
    26% {
      opacity: 1;
      transform: translateY(0) scale(1);
    }

    30%,
    100% {
      opacity: 0;
      transform: translateY(-0.75rem) scale(0.98);
    }
  }

  @keyframes bookingPanelFadeIn {
    from {
      opacity: 0;
      transform: translateY(0.55rem) scale(0.985);
    }

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

  @keyframes homeStepBorderPulse {
    0% {
      border-color: rgb(255 255 255 / 0.08);
      box-shadow: 0 18px 48px rgb(0 0 0 / 0.26);
    }

    12%,
    26% {
      border-color: rgb(var(--cz-accent-2-rgb) / 0.88);
      box-shadow:
        0 18px 48px rgb(0 0 0 / 0.28),
        0 0 0 1px rgb(var(--cz-accent-rgb) / 0.18),
        0 0 34px rgb(var(--cz-accent-rgb) / 0.24);
    }

    34%,
    100% {
      border-color: rgb(255 255 255 / 0.08);
      box-shadow: 0 18px 48px rgb(0 0 0 / 0.26);
    }
  }
}
