@layer pages.service {
  .service-page {
    position: relative;
    overflow: clip;
  }

  .service-page::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    pointer-events: none;
    background:
      radial-gradient(circle at 20% 10%, rgb(var(--cz-accent-rgb) / 0.22), transparent 30rem),
      radial-gradient(circle at 78% 20%, rgb(var(--cz-accent-2-rgb) / 0.16), transparent 28rem);
    opacity: 0.8;
  }

  /* -----------------------------
     HERO
  ----------------------------- */
  .service-hero {
    padding-block: clamp(4rem, 8vw, 7rem) var(--cz-space-xl);
  }

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

  .service-hero-copy {
    display: grid;
    gap: var(--cz-space-lg);
  }

  .service-hero-copy h1 {
    max-width: 11ch;
    font-size: clamp(3rem, 9vw, 7rem);
    letter-spacing: -0.075em;
  }

  .service-hero-copy p {
    max-width: 66ch;
    font-size: var(--cz-body-lg);
  }

  .service-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--cz-space-sm);
  }

  .service-hero-points,
  .service-hero-trust {
    display: none !important;
  }

  .service-hero-media {
    position: relative;
    isolation: isolate;
    overflow: visible;
    padding: 0.72rem;
    border: 0;
    border-radius: calc(var(--cz-radius-xl) + 0.72rem);
    background: transparent;
    box-shadow: none;
  }

  .service-hero-media::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    padding: 4px;
    border-radius: inherit;
    background: linear-gradient(
      120deg,
      rgb(var(--cz-accent-rgb) / 0.22),
      rgb(var(--cz-accent-2-rgb) / 0.72),
      rgb(255 255 255 / 0.2),
      rgb(var(--cz-accent-rgb) / 0.22)
    );
    background-size: 260% 260%;
    animation: serviceHeroFrameShift 3s linear infinite;
    pointer-events: none;
    -webkit-mask:
      linear-gradient(#000 0 0) content-box,
      linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask:
      linear-gradient(#000 0 0) content-box,
      linear-gradient(#000 0 0);
    mask-composite: exclude;
  }

  .service-hero-media::after {
    content: "";
    position: absolute;
    inset: 0.72rem;
    padding: 4px;
    border-radius: var(--cz-radius-xl);
    background:
      linear-gradient(180deg, transparent, rgb(5 7 12 / 0.21)),
      radial-gradient(circle at 72% 12%, rgb(var(--cz-accent-rgb) / 0.16), transparent 18rem);
    pointer-events: none;
  }

  .service-hero-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: var(--cz-radius-xl);
    box-shadow: var(--cz-shadow-soft);
  }

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

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

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

  /* -----------------------------
     TRUST STRIP
  ----------------------------- */
  .service-trust-section {
    padding-block: 0 var(--cz-space-3xl);
  }

  /* -----------------------------
     QUICK START
  ----------------------------- */
  .service-quick-book {
    padding-block: 0 var(--cz-space-2xl);
  }

  .service-quick-card {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    justify-items: center;
    gap: var(--cz-space-xl);
    overflow: hidden;
    padding: clamp(1.75rem, 5vw, 3rem);
    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);
    text-align: center;
  }

  .service-quick-card::before {
    content: "";
    position: absolute;
    inset: -30%;
    pointer-events: none;
    background:
      radial-gradient(circle at 50% 30%, rgb(var(--cz-accent-rgb) / 0.18), transparent 16rem),
      radial-gradient(circle at 20% 80%, rgb(var(--cz-accent-2-rgb) / 0.1), transparent 18rem);
    opacity: 0.85;
    animation: serviceQuickGlow 8s var(--cz-ease) infinite alternate;
  }

  .service-quick-copy,
  .service-quick-actions {
    position: relative;
    z-index: 1;
  }

  .service-quick-copy {
    display: grid;
    justify-items: center;
    gap: var(--cz-space-sm);
    max-width: 760px;
  }

  .service-quick-copy h2 {
    max-width: 14ch;
  }

  .service-quick-copy p {
    max-width: 66ch;
  }

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

  .service-quick-btn {
    position: relative;
    min-width: 12.5rem;
    overflow: hidden;
    gap: 0.55rem;
    animation: serviceQuickButtonBreath 4.5s var(--cz-ease) infinite;
  }

  .service-quick-btn:nth-child(2) {
    animation-delay: 1.2s;
  }

  .service-quick-btn::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, transparent, rgb(255 255 255 / 0.18), transparent);
    transform: translateX(-120%);
    animation: serviceButtonSweep 4.2s var(--cz-ease) infinite;
  }

  .service-quick-btn:nth-child(2)::before {
    animation-delay: 1.2s;
  }

  .service-quick-btn > * {
    position: relative;
    z-index: 1;
  }

  @keyframes serviceQuickGlow {
    from {
      transform: scale(1);
      opacity: 0.65;
    }

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

  @keyframes serviceQuickButtonBreath {
    0%,
    100% {
      box-shadow: 0 16px 44px rgb(var(--cz-accent-rgb) / 0.22);
    }

    50% {
      box-shadow: 0 18px 56px rgb(var(--cz-accent-2-rgb) / 0.32);
    }
  }

  @keyframes serviceButtonSweep {
    0%,
    65% {
      transform: translateX(-120%);
    }

    100% {
      transform: translateX(120%);
    }
  }

  /* -----------------------------
     WHY BOOK AHEAD
  ----------------------------- */
  .service-card-grid {
    display: grid;
    gap: var(--cz-space-lg);
  }

  .service-feature-card {
    display: grid;
    gap: var(--cz-space-md);
    animation: serviceFeaturePulse 8s ease-in-out infinite;
  }

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

  .service-feature-card:nth-child(2) {
    animation-delay: 2s;
  }

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

  .service-feature-card:nth-child(4) {
    animation-delay: 6s;
  }

  .service-feature-icon {
    display: grid;
    place-items: center;
    width: 3.6rem;
    aspect-ratio: 1;
    border: 1px solid rgb(var(--cz-accent-2-rgb) / 0.28);
    border-radius: var(--cz-radius-lg);
    background: rgb(var(--cz-accent-rgb) / 0.14);
    color: #c9adff;
    font-size: 1.45rem;
  }

  @keyframes serviceFeaturePulse {
    0% {
      border-color: var(--cz-border);
      box-shadow: var(--cz-shadow-card);
    }

    10%,
    22% {
      border-color: rgb(var(--cz-accent-2-rgb) / 0.72);
      box-shadow:
        var(--cz-shadow-card),
        0 0 0 1px rgb(var(--cz-accent-rgb) / 0.15),
        0 0 34px rgb(var(--cz-accent-rgb) / 0.22);
    }

    34%,
    100% {
      border-color: var(--cz-border);
      box-shadow: var(--cz-shadow-card);
    }
  }

  /* -----------------------------
     SPLIT IMAGE SECTIONS
  ----------------------------- */
  .service-split-grid {
    display: grid;
    gap: var(--cz-space-xl);
    align-items: center;
  }

  .service-split-media {
    position: relative;
    min-height: 22rem;
    overflow: hidden;
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-xl);
    box-shadow: var(--cz-shadow-card);
  }

  .service-split-media::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
      linear-gradient(180deg, transparent, rgb(5 7 12 / 0.35)),
      radial-gradient(circle at 72% 12%, rgb(var(--cz-accent-rgb) / 0.22), transparent 18rem);
  }

  .service-split-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .service-split-copy {
    display: grid;
    gap: var(--cz-space-lg);
  }

  .service-split-copy h2 {
    max-width: 12ch;
  }

  .service-check-list {
    display: grid;
    gap: 0.75rem;
    padding: 0;
    list-style: none;
  }

  .service-check-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    color: var(--cz-text-soft);
  }

  .service-check-list i {
    margin-block-start: 0.25rem;
    color: #c9adff;
  }

  /* -----------------------------
     WHAT TO EXPECT
  ----------------------------- */
  .service-included-grid {
    display: grid;
    gap: var(--cz-space-lg);
  }

  .service-included-item {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    min-height: 100%;
    overflow: hidden;
    padding: 1.15rem;
    border: 1px solid rgb(255 255 255 / 0.1);
    border-radius: var(--cz-radius-lg);
    background:
      linear-gradient(180deg, rgb(255 255 255 / 0.04), rgb(255 255 255 / 0.02)),
      linear-gradient(135deg, rgb(22 28 42 / 0.92), rgb(17 22 34 / 0.88));
    transition:
      transform var(--cz-duration) var(--cz-ease),
      border-color var(--cz-duration) var(--cz-ease),
      box-shadow var(--cz-duration) var(--cz-ease),
      background var(--cz-duration) var(--cz-ease);
  }

  .service-included-item:hover {
    transform: translateY(-4px);
    border-color: rgb(var(--cz-accent-2-rgb) / 0.52);
    background:
      radial-gradient(circle at 20% 0%, rgb(var(--cz-accent-rgb) / 0.14), transparent 12rem),
      linear-gradient(180deg, rgb(255 255 255 / 0.055), rgb(255 255 255 / 0.025)),
      linear-gradient(135deg, rgb(22 28 42 / 0.96), rgb(17 22 34 / 0.94));
    box-shadow:
      var(--cz-shadow-card),
      0 0 0 1px rgb(var(--cz-accent-rgb) / 0.12),
      0 0 26px rgb(var(--cz-accent-rgb) / 0.16);
  }

  .service-included-item > i {
    display: grid;
    place-items: center;
    flex: 0 0 2.75rem;
    width: 2.75rem;
    aspect-ratio: 1;
    margin-block-start: 0;
    border-radius: var(--cz-radius-md);
    background: rgb(var(--cz-accent-rgb) / 0.14);
    color: #c9adff;
    font-size: 1.25rem;
  }

  .service-included-item h3 {
    margin-block-end: 0.25rem;
    font-size: 1.2rem;
  }

  /* -----------------------------
     CITIES
  ----------------------------- */
  .service-city-card {
    display: grid;
    gap: var(--cz-space-lg);
    padding: clamp(1.25rem, 4vw, 2rem);
  }

  .service-city-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.95rem;
  }

  .service-city-tags a {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.6rem 1.5rem;
    border: 0;
    border-radius: var(--cz-radius-pill);
    background: rgb(255 255 255 / 0.06);
    color: var(--cz-text-soft);
    box-shadow:
      inset 0 0 0 1px rgb(255 255 255 / 0.12),
      0 0 0 rgb(var(--cz-accent-rgb) / 0);
    font-weight: 800;
    text-decoration: none;
    transition:
      background var(--cz-duration) var(--cz-ease),
      box-shadow var(--cz-duration) var(--cz-ease),
      color var(--cz-duration) var(--cz-ease),
      transform var(--cz-duration) var(--cz-ease);
  }

  .service-city-tags a:hover,
  .service-city-tags a:focus {
    transform: translateY(-2px);
    color: #fff;
    text-decoration: none;
    background:
      linear-gradient(135deg, rgb(var(--cz-accent-rgb) / 0.34), rgb(var(--cz-accent-2-rgb) / 0.18)),
      rgb(255 255 255 / 0.075);
    box-shadow:
      inset 0 0 0 1px rgb(var(--cz-accent-2-rgb) / 0.38),
      0 14px 30px rgb(var(--cz-accent-rgb) / 0.16);
  }

  /* -----------------------------
     CHAUFFEURIZE JOURNAL
  ----------------------------- */
  .service-related .cz-section-head p {
    max-width: 64ch;
  }

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

  .service-related-card {
    display: grid;
    gap: var(--cz-space-sm);
    color: var(--cz-text);
    transition:
      transform var(--cz-duration) var(--cz-ease),
      border-color var(--cz-duration) var(--cz-ease),
      box-shadow var(--cz-duration) var(--cz-ease);
  }

  .service-related-card:hover {
    transform: translateY(-4px);
    border-color: rgb(var(--cz-accent-2-rgb) / 0.44);
    box-shadow:
      var(--cz-shadow-card),
      0 0 26px rgb(var(--cz-accent-rgb) / 0.13);
  }

  .service-related-card span {
    color: #c9adff;
    font-size: var(--cz-xs);
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
  }

  .service-related-card i {
    color: #c9adff;
  }

  /* -----------------------------
     FAQ
  ----------------------------- */
  .service-faq-list {
    display: grid;
    gap: 0.85rem;
  }

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

  .service-faq-list summary {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.15rem;
    color: var(--cz-text);
    font-weight: 850;
    cursor: pointer;
    list-style: none;
  }

  .service-faq-list summary::-webkit-details-marker {
    display: none;
  }

  .service-faq-list 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;
  }

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

  .service-faq-list p {
    padding: 0 1.15rem 1.15rem;
    color: var(--cz-text-muted);
    font-size: var(--cz-small);
  }

  /* -----------------------------
     FINAL CTA
  ----------------------------- */
  .service-final-cta {
    padding-block: var(--cz-space-2xl) var(--cz-space-3xl);
  }

  .service-final-card {
    display: grid;
    justify-items: center;
    gap: var(--cz-space-lg);
    padding: clamp(1.25rem, 4vw, 2rem);
    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);
    text-align: center;
  }

  .service-final-card h2 {
    max-width: 12ch;
  }

  .service-final-card p {
    max-width: 58ch;
  }

  /* -----------------------------
     RESPONSIVE
  ----------------------------- */
  @media (min-width: 820px) {
    .service-hero-grid,
    .service-split-grid {
      grid-template-columns: minmax(0, 1fr) minmax(360px, 0.78fr);
    }

    .service-split-grid-reverse {
      grid-template-columns: minmax(360px, 0.78fr) minmax(0, 1fr);
    }

    .service-card-grid,
    .service-included-grid {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }

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

    .service-city-card {
      grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr);
      align-items: center;
    }
  }

  @media (max-width: 700px) {
    .service-hero {
      padding-block-start: var(--cz-space-2xl);
    }

    .service-hero-copy h1 {
      font-size: clamp(3rem, 15vw, 4.5rem);
    }

    .service-hero-actions .cz-btn,
    .service-quick-actions .cz-btn {
      width: 100%;
    }

    .service-hero-media {
      padding: 0.55rem;
    }

    .service-hero-media::after {
      inset: 0.55rem;
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .service-hero-media::before,
    .service-quick-card::before,
    .service-quick-btn,
    .service-quick-btn::before,
    .service-feature-card {
      animation: none !important;
    }
  }
}

.svg-inline--fa {
  margin-top: 0.25rem;
}
