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

  .city-page::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    pointer-events: none;
    background:
      radial-gradient(circle at 22% 12%, rgb(var(--cz-accent-rgb) / 0.2), transparent 30rem),
      radial-gradient(circle at 82% 18%, rgb(var(--cz-accent-2-rgb) / 0.13), transparent 28rem);
  }

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

  .city-hero-grid,
  .city-split-grid {
    display: grid;
    gap: var(--cz-space-xl);
    align-items: start;
  }

  .city-hero-grid {
    align-items: center;
  }

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

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

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

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

  .city-airport-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    width: fit-content;
    padding: 0.65rem 0.85rem;
    border: 1px solid rgb(var(--cz-accent-2-rgb) / 0.28);
    border-radius: var(--cz-radius-pill);
    background: rgb(var(--cz-accent-rgb) / 0.14);
    color: var(--cz-accent-soft);
    font-size: var(--cz-small);
    font-weight: 850;
  }

  .city-hero-media {
    position: relative;
    isolation: isolate;
    overflow: visible;
    padding: 0.7rem;
    border-radius: calc(var(--cz-radius-xl) + 0.7rem);
  }

  .city-hero-media::before,
  .city-gallery-slide::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    padding: 2px;
    border-radius: inherit;
    background: linear-gradient(
      120deg,
      rgb(var(--cz-accent-rgb) / 0.18),
      rgb(var(--cz-accent-2-rgb) / 0.58),
      rgb(255 255 255 / 0.14),
      rgb(var(--cz-accent-rgb) / 0.18)
    );
    background-size: 260% 260%;
    animation: cityFrameShift 7s linear infinite;
    -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;
  }

  .city-hero-media::before {
    z-index: -1;
  }

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

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

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

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

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

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

  .city-copy-panel,
  .city-routes-card,
  .city-rating-card,
  .city-restaurants-card,
  .city-emergency-card,
  .city-gallery-card,
  .city-final-card {
    border: 1px solid var(--cz-border);
    border-radius: var(--cz-radius-xl);
    background: linear-gradient(180deg, rgb(255 255 255 / 0.055), rgb(255 255 255 / 0.022)), rgb(16 23 34 / 0.72);
    box-shadow: var(--cz-shadow-card);
  }

  .city-copy-panel,
  .city-routes-card,
  .city-rating-card,
  .city-restaurants-card,
  .city-emergency-card,
  .city-gallery-card {
    display: grid;
    gap: var(--cz-space-lg);
    padding: clamp(1.25rem, 4vw, 2rem);
  }

  .city-copy-panel h2,
  .city-routes-card h3,
  .city-rating-card h2,
  .city-restaurants-card h2,
  .city-emergency-copy h2,
  .city-gallery-head h2,
  .city-final-card h2 {
    max-width: 18ch;
  }

  .city-routes-card ul {
    display: grid;
    gap: 0.75rem;
    padding: 0;
    list-style: none;
  }

  .city-routes-card li {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    color: var(--cz-text-soft);
  }

  .city-routes-card i {
    margin-block-start: 0.25rem;
    color: #c9adff;
  }

  .city-list-grid,
  .city-restaurant-list,
  .city-planning-list,
  .city-emergency-grid {
    display: grid;
    gap: var(--cz-space-lg);
  }

  .city-info-card,
  .city-restaurant-list article,
  .city-planning-list article,
  .city-emergency-link {
    border: 1px solid rgb(255 255 255 / 0.1);
    border-radius: var(--cz-radius-lg);
    background: linear-gradient(180deg, rgb(255 255 255 / 0.045), rgb(255 255 255 / 0.02)), rgb(8 12 20 / 0.42);
  }

  .city-info-card {
    display: grid;
    gap: var(--cz-space-sm);
    min-height: 100%;
    padding: 1.25rem;
    border-radius: var(--cz-radius-xl);
    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);
  }

  .city-info-card:hover {
    transform: translateY(-4px);
    border-color: rgb(var(--cz-accent-2-rgb) / 0.42);
    background:
      radial-gradient(circle at 16% 0%, rgb(var(--cz-accent-rgb) / 0.12), transparent 14rem),
      linear-gradient(180deg, rgb(255 255 255 / 0.05), rgb(255 255 255 / 0.025)), rgb(16 21 32 / 0.9);
    box-shadow:
      var(--cz-shadow-card),
      0 0 22px rgb(var(--cz-accent-rgb) / 0.11);
  }

  .city-info-number {
    display: grid;
    place-items: center;
    width: 2.5rem;
    aspect-ratio: 1;
    border: 1px solid rgb(var(--cz-accent-2-rgb) / 0.34);
    border-radius: var(--cz-radius-md);
    background: rgb(var(--cz-accent-rgb) / 0.14);
    color: #c9adff;
    font-size: var(--cz-small);
    font-weight: 950;
  }

  .city-snapshot-section .city-split-grid {
    grid-template-columns: 1fr;
  }

  .city-rating-card {
    background:
      radial-gradient(circle at 20% 0%, rgb(var(--cz-accent-rgb) / 0.18), transparent 18rem),
      linear-gradient(180deg, rgb(255 255 255 / 0.055), rgb(255 255 255 / 0.022)), rgb(16 23 34 / 0.72);
  }

  .city-planning-list {
    gap: 0.9rem;
  }

  .city-planning-list article {
    display: grid;
    grid-template-columns: 2.8rem minmax(0, 1fr);
    gap: 0.85rem;
    align-items: start;
    padding: 1rem;
  }

  .city-planning-list article > :is(i, svg) {
    box-sizing: border-box;
    width: 2.8rem;
    height: 2.8rem;
    padding: 0.78rem;
    border-radius: var(--cz-radius-md);
    background: rgb(var(--cz-accent-rgb) / 0.14);
    color: #c9adff;
  }

  .city-planning-list article > div {
    display: grid;
    gap: 0.25rem;
    min-width: 0;
  }

  .city-planning-list strong,
  .city-planning-list span {
    display: block;
  }

  .city-planning-list strong {
    line-height: 1.15;
  }

  .city-planning-list span {
    color: var(--cz-text-muted);
    font-size: var(--cz-small);
    line-height: 1.5;
  }

  .city-restaurant-list article {
    display: grid;
    gap: 0.3rem;
    min-height: 100%;
    padding: 1rem;
  }

  .city-restaurant-list span {
    color: var(--cz-accent-soft);
    font-size: var(--cz-small);
    font-weight: 850;
  }

  .city-restaurant-list p {
    color: var(--cz-text-muted);
    font-size: var(--cz-small);
  }

  .city-emergency-card {
    border-color: rgb(var(--cz-accent-2-rgb) / 0.22);
    background:
      radial-gradient(circle at 12% 0%, rgb(var(--cz-accent-rgb) / 0.16), transparent 18rem),
      linear-gradient(180deg, rgb(255 255 255 / 0.055), rgb(255 255 255 / 0.022)), rgb(16 23 34 / 0.76);
  }

  .city-emergency-copy {
    display: grid;
    gap: var(--cz-space-sm);
  }

  .city-emergency-copy p {
    max-width: 68ch;
  }

  .city-emergency-link {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.85rem;
    align-items: center;
    min-height: 5rem;
    padding: 1rem;
    color: var(--cz-text);
    text-decoration: none;
    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);
  }

  .city-emergency-link:hover {
    transform: translateY(-3px);
    border-color: rgb(var(--cz-accent-2-rgb) / 0.5);
    background:
      radial-gradient(circle at 10% 0%, rgb(var(--cz-accent-rgb) / 0.14), transparent 10rem),
      linear-gradient(180deg, rgb(255 255 255 / 0.06), rgb(255 255 255 / 0.025)), rgb(8 12 20 / 0.52);
    box-shadow:
      var(--cz-shadow-card),
      0 0 24px rgb(var(--cz-accent-rgb) / 0.14);
  }

  .city-emergency-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.15rem;
  }

  .city-emergency-link strong,
  .city-emergency-link em {
    display: block;
  }

  .city-emergency-link em {
    margin-block-start: 0.15rem;
    color: var(--cz-accent-soft);
    font-size: 1.3rem;
    font-style: normal;
    font-weight: 950;
    letter-spacing: 0.02em;
  }

  .city-gallery-card {
    overflow: hidden;
    background:
      radial-gradient(circle at 18% 0%, rgb(var(--cz-accent-rgb) / 0.16), transparent 20rem),
      linear-gradient(180deg, rgb(255 255 255 / 0.055), rgb(255 255 255 / 0.022)), rgb(16 23 34 / 0.72);
  }

  .city-gallery-head {
    display: grid;
    gap: var(--cz-space-sm);
    max-width: 760px;
  }

  .city-gallery-splide {
    position: relative;
  }

  .city-gallery-splide .splide__track {
    overflow: hidden;
    border-radius: calc(var(--cz-radius-xl) + 0.7rem);
  }

  .city-gallery-splide .splide__list {
    display: flex;
    height: 100%;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none;
  }

  .city-gallery-splide .splide__slide {
    position: relative;
    flex-shrink: 0;
    width: 100%;
    margin: 0;
    list-style: none;
  }

  .city-gallery-slide {
    position: relative;
    isolation: isolate;
    min-height: clamp(25rem, 48vw, 38rem);
    margin: 0;
    padding: 0.7rem;
    overflow: hidden;
    border-radius: calc(var(--cz-radius-xl) + 0.7rem);
  }

  .city-gallery-slide img {
    position: absolute;
    inset: 0.7rem;
    z-index: 1;
    width: calc(100% - 1.4rem);
    height: calc(100% - 1.4rem);
    object-fit: cover;
    border-radius: var(--cz-radius-xl);
    box-shadow: var(--cz-shadow-soft);
  }

  .city-gallery-slide::after {
    content: "";
    position: absolute;
    inset: 0.7rem;
    z-index: 2;
    border-radius: var(--cz-radius-xl);
    background:
      linear-gradient(180deg, transparent 42%, rgb(5 7 12 / 0.82)),
      radial-gradient(circle at 78% 12%, rgb(var(--cz-accent-rgb) / 0.18), transparent 18rem);
    pointer-events: none;
  }

  .city-gallery-slide figcaption {
    position: absolute;
    inset-inline: 0;
    inset-block-end: 0;
    z-index: 3;
    display: grid;
    gap: 0.35rem;
    max-width: 44rem;
    padding: clamp(1.25rem, 4vw, 2.4rem);
  }

  .city-gallery-slide figcaption strong {
    color: var(--cz-text);
    font-size: clamp(1.8rem, 4vw, 3.4rem);
    line-height: 0.95;
    letter-spacing: -0.06em;
  }

  .city-gallery-slide figcaption span {
    max-width: 54ch;
    color: var(--cz-text-soft);
    font-size: var(--cz-body);
    line-height: 1.6;
  }

  .city-gallery-splide .splide__arrow {
    position: absolute;
    z-index: 5;
    top: 50%;
    display: grid;
    place-items: center;
    width: 3rem;
    height: 3rem;
    padding: 0;
    border: 1px solid rgb(255 255 255 / 0.16);
    border-radius: 999px;
    background: rgb(8 12 20 / 0.74);
    opacity: 1;
    cursor: pointer;
    transform: translateY(-50%);
    transition:
      background var(--cz-duration) var(--cz-ease),
      border-color var(--cz-duration) var(--cz-ease);
  }

  .city-gallery-splide .splide__arrow:hover {
    border-color: rgb(var(--cz-accent-2-rgb) / 0.5);
    background: rgb(var(--cz-accent-rgb) / 0.3);
  }

  .city-gallery-splide .splide__arrow--prev {
    left: 1.25rem;
  }

  .city-gallery-splide .splide__arrow--next {
    right: 1.25rem;
  }

  .city-gallery-splide .splide__arrow svg {
    width: 1rem;
    height: 1rem;
    fill: var(--cz-text);
  }

  .city-gallery-splide .splide__pagination {
    position: static;
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    margin: var(--cz-space-md) 0 0;
    padding: 0;
  }

  .city-gallery-splide .splide__pagination li {
    display: flex;
  }

  .city-gallery-splide .splide__pagination__page {
    width: 0.65rem;
    height: 0.65rem;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: rgb(255 255 255 / 0.28);
    opacity: 1;
    cursor: pointer;
    transform: none;
    transition:
      width var(--cz-duration) var(--cz-ease),
      background var(--cz-duration) var(--cz-ease);
  }

  .city-gallery-splide .splide__pagination__page.is-active {
    width: 2rem;
    background: rgb(var(--cz-accent-2-rgb) / 0.9);
  }

  .city-final-cta {
    padding-block: var(--cz-space-2xl) var(--cz-space-3xl);
  }

  .city-final-card {
    display: grid;
    justify-items: center;
    gap: var(--cz-space-lg);
    padding: clamp(1.5rem, 5vw, 3rem);
    text-align: center;
    background:
      radial-gradient(circle at 50% 0%, rgb(var(--cz-accent-rgb) / 0.18), transparent 22rem),
      linear-gradient(135deg, rgb(255 255 255 / 0.07), rgb(255 255 255 / 0.025)), rgb(16 23 34 / 0.72);
  }

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

  @media (min-width: 760px) {
    .city-emergency-card {
      grid-template-columns: minmax(0, 0.75fr) minmax(0, 1fr);
      align-items: center;
    }

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

  @media (min-width: 820px) {
    .city-hero-grid {
      grid-template-columns: minmax(0, 0.86fr) minmax(380px, 0.76fr);
    }

    .city-intro-section .city-split-grid {
      grid-template-columns: minmax(0, 0.9fr) minmax(360px, 0.7fr);
    }

    .city-list-grid {
      grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .city-restaurant-list {
      grid-template-columns: repeat(5, minmax(0, 1fr));
    }
  }

  @media (max-width: 1200px) {
    .city-restaurant-list {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (max-width: 1100px) {
    .city-list-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (max-width: 700px) {
    .city-hero-copy h1 {
      font-size: clamp(3rem, 15vw, 4.5rem);
    }

    .city-hero-actions .cz-btn,
    .city-final-actions .cz-btn {
      width: 100%;
    }

    .city-list-grid,
    .city-restaurant-list {
      grid-template-columns: 1fr;
    }

    .city-hero-media img {
      min-height: 20rem;
    }

    .city-gallery-slide {
      min-height: 28rem;
    }

    .city-gallery-splide .splide__arrow {
      width: 2.65rem;
      height: 2.65rem;
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .city-hero-media::before,
    .city-gallery-slide::before {
      animation: none !important;
    }
  }
}

.city-gallery-splide .splide__arrow svg {
  width: 1rem;
  height: 1rem;
  fill: var(--cz-text);
}

.city-gallery-splide .splide__arrow--prev svg {
  transform: rotate(180deg);
  transform-origin: center;
}
