/* ===========================================================
   Voyamore Core — City Carousel / Grid
   Mockup ref: Voyamore Homepage.html · "Departure cities"
   =========================================================== */

.vym-city-grid {
	display: grid;
	grid-template-columns: repeat(var(--vym-city-cols, 4), 1fr);
	gap: 18px;
}

.vym-city-tile {
	position: relative;
	display: block;
	aspect-ratio: 1 / 1;
	border-radius: 12px;
	overflow: hidden;
	cursor: pointer;
	border: 1px solid var(--vym-border);
	isolation: isolate;
	color: #fff;
	text-decoration: none;
}

.vym-city-tile__bg {
	position: absolute;
	inset: 0;
	background-color: #1a2a4a;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	transition: transform 0.6s var(--vym-ease);
}
.vym-city-tile:hover .vym-city-tile__bg { transform: scale(1.06); }
.vym-city-tile__bg::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0.18) 0%, transparent 35%);
	pointer-events: none;
}

.vym-city-tile__scrim {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,0.55) 75%, rgba(0,0,0,0.85) 100%);
	transition: background 0.4s var(--vym-ease);
}
.vym-city-tile:hover .vym-city-tile__scrim {
	background: linear-gradient(180deg, rgba(0,0,0,0.05) 20%, rgba(0,0,0,0.65) 65%, rgba(0,0,0,0.92) 100%);
}

.vym-city-tile__content {
	position: absolute;
	left: 18px;
	right: 18px;
	bottom: 18px;
	z-index: 2;
}
.vym-city-tile__region {
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: rgba(255, 255, 255, 0.78);
	margin-bottom: 8px;
	text-shadow: 0 1px 6px rgba(0, 0, 0, 0.45);
	font-weight: 500;
}
.vym-city-tile__name {
	font-family: var(--vym-font-display);
	font-size: 28px;
	font-weight: 400;
	line-height: 1.1;
	margin: 0;
	color: #fff;
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.55);
}

/* Mobile swiper variant */
.vym-city-carousel { padding-bottom: 2rem; }
.vym-city-carousel__group {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
}
.vym-city-carousel .vym-city-tile { aspect-ratio: 1 / 1; }
.vym-city-carousel .swiper-pagination-bullet { background: var(--vym-text); opacity: 0.4; }
.vym-city-carousel .swiper-pagination-bullet-active { background: var(--vym-accent); opacity: 1; }

@media (max-width: 980px) {
	.vym-city-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
	.vym-city-tile__name { font-size: 22px; }
	.vym-city-tile__content { left: 14px; right: 14px; bottom: 14px; }
}
@media (max-width: 480px) {
	.vym-city-grid { grid-template-columns: 1fr; }
}
