:root {
	--ec-ink: #111827;
	--ec-muted: #667085;
	--ec-paper: #fffaf2;
	--ec-soft: #f4efe7;
	--ec-night: #08131b;
	--ec-warm: #f7ead8;
	--ec-line: rgba(17, 24, 39, 0.1);
	--ec-blue: #0a6f8f;
	--ec-coral: #e85d4f;
	--ec-gold: #e4a73f;
	--ec-green: #2b7a66;
	--ec-shadow: 0 24px 70px rgba(17, 24, 39, 0.16);
}

html {
	scroll-behavior: smooth;
}

.ec-home {
	background: var(--ec-paper);
	color: var(--ec-ink);
	font-family: "Sunsive", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	overflow-x: hidden;
}

.ec-home a {
	text-decoration: none;
}

.ec-home .container {
	max-width: 1240px;
}

.ec-nav-shell {
	background: transparent !important;
	left: 0;
	padding: 16px 20px 0;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 1000;
}

.ec-nav-shell .header-main,
.ec-nav-shell .header-main-inner {
	background: transparent !important;
	box-shadow: none !important;
	padding: 0 !important;
}

.ec-nav {
	align-items: center;
	backdrop-filter: blur(24px);
	background: rgba(255, 250, 242, 0.68);
	border: 1px solid rgba(255, 255, 255, 0.62);
	border-radius: 28px;
	box-shadow: 0 22px 70px rgba(8, 19, 27, 0.18);
	display: flex;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 1180px;
	min-height: 76px;
	padding: 10px 12px 10px 24px;
}

.ec-nav .left-area,
.ec-nav .button-area-start {
	align-items: center;
	display: flex;
	gap: 26px;
}

.ec-nav .logo img {
	height: auto;
	max-width: 130px;
}

.ec-nav .main-nav-area .rts-desktop-menu {
	align-items: center;
	display: flex;
	gap: 4px;
	margin: 0;
}

.ec-nav .main-nav-area .rts-desktop-menu .menu-item .rts-dropdown-main-element {
	border-radius: 999px;
	color: rgba(17, 24, 39, 0.72) !important;
	display: block;
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
	padding: 13px 16px;
	transition: all 0.25s ease;
}

.ec-nav .main-nav-area .rts-desktop-menu .menu-item .rts-dropdown-main-element:hover {
	background: rgba(8, 19, 27, 0.08);
	color: #0c2837 !important;
	transform: translateY(-1px);
}

.ec-nav .main-nav-area .rts-desktop-menu .menu-item .ec-nav-club {
	align-items: center;
	background: linear-gradient(135deg, #111827 0%, #0a6f8f 52%, #e85d4f 100%);
	box-shadow: 0 16px 34px rgba(10, 111, 143, 0.28);
	color: #fff !important;
	display: inline-flex;
	gap: 8px;
	margin-left: 4px;
}

.ec-nav .main-nav-area .rts-desktop-menu .menu-item .ec-nav-club:hover {
	background: linear-gradient(135deg, #0c1b24 0%, #0c7fa1 50%, #f06d54 100%);
	color: #fff !important;
	box-shadow: 0 20px 42px rgba(10, 111, 143, 0.36);
}

.ec-nav-cta {
	align-items: center;
	background: #10202c !important;
	border: 0 !important;
	box-shadow: 0 12px 30px rgba(16, 32, 44, 0.2);
	color: #fff !important;
	display: inline-flex;
	font-size: 14px;
	gap: 8px;
	min-height: 48px;
	padding: 0 18px !important;
}

.ec-menu-toggle {
	align-items: center;
	background: #10202c;
	border: 0;
	border-radius: 50%;
	color: #fff;
	display: none;
	height: 48px;
	justify-content: center;
	width: 48px;
}

.side-bar.active {
	right: 0;
	overflow-y: hidden;
}

body.ec-menu-open {
	overflow: hidden;
}

.ec-hero {
	background: var(--ec-night);
	color: #fff;
	min-height: 860px;
	overflow: hidden;
	padding: 188px 0 108px;
	position: relative;
}

.ec-hero__media,
.ec-hero__shade {
	inset: 0;
	position: absolute;
}

.ec-hero__media img {
	height: 100%;
	object-fit: cover;
	filter: saturate(1.12) contrast(1.08);
	transform: scale(1.06);
	width: 100%;
}

.ec-hero__shade {
	background:
		radial-gradient(circle at 78% 18%, rgba(228, 167, 63, 0.28), rgba(228, 167, 63, 0) 30%),
		linear-gradient(90deg, rgba(4, 12, 18, 0.94) 0%, rgba(6, 18, 28, 0.72) 42%, rgba(6, 18, 28, 0.18) 100%),
		linear-gradient(0deg, rgba(4, 12, 18, 0.96) 0%, rgba(4, 12, 18, 0.18) 48%, rgba(4, 12, 18, 0.42) 100%);
}

.ec-hero::after {
	background: linear-gradient(180deg, rgba(255, 250, 242, 0) 0%, var(--ec-paper) 100%);
	bottom: -1px;
	content: "";
	height: 150px;
	left: 0;
	position: absolute;
	right: 0;
	z-index: 1;
}

.ec-hero .container {
	display: grid;
	gap: 42px;
	grid-template-columns: minmax(0, 760px) minmax(260px, 360px);
	position: relative;
	z-index: 2;
}

.ec-eyebrow {
	align-items: center;
	color: var(--ec-gold);
	display: inline-flex;
	font-size: 12px;
	font-weight: 900;
	letter-spacing: 0;
	margin: 0 0 16px;
	text-transform: uppercase;
}

.ec-eyebrow::before {
	background: currentColor;
	border-radius: 999px;
	content: "";
	height: 8px;
	margin-right: 10px;
	width: 8px;
}

.ec-hero h1 {
	color: #fff;
	font-size: clamp(54px, 7.2vw, 104px);
	font-weight: 900;
	letter-spacing: 0;
	line-height: 0.96;
	margin: 0;
	max-width: 800px;
	text-wrap: balance;
}

.ec-hero__lead {
	color: rgba(255, 255, 255, 0.82);
	font-size: clamp(18px, 1.8vw, 22px);
	line-height: 1.5;
	margin: 22px 0 0;
	max-width: 610px;
}

.ec-search {
	align-items: center;
	backdrop-filter: blur(22px);
	background: rgba(255, 255, 255, 0.95);
	border: 1px solid rgba(255, 255, 255, 0.72);
	border-radius: 999px;
	box-shadow: 0 34px 90px rgba(0, 0, 0, 0.34);
	display: grid;
	gap: 12px;
	grid-template-columns: 22px minmax(0, 1fr) auto;
	margin-top: 34px;
	max-width: 720px;
	padding: 10px 10px 10px 24px;
}

.ec-search i {
	color: var(--ec-blue);
	font-size: 19px;
}

.ec-search input {
	background: transparent;
	border: 0;
	color: var(--ec-ink);
	font-size: 16px;
	font-weight: 700;
	height: 52px;
	outline: 0;
	width: 100%;
}

.ec-search input::placeholder {
	color: rgba(17, 24, 39, 0.48);
}

.ec-search button,
.ec-cta__button {
	align-items: center;
	background: linear-gradient(135deg, var(--ec-coral), #f19945);
	border: 0;
	border-radius: 999px;
	color: #fff;
	display: inline-flex;
	font-size: 15px;
	font-weight: 900;
	gap: 8px;
	justify-content: center;
	min-height: 52px;
	padding: 0 24px;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
	white-space: nowrap;
}

.ec-search button:hover,
.ec-cta__button:hover {
	box-shadow: 0 18px 42px rgba(232, 93, 79, 0.32);
	color: #fff;
	transform: translateY(-2px);
}

.ec-hero__quick {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 22px;
}

.ec-hero__quick a {
	backdrop-filter: blur(16px);
	background: rgba(255, 255, 255, 0.13);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 999px;
	color: rgba(255, 255, 255, 0.9);
	font-size: 13px;
	font-weight: 800;
	padding: 10px 15px;
	transition: all 0.25s ease;
}

.ec-hero__quick a:hover {
	background: rgba(255, 255, 255, 0.22);
	color: #fff;
	transform: translateY(-2px);
}

.ec-hero__panel {
	align-self: end;
	backdrop-filter: blur(22px);
	background: rgba(255, 255, 255, 0.11);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 22px;
	box-shadow: 0 30px 80px rgba(0, 0, 0, 0.22);
	display: grid;
	gap: 0;
	margin-bottom: 8px;
	overflow: hidden;
}

.ec-hero__panel div {
	border-bottom: 1px solid rgba(255, 255, 255, 0.16);
	padding: 24px;
}

.ec-hero__panel div:last-child {
	border-bottom: 0;
}

.ec-hero__panel strong {
	color: #fff;
	display: block;
	font-size: 38px;
	font-weight: 900;
	line-height: 1;
}

.ec-hero__panel span {
	color: rgba(255, 255, 255, 0.72);
	display: block;
	font-size: 13px;
	font-weight: 800;
	margin-top: 7px;
	text-transform: uppercase;
}

.ec-scroll-cue {
	align-items: center;
	background: rgba(255, 255, 255, 0.9);
	border-radius: 999px;
	bottom: 28px;
	color: var(--ec-ink);
	display: flex;
	height: 46px;
	justify-content: center;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: 46px;
	z-index: 3;
	animation: ecFloat 2.4s ease-in-out infinite;
}

.ec-proof {
	background: transparent;
	margin-top: -72px;
	position: relative;
	z-index: 4;
}

.ec-proof__grid {
	backdrop-filter: blur(18px);
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid var(--ec-line);
	border-radius: 22px;
	box-shadow: var(--ec-shadow);
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	overflow: hidden;
}

.ec-proof__item {
	border-right: 1px solid var(--ec-line);
	padding: 30px 26px;
}

.ec-proof__item:last-child {
	border-right: 0;
}

.ec-proof__item i {
	color: var(--ec-coral);
	font-size: 26px;
	margin-bottom: 18px;
}

.ec-proof__item h2 {
	color: var(--ec-ink);
	font-size: 20px;
	font-weight: 900;
	line-height: 1.15;
	margin: 0 0 10px;
}

.ec-proof__item p,
.ec-section-head p,
.ec-seo-intro p,
.ec-cta p,
.ec-footer p {
	color: var(--ec-muted);
	font-size: 16px;
	line-height: 1.55;
	margin: 0;
}

.ec-seo-intro {
	background: #fffaf2;
	padding: 78px 0 20px;
}

.ec-seo-intro .container {
	align-items: end;
	display: grid;
	gap: 42px;
	grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.7fr);
}

.ec-seo-intro h2 {
	color: var(--ec-ink);
	font-size: clamp(34px, 5vw, 64px);
	font-weight: 900;
	letter-spacing: 0;
	line-height: 0.98;
	margin: 0;
	text-wrap: balance;
}

.ec-seo-intro p {
	font-size: 18px;
	line-height: 1.7;
}

.ec-now,
.ec-today,
.ec-mood,
.ec-city-guides,
.ec-listing,
.ec-faq,
.ec-cta,
.ec-partners {
	padding: 88px 0;
}

.ec-now {
	background: var(--ec-paper);
	padding-top: 104px;
}

.ec-now__rail {
	display: grid;
	gap: 18px;
	grid-template-columns: 1.2fr repeat(3, minmax(0, 0.82fr));
	scrollbar-width: none;
}

.ec-now__rail::-webkit-scrollbar {
	display: none;
}

.ec-now-card {
	aspect-ratio: 0.78 / 1;
	border-radius: 22px;
	box-shadow: 0 24px 60px rgba(17, 24, 39, 0.16);
	color: #fff;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 380px;
	overflow: hidden;
	padding: 24px;
	position: relative;
	transition: transform 0.28s ease, box-shadow 0.28s ease;
}

.ec-now-card--wide {
	aspect-ratio: 1.18 / 1;
}

.ec-now-card img {
	height: 100%;
	inset: 0;
	object-fit: cover;
	position: absolute;
	transition: transform 0.6s ease, filter 0.6s ease;
	width: 100%;
	z-index: 0;
}

.ec-now-card::after {
	background: linear-gradient(180deg, rgba(6, 18, 28, 0.03) 0%, rgba(6, 18, 28, 0.9) 86%);
	content: "";
	inset: 0;
	position: absolute;
	z-index: 1;
}

.ec-now-card span,
.ec-now-card strong {
	position: relative;
	z-index: 2;
}

.ec-now-card span {
	backdrop-filter: blur(12px);
	background: rgba(255, 255, 255, 0.16);
	border: 1px solid rgba(255, 255, 255, 0.26);
	border-radius: 999px;
	color: #fff;
	font-size: 12px;
	font-weight: 900;
	margin-bottom: 12px;
	padding: 8px 12px;
	text-transform: uppercase;
	width: fit-content;
}

.ec-now-card strong {
	color: #fff;
	font-size: clamp(24px, 2.5vw, 38px);
	font-weight: 900;
	line-height: 1;
	text-wrap: balance;
}

.ec-now-card:hover {
	box-shadow: 0 34px 86px rgba(17, 24, 39, 0.26);
	color: #fff;
	transform: translateY(-6px);
}

.ec-now-card:hover img {
	filter: saturate(1.12) contrast(1.06);
	transform: scale(1.08);
}

.ec-today {
	background: #0b1720;
	color: #fff;
	position: relative;
}

.ec-today::before {
	background: linear-gradient(90deg, rgba(232, 93, 79, 0.22), rgba(10, 111, 143, 0.26));
	content: "";
	inset: 0;
	opacity: 0.72;
	position: absolute;
}

.ec-today .container {
	position: relative;
	z-index: 1;
}

.ec-today__layout {
	display: grid;
	gap: 20px;
	grid-template-columns: minmax(320px, 0.78fr) minmax(0, 1.22fr);
}

.ec-today__feature {
	align-items: flex-end;
	background:
		linear-gradient(180deg, rgba(6, 18, 28, 0.08), rgba(6, 18, 28, 0.9)),
		url("/assets/images/activity/01.webp") center / cover;
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 22px;
	color: #fff;
	display: flex;
	min-height: 410px;
	padding: 34px;
	transition: transform 0.28s ease, box-shadow 0.28s ease;
}

.ec-today__feature h2 {
	color: #fff;
	font-size: clamp(36px, 4.8vw, 70px);
	font-weight: 900;
	line-height: 0.98;
	margin: 0 0 18px;
	text-wrap: balance;
}

.ec-today__feature span {
	align-items: center;
	color: #fff;
	display: inline-flex;
	font-weight: 900;
	gap: 9px;
}

.ec-today__grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ec-today__grid a {
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 18px;
	color: #fff;
	display: flex;
	flex-direction: column;
	min-height: 196px;
	padding: 24px;
	transition: background 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
}

.ec-today__grid i {
	align-items: center;
	background: rgba(255, 255, 255, 0.12);
	border-radius: 50%;
	color: var(--ec-gold);
	display: flex;
	font-size: 22px;
	height: 48px;
	justify-content: center;
	margin-bottom: auto;
	width: 48px;
}

.ec-today__grid span {
	color: rgba(255, 255, 255, 0.6);
	font-size: 12px;
	font-weight: 900;
	margin-top: 24px;
	text-transform: uppercase;
}

.ec-today__grid strong {
	color: #fff;
	font-size: 22px;
	font-weight: 900;
	line-height: 1.08;
	margin-top: 8px;
}

.ec-today__feature:hover,
.ec-today__grid a:hover {
	background-color: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.28);
	color: #fff;
	transform: translateY(-5px);
}

.ec-city-guides {
	background: #fff;
}

.ec-city-guides__grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ec-city-guides__grid a {
	align-items: center;
	background: linear-gradient(135deg, #fff 0%, #fff7ec 100%);
	border: 1px solid rgba(17, 24, 39, 0.08);
	border-radius: 18px;
	color: var(--ec-ink);
	display: flex;
	font-family: "Playfair Display", serif;
	font-size: 28px;
	font-weight: 900;
	gap: 18px;
	justify-content: space-between;
	letter-spacing: 0;
	line-height: 1;
	min-height: 128px;
	padding: 24px;
	transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
}

.ec-city-guides__grid a:hover {
	border-color: rgba(232, 93, 79, 0.25);
	box-shadow: var(--ec-shadow);
	transform: translateY(-5px);
}

.ec-city-guides__grid i {
	color: var(--ec-coral);
	font-size: 20px;
}

.ec-faq {
	background: var(--ec-warm);
}

.ec-faq__grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ec-faq__grid article {
	background: #fff;
	border: 1px solid rgba(17, 24, 39, 0.08);
	border-radius: 18px;
	box-shadow: 0 18px 48px rgba(17, 24, 39, 0.08);
	padding: 30px;
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.ec-faq__grid article:hover {
	box-shadow: var(--ec-shadow);
	transform: translateY(-5px);
}

.ec-faq__grid h3 {
	color: var(--ec-ink);
	font-family: "Playfair Display", serif;
	font-size: 30px;
	font-weight: 900;
	letter-spacing: 0;
	line-height: 1;
	margin: 0 0 16px;
}

.ec-faq__grid p {
	color: #4b5d6d;
	font-size: 16px;
	line-height: 1.7;
	margin: 0 0 20px;
}

.ec-faq__grid a {
	color: var(--ec-coral);
	font-size: 14px;
	font-weight: 900;
}

.ec-section-head {
	margin: 0 auto 34px;
	max-width: 760px;
	text-align: center;
}

.ec-section-head--split {
	align-items: end;
	display: grid;
	gap: 40px;
	grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.55fr);
	max-width: none;
	text-align: left;
}

.ec-section-head h2,
.ec-cta h2 {
	color: var(--ec-ink);
	font-size: clamp(34px, 5vw, 64px);
	font-weight: 900;
	letter-spacing: 0;
	line-height: 0.98;
	margin: 0 0 18px;
	text-wrap: balance;
}

.ec-mood__grid {
	display: grid;
	gap: 18px;
	grid-template-columns: 1.35fr 0.85fr 0.85fr;
}

.ec-mood-card {
	aspect-ratio: 1 / 1.05;
	border-radius: 22px;
	box-shadow: 0 22px 55px rgba(17, 24, 39, 0.14);
	color: #fff;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	overflow: hidden;
	padding: 28px;
	position: relative;
	transform: translateZ(0);
}

.ec-mood-card--large {
	aspect-ratio: 1.5 / 1;
}

.ec-mood-card img,
.ec-place-card img {
	height: 100%;
	inset: 0;
	object-fit: cover;
	position: absolute;
	transition: transform 0.55s ease, filter 0.55s ease;
	width: 100%;
	z-index: 0;
}

.ec-mood-card::after,
.ec-place-card::after {
	background: linear-gradient(180deg, rgba(6, 18, 28, 0.03) 0%, rgba(6, 18, 28, 0.38) 38%, rgba(6, 18, 28, 0.92) 100%);
	content: "";
	inset: 0;
	position: absolute;
	z-index: 1;
}

.ec-mood-card span,
.ec-mood-card strong {
	position: relative;
	z-index: 2;
}

.ec-mood-card span {
	color: var(--ec-gold);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.ec-mood-card strong {
	color: #fff;
	font-size: clamp(24px, 3vw, 38px);
	font-weight: 900;
	line-height: 1;
	margin-top: 8px;
	max-width: 440px;
}

.ec-mood-card:hover,
.ec-place-card:hover {
	color: #fff;
	transform: translateY(-6px);
}

.ec-mood-card:hover img,
.ec-place-card:hover img {
	filter: saturate(1.12) contrast(1.05);
	transform: scale(1.08);
}

.ec-listing {
	background: #fff;
}

.ec-listing--priority {
	background: linear-gradient(180deg, var(--ec-paper) 0%, #fff 24%);
	padding-top: 104px;
}

.ec-listing--soft {
	background: linear-gradient(180deg, #0b1720 0%, #13212b 100%);
	color: #fff;
}

.ec-listing--soft .ec-section-head h2 {
	color: #fff;
}

.ec-listing--soft .ec-section-head p {
	color: rgba(255, 255, 255, 0.68);
}

.ec-card-grid {
	display: grid;
	gap: 24px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ec-card-grid--hotels {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ec-place-card {
	aspect-ratio: 0.72 / 1;
	background: #111827;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 24px;
	box-shadow: 0 24px 60px rgba(17, 24, 39, 0.14);
	color: #fff;
	display: block;
	overflow: hidden;
	position: relative;
	transition: opacity 0.25s ease, transform 0.28s ease, box-shadow 0.28s ease;
}

.ec-place-card--hotel {
	aspect-ratio: 0.95 / 1;
}

.ec-place-card:hover {
	box-shadow: 0 30px 70px rgba(17, 24, 39, 0.24);
}

.ec-place-card--muted {
	opacity: 0.28;
}

.ec-badge {
	backdrop-filter: blur(14px);
	background: rgba(255, 255, 255, 0.2);
	border: 1px solid rgba(255, 255, 255, 0.28);
	border-radius: 999px;
	color: #fff;
	font-size: 12px;
	font-weight: 900;
	left: 18px;
	padding: 8px 12px;
	position: absolute;
	text-transform: uppercase;
	top: 18px;
	z-index: 3;
}

.ec-card-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	left: 18px;
	position: absolute;
	right: 18px;
	top: 60px;
	z-index: 3;
}

.ec-card-tags span {
	backdrop-filter: blur(12px);
	background: rgba(6, 18, 28, 0.36);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	color: rgba(255, 255, 255, 0.86);
	font-size: 11px;
	font-weight: 900;
	padding: 7px 10px;
	text-transform: uppercase;
	transition: transform 0.25s ease;
}

.ec-place-card:hover .ec-card-tags span:first-child {
	transform: translateY(-2px);
}

.ec-place-card__content {
	bottom: 0;
	left: 0;
	padding: 26px;
	position: absolute;
	right: 0;
	z-index: 3;
}

.ec-place-card__content small {
	align-items: center;
	color: rgba(255, 255, 255, 0.76);
	display: flex;
	font-size: 12px;
	font-weight: 900;
	gap: 7px;
	margin-bottom: 9px;
	text-transform: uppercase;
}

.ec-place-card__content h3 {
	color: #fff;
	font-size: clamp(25px, 2.2vw, 34px);
	font-weight: 900;
	line-height: 1;
	margin: 0 0 9px;
}

.ec-place-card__content p {
	color: rgba(255, 255, 255, 0.82);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
	margin: 0;
}

.ec-cta {
	background:
		linear-gradient(90deg, rgba(6, 18, 28, 0.92), rgba(6, 18, 28, 0.68)),
		url("/assets/images/cta/bg-05.webp") center / cover;
	color: #fff;
	position: relative;
}

.ec-cta__inner {
	align-items: center;
	display: grid;
	gap: 32px;
	grid-template-columns: minmax(0, 1fr) auto;
}

.ec-cta h2 {
	color: #fff;
}

.ec-cta p {
	color: rgba(255, 255, 255, 0.75);
	max-width: 680px;
}

.ec-partners {
	background: #fff;
	padding: 52px 0;
}

.ec-partners__track {
	align-items: center;
	display: flex;
	gap: 18px;
	justify-content: center;
}

.ec-partners__track a {
	align-items: center;
	background: #fff;
	border: 1px solid var(--ec-line);
	border-radius: 8px;
	display: flex;
	height: 92px;
	justify-content: center;
	padding: 22px 34px;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
	width: 220px;
}

.ec-partners__track a:hover {
	box-shadow: 0 16px 36px rgba(17, 24, 39, 0.1);
	transform: translateY(-3px);
}

.ec-partners__track img {
	max-height: 44px;
	max-width: 150px;
	object-fit: contain;
}

.ec-footer {
	background:
		linear-gradient(180deg, #08131b 0%, #050b10 100%);
	color: #fff;
	overflow: hidden;
	padding: 86px 0 28px;
	position: relative;
}

.ec-footer__glow {
	background: radial-gradient(circle, rgba(232, 93, 79, 0.26), rgba(232, 93, 79, 0) 60%);
	height: 360px;
	position: absolute;
	right: -110px;
	top: -160px;
	width: 360px;
}

.ec-footer__top {
	display: grid;
	gap: 70px;
	grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr);
	position: relative;
	z-index: 2;
}

.ec-footer__logo img {
	max-width: 170px;
}

.ec-footer__brand p {
	color: rgba(255, 255, 255, 0.68);
	margin-top: 24px;
	max-width: 480px;
}

.ec-footer__brand::after {
	color: #fff;
	content: "La ciudad no termina acá.";
	display: block;
	font-size: clamp(32px, 4.8vw, 66px);
	font-weight: 900;
	letter-spacing: 0;
	line-height: 0.96;
	margin-top: 34px;
	max-width: 560px;
}

.ec-footer__columns {
	display: grid;
	gap: 28px;
	grid-template-columns: repeat(3, 1fr);
}

.ec-footer__columns h3 {
	color: #fff;
	font-size: 15px;
	font-weight: 900;
	margin: 0 0 18px;
	text-transform: uppercase;
}

.ec-footer__columns a {
	color: rgba(255, 255, 255, 0.64);
	display: block;
	font-size: 15px;
	font-weight: 700;
	margin-bottom: 12px;
	transition: color 0.2s ease, transform 0.2s ease;
}

.ec-footer__columns a:hover,
.ec-footer__bottom a:hover {
	color: #fff;
	transform: translateX(3px);
}

.ec-footer__bottom {
	align-items: center;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	display: flex;
	justify-content: space-between;
	margin-top: 58px;
	padding-top: 24px;
	position: relative;
	z-index: 2;
}

.ec-footer__bottom p,
.ec-footer__bottom a {
	color: rgba(255, 255, 255, 0.58);
	font-size: 14px;
	margin: 0;
}

.ec-mobile-links {
	list-style: none;
	margin: 0;
	padding: 0;
}

.ec-mobile-links a {
	border-bottom: 1px solid rgba(17, 24, 39, 0.08);
	color: var(--ec-ink);
	display: block;
	font-size: 22px;
	font-weight: 900;
	padding: 14px 0;
}

.side-bar.header-eight .ec-mobile-links a:not(.ec-mobile-club) {
	border-bottom-color: rgba(255, 255, 255, 0.12);
	color: #fff;
}

.ec-mobile-links a.ec-mobile-club {
	align-items: center;
	background: linear-gradient(135deg, var(--ec-coral), #f19945);
	border: 0;
	border-radius: 16px;
	box-shadow: 0 18px 36px rgba(232, 93, 79, 0.24);
	color: #fff;
	display: flex;
	gap: 10px;
	justify-content: space-between;
	margin: 8px 0 12px;
	padding: 16px 18px;
}

.ec-reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

.ec-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

@keyframes ecFloat {
	0%,
	100% {
		transform: translate(-50%, 0);
	}

	50% {
		transform: translate(-50%, -7px);
	}
}

@media (max-width: 991px) {
	.side-bar,
	.side-bar.header-eight {
		background: #fffaf2 !important;
		box-shadow: -24px 0 80px rgba(16, 32, 44, 0.18);
		max-width: none;
		overflow-y: auto !important;
		padding: 28px 28px 42px;
		right: -100vw;
		width: 100vw;
	}

	.side-bar.show,
	.side-bar.active {
		right: 0;
	}

	.side-bar .logo {
		display: inline-flex;
		margin: 54px 0 34px;
		max-width: 230px;
	}

	.side-bar .logo img {
		display: block;
		height: auto;
		max-width: 100%;
	}

	.side-bar .close-icon-menu {
		align-items: center;
		background: #10202c !important;
		border: 0 !important;
		border-radius: 999px;
		color: #fff !important;
		display: inline-flex;
		height: 52px;
		justify-content: center;
		position: absolute;
		right: 22px;
		top: 22px;
		width: 52px;
		z-index: 2;
	}

	.side-bar .close-icon-menu i {
		color: #fff !important;
		font-size: 24px;
	}

	#side-bar .mobile-menu-main {
		display: block;
	}

	.mobile-menu-main nav ul,
	.ec-mobile-links {
		padding: 0 !important;
	}

	.side-bar.header-eight .ec-mobile-links a:not(.ec-mobile-club),
	.ec-mobile-links a {
		border-bottom: 1px solid rgba(17, 24, 39, 0.1);
		color: #10202c !important;
		font-size: clamp(28px, 8vw, 42px);
		line-height: 1.05;
		padding: 18px 0;
	}

	.ec-mobile-links a.ec-mobile-club {
		color: #fff !important;
		font-size: clamp(24px, 7vw, 34px);
		margin-top: 20px;
		padding: 18px 20px;
	}
}

@media (max-width: 1199px) {
	.ec-card-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 991px) {
	.ec-nav {
		border-radius: 8px;
		min-height: 64px;
	}

	.ec-nav .main-nav-area,
	.ec-nav-cta {
		display: none !important;
	}

	.ec-menu-toggle {
		display: inline-flex;
	}

	.ec-hero {
		min-height: auto;
		padding: 150px 0 82px;
	}

	.ec-hero .container,
	.ec-seo-intro .container,
	.ec-section-head--split,
	.ec-today__layout,
	.ec-cta__inner,
	.ec-footer__top {
		grid-template-columns: 1fr;
	}

	.ec-hero__panel {
		grid-template-columns: repeat(3, 1fr);
	}

	.ec-hero__panel div {
		border-bottom: 0;
		border-right: 1px solid rgba(255, 255, 255, 0.16);
	}

	.ec-hero__panel div:last-child {
		border-right: 0;
	}

	.ec-proof__grid,
	.ec-card-grid,
	.ec-card-grid--hotels,
	.ec-city-guides__grid,
	.ec-faq__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.ec-proof__item {
		border-bottom: 1px solid var(--ec-line);
	}

	.ec-mood__grid {
		grid-template-columns: 1fr;
	}

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

	.ec-mood-card,
	.ec-mood-card--large {
		aspect-ratio: 1.65 / 1;
	}
}

@media (max-width: 767px) {
	.ec-nav-shell {
		padding: 10px 10px 0;
	}

	.ec-nav {
		padding: 8px 8px 8px 16px;
	}

	.ec-nav .logo img {
		max-width: 112px;
	}

	.ec-hero {
		padding: 132px 0 66px;
	}

	.ec-hero h1 {
		font-size: clamp(40px, 12.8vw, 54px);
		line-height: 1.01;
		overflow-wrap: normal;
		word-break: normal;
	}

	.ec-search {
		border-radius: 8px;
		grid-template-columns: 22px minmax(0, 1fr);
		padding: 12px 12px 12px 18px;
	}

	.ec-search input {
		font-size: 14px;
	}

	.ec-search button {
		grid-column: 1 / -1;
		width: 100%;
	}

	.ec-hero__panel,
	.ec-proof__grid,
	.ec-card-grid,
	.ec-card-grid--hotels,
	.ec-city-guides__grid,
	.ec-faq__grid,
	.ec-footer__columns {
		grid-template-columns: 1fr;
	}

	.ec-hero__panel div {
		border-bottom: 1px solid rgba(255, 255, 255, 0.16);
		border-right: 0;
	}

	.ec-hero__panel div:last-child {
		border-bottom: 0;
	}

	.ec-proof {
		margin-top: 0;
	}

	.ec-proof__item {
		border-right: 0;
	}

	.ec-now,
	.ec-today,
	.ec-mood,
	.ec-city-guides,
	.ec-seo-intro,
	.ec-listing,
	.ec-faq,
	.ec-cta {
		padding: 62px 0;
	}

	.ec-now__rail {
		display: flex;
		gap: 14px;
		margin-left: -12px;
		margin-right: -12px;
		overflow-x: auto;
		padding: 2px 12px 18px;
		scroll-snap-type: x mandatory;
	}

	.ec-now-card,
	.ec-now-card--wide {
		aspect-ratio: 0.78 / 1;
		flex: 0 0 78vw;
		min-height: 360px;
		scroll-snap-align: start;
	}

	.ec-today__feature {
		min-height: 350px;
		padding: 26px;
	}

	.ec-today__grid {
		grid-template-columns: 1fr;
	}

	.ec-today__grid a {
		min-height: 150px;
	}

	.ec-section-head {
		text-align: left;
	}

	.ec-mood-card,
	.ec-mood-card--large,
	.ec-place-card,
	.ec-place-card--hotel {
		aspect-ratio: 1 / 1.08;
	}

	.ec-partners__track {
		flex-direction: column;
	}

	.ec-partners__track a {
		width: 100%;
	}

	.ec-footer__bottom {
		align-items: flex-start;
		flex-direction: column;
		gap: 8px;
	}
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	.ec-home *,
	.ec-home *::before,
	.ec-home *::after {
		animation-duration: 0.001ms !important;
		transition-duration: 0.001ms !important;
	}

	.ec-reveal {
		opacity: 1;
		transform: none;
	}
}
