:root {
  --background: oklch(0.14 0.03 300);
  --foreground: oklch(0.98 0.005 300);
  --card: oklch(0.18 0.04 300);
  --primary: oklch(0.75 0.24 340);
  --primary-foreground: oklch(0.14 0.03 300);
  --muted-foreground: oklch(0.72 0.03 310);
  --border: oklch(0.32 0.06 320 / 60%);
  --gradient-primary: linear-gradient(135deg, oklch(0.75 0.24 340), oklch(0.6 0.22 300));
  --gradient-hero: linear-gradient(180deg, oklch(0.14 0.03 300 / 0), oklch(0.14 0.03 300 / 0.85) 60%, oklch(0.14 0.03 300));
  --gradient-card: linear-gradient(160deg, oklch(0.22 0.06 320 / 0.7), oklch(0.16 0.04 300 / 0.7));
  --shadow-glow: 0 20px 60px -20px oklch(0.75 0.24 340 / 0.55);
  --shadow-card: 0 10px 40px -20px oklch(0 0 0 / 0.6);
}
* { box-sizing: border-box; border-color: var(--border); }
html, body { margin: 0; padding: 0; }
body {
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  background: var(--background);
  color: var(--foreground);
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
button { font: inherit; cursor: pointer; }

/* Animations */
@keyframes float-y { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }
@keyframes shimmer-x { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
@keyframes marquee-x { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes glow-pulse {
  0%,100%{ box-shadow:0 0 0 0 oklch(0.75 0.24 340 / 0.5); }
  50%{ box-shadow:0 0 40px 8px oklch(0.75 0.24 340 / 0.35); }
}
@keyframes fade-up { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
@keyframes zoom-slow { from{transform:scale(1.05)} to{transform:scale(1.15)} }
@keyframes sparkle { 0%,100%{opacity:.2;transform:scale(.8)} 50%{opacity:1;transform:scale(1.2)} }

.animate-float { animation: float-y 6s ease-in-out infinite; }
.animate-glow { animation: glow-pulse 2.8s ease-in-out infinite; }
.animate-marquee { animation: marquee-x 40s linear infinite; }
.animate-fade-up { animation: fade-up .9s ease-out both; }
.animate-zoom-slow { animation: zoom-slow 18s ease-in-out infinite alternate; }
.animate-sparkle { animation: sparkle 2.4s ease-in-out infinite; }

.shimmer-text {
  background: linear-gradient(90deg, oklch(0.75 0.24 340), oklch(0.98 0.1 320), oklch(0.75 0.24 340));
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: shimmer-x 4s linear infinite;
}
.hover-lift { transition: transform .4s cubic-bezier(.22,1,.36,1), box-shadow .4s; }
.hover-lift:hover { transform: translateY(-6px); }

/* Layout */
.container { max-width: 72rem; margin: 0 auto; padding: 0 1rem; }
@media (min-width: 640px) { .container { padding: 0 1.5rem; } }

/* Header */
.site-header {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(20px);
  background: color-mix(in oklch, var(--background) 70%, transparent);
  border-bottom: 1px solid var(--border);
}
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 0;
}
.brand { display: flex; align-items: center; gap: .5rem; font-weight: 900; letter-spacing: -.02em; font-size: 1.125rem; }
.brand svg { color: var(--primary); }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  border-radius: 9999px; padding: .625rem 1rem; font-weight: 700;
  font-size: .875rem; border: none;
}
.btn-primary { background: var(--gradient-primary); color: var(--primary-foreground); box-shadow: var(--shadow-glow); }
.btn-lg { padding: 1rem 1.75rem; font-size: 1rem; }
.btn-outline {
  background: color-mix(in oklch, var(--card) 60%, transparent);
  color: var(--foreground);
  border: 1px solid color-mix(in oklch, var(--primary) 40%, transparent);
  backdrop-filter: blur(8px);
}
.btn-outline:hover { border-color: var(--primary); background: var(--card); }

/* Hero */
.hero { position: relative; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .6; }
.hero-overlay-1 { position: absolute; inset: 0; background: var(--gradient-hero); }
.hero-overlay-2 { position: absolute; inset: 0; background: linear-gradient(to right, color-mix(in oklch, var(--background) 80%, transparent), color-mix(in oklch, var(--background) 30%, transparent), transparent); }
.blob { position: absolute; border-radius: 9999px; filter: blur(60px); background: var(--gradient-primary); pointer-events: none; }
.blob-1 { top: -5rem; left: -5rem; width: 18rem; height: 18rem; opacity: .4; }
.blob-2 { bottom: 2.5rem; right: -4rem; width: 20rem; height: 20rem; opacity: .3; animation-delay: -3s; }
.hero-inner { position: relative; padding: 3.5rem 0 6rem; }
@media (min-width: 640px) { .hero-inner { padding: 5rem 0 8rem; } }

.badge {
  display: inline-flex; align-items: center; gap: .5rem;
  border-radius: 9999px;
  border: 1px solid color-mix(in oklch, var(--primary) 50%, transparent);
  background: color-mix(in oklch, var(--primary) 10%, transparent);
  backdrop-filter: blur(8px);
  padding: .375rem .75rem;
  font-size: .6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--primary);
}
@media (min-width: 640px) { .badge { font-size: .75rem; } }

h1.hero-title {
  margin: 1.5rem 0 0; font-weight: 900; letter-spacing: -.02em;
  font-size: 2.5rem; line-height: 1; max-width: 56rem;
}
@media (min-width: 640px) { h1.hero-title { font-size: 3.75rem; } }
@media (min-width: 1024px) { h1.hero-title { font-size: 5.5rem; } }
h1.hero-title span { display: block; }

.hero-lead { margin: 1.5rem 0 0; max-width: 36rem; color: var(--muted-foreground); font-size: 1rem; }
@media (min-width: 640px) { .hero-lead { font-size: 1.125rem; } }
.text-primary { color: var(--primary); font-weight: 600; }

.hero-actions { margin-top: 2rem; display: flex; flex-direction: column; gap: .75rem; }
@media (min-width: 640px) { .hero-actions { flex-direction: row; } }

.stats { margin-top: 3rem; display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: .75rem; max-width: 48rem; }
@media (min-width: 640px) { .stats { grid-template-columns: repeat(4, minmax(0,1fr)); } }
.stat {
  position: relative; overflow: hidden;
  border-radius: 1rem;
  border: 1px solid color-mix(in oklch, var(--primary) 30%, transparent);
  background: color-mix(in oklch, var(--card) 60%, transparent);
  backdrop-filter: blur(8px);
  padding: 1rem;
}
.stat .stat-blob { position: absolute; top: -1.5rem; right: -1.5rem; width: 4rem; height: 4rem; border-radius: 9999px; filter: blur(30px); opacity: .4; background: var(--gradient-primary); }
.stat-k { font-size: 1.5rem; font-weight: 900; }
@media (min-width: 640px) { .stat-k { font-size: 1.875rem; } }
.stat-v { font-size: .75rem; font-weight: 700; margin-top: .25rem; }
@media (min-width: 640px) { .stat-v { font-size: .875rem; } }
.stat-sub { font-size: .625rem; text-transform: uppercase; letter-spacing: .1em; color: var(--muted-foreground); margin-top: .25rem; }
@media (min-width: 640px) { .stat-sub { font-size: .75rem; } }

/* Marquee */
.marquee-wrap {
  border-top: 1px solid color-mix(in oklch, var(--primary) 20%, transparent);
  border-bottom: 1px solid color-mix(in oklch, var(--primary) 20%, transparent);
  overflow: hidden; padding: 1.25rem 0;
  background: color-mix(in oklch, var(--card) 40%, transparent);
  position: relative;
}
.marquee-fade {
  position: absolute; inset: 0 auto 0 0; width: 6rem; z-index: 10;
  background: linear-gradient(to right, var(--background), transparent); pointer-events: none;
}
.marquee-fade-r { left: auto; right: 0; background: linear-gradient(to left, var(--background), transparent); }
.marquee { display: flex; white-space: nowrap; }
.marquee-inner { display: flex; align-items: center; gap: 1.5rem; padding-right: 1.5rem; font-size: 1.125rem; font-weight: 900; }
@media (min-width: 640px) { .marquee-inner { font-size: 1.5rem; } }

/* Sections */
section.pad { padding: 5rem 0; }
@media (min-width: 640px) { section.pad { padding: 7rem 0; } }
section.pad-b { padding: 0 0 5rem; }
@media (min-width: 640px) { section.pad-b { padding: 0 0 7rem; } }
section.pad-b-sm { padding: 0 0 4rem; }
@media (min-width: 640px) { section.pad-b-sm { padding: 0 0 6rem; } }

.eyebrow { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .15em; color: var(--primary); }
h2.section-title { margin: .75rem 0 0; font-size: 1.875rem; line-height: 1.05; font-weight: 900; letter-spacing: -.02em; }
@media (min-width: 640px) { h2.section-title { font-size: 3rem; } }
@media (min-width: 1024px) { h2.section-title { font-size: 3.75rem; } }
.section-lead { margin-top: 1rem; color: var(--muted-foreground); max-width: 36rem; }
.section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; margin-bottom: 2rem; }
.section-head .icon-lg { color: var(--primary); display: none; }
@media (min-width: 640px) { .section-head .icon-lg { display: block; } }

/* Grid utilities */
.grid { display: grid; gap: 1rem; }
.grid-2 { grid-template-columns: 1fr; }
.grid-3 { grid-template-columns: 1fr; }
.grid-4 { grid-template-columns: 1fr; }
@media (min-width: 640px) {
  .grid-2 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .grid-3 { grid-template-columns: repeat(3, 1fr); }
  .grid-4 { grid-template-columns: repeat(4, 1fr); }
  .grid-reviews { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1536px) {
  .grid-reviews { grid-template-columns: repeat(4, 1fr); }
}

/* Gallery cards */
.city-card {
  position: relative; overflow: hidden; border-radius: 1.5rem;
  border: 1px solid var(--border); box-shadow: var(--shadow-card);
}
.city-card img { aspect-ratio: 4/5; width: 100%; object-fit: cover; transition: transform 1s; }
.city-card:hover img { transform: scale(1.1); }
.city-card .fade { position: absolute; inset: 0; background: linear-gradient(to top, var(--background), color-mix(in oklch, var(--background) 60%, transparent), transparent); }
.city-card .pill {
  position: absolute; top: 1rem; right: 1rem;
  border-radius: 9999px;
  background: color-mix(in oklch, var(--background) 80%, transparent);
  backdrop-filter: blur(8px);
  border: 1px solid color-mix(in oklch, var(--primary) 40%, transparent);
  padding: .25rem .75rem; font-size: .625rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--primary);
}
.city-card .caption { position: absolute; inset: auto 0 0 0; padding: 1.5rem; }
.city-card .caption .city { display: inline-flex; align-items: center; gap: .375rem; color: var(--primary); font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .15em; }
.city-card .caption .tag { margin-top: .25rem; font-size: 1.25rem; font-weight: 900; }

/* Offer cards */
.offer-card {
  border-radius: 1.5rem; border: 1px solid var(--border); padding: 1.5rem;
  background: var(--gradient-card); box-shadow: var(--shadow-card);
  transition: border-color .3s, transform .4s;
}
@media (min-width: 640px) { .offer-card { padding: 1.75rem; } }
.offer-card:hover { border-color: color-mix(in oklch, var(--primary) 70%, transparent); transform: translateY(-6px); }
.icon-tile {
  display: inline-flex; align-items: center; justify-content: center;
  width: 3.5rem; height: 3.5rem; border-radius: 1rem;
  background: var(--gradient-primary); color: var(--primary-foreground);
  transition: transform .3s;
}
.offer-card:hover .icon-tile { transform: scale(1.1) rotate(-6deg); }
.offer-card h3 { margin: 1.25rem 0 0; font-size: 1.25rem; font-weight: 900; }
.offer-card p { margin: .5rem 0 0; font-size: .875rem; color: var(--muted-foreground); line-height: 1.6; }

/* Panel */
.panel {
  position: relative; overflow: hidden; border-radius: 1.5rem;
  border: 1px solid color-mix(in oklch, var(--primary) 30%, transparent);
  padding: 1.5rem; background: var(--gradient-card); box-shadow: var(--shadow-card);
}
@media (min-width: 640px) { .panel { padding: 2.5rem; } }
@media (min-width: 1024px) { .panel { padding: 3.5rem; } }
.panel .blob-tr { position: absolute; top: -8rem; right: -8rem; width: 24rem; height: 24rem; border-radius: 9999px; filter: blur(80px); opacity: .3; background: var(--gradient-primary); }
.panel .blob-bl { position: absolute; bottom: -6rem; left: -6rem; width: 18rem; height: 18rem; border-radius: 9999px; filter: blur(80px); opacity: .3; background: var(--gradient-primary); }

.why-grid { display: grid; gap: 2.5rem; }
@media (min-width: 1024px) { .why-grid { grid-template-columns: 1fr 1fr; gap: 4rem; } }
.benefits-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .75rem; }
.benefits-list li {
  display: flex; align-items: center; gap: .75rem;
  border-radius: 1rem; border: 1px solid var(--border);
  background: color-mix(in oklch, var(--background) 50%, transparent);
  padding: .875rem 1rem;
  transition: border-color .3s;
}
@media (min-width: 640px) { .benefits-list li { padding: .875rem 1.25rem; } }
.benefits-list li:hover { border-color: color-mix(in oklch, var(--primary) 60%, transparent); }
.benefits-list .badge-icon {
  display: grid; place-items: center; width: 2rem; height: 2rem; border-radius: .5rem;
  background: var(--gradient-primary); color: var(--primary-foreground); flex-shrink: 0;
}
.benefits-list .txt { font-size: .875rem; font-weight: 600; }
@media (min-width: 640px) { .benefits-list .txt { font-size: 1rem; } }
.benefits-list .check { margin-left: auto; color: var(--primary); flex-shrink: 0; }

/* Steps */
.step-card {
  position: relative; overflow: hidden; border-radius: 1.5rem;
  border: 1px solid var(--border); padding: 1.5rem;
  background: var(--gradient-card); box-shadow: var(--shadow-card);
}
@media (min-width: 640px) { .step-card { padding: 1.75rem; } }
.step-card .num-bg { position: absolute; top: -1rem; right: -1rem; font-size: 4.5rem; font-weight: 900; color: color-mix(in oklch, var(--primary) 10%, transparent); user-select: none; }
.step-card .num {
  display: grid; place-items: center; width: 3rem; height: 3rem; border-radius: 1rem;
  background: var(--gradient-primary); color: var(--primary-foreground);
  font-size: .875rem; font-weight: 900; position: relative;
}
.step-card h3 { margin: 1.25rem 0 0; font-size: 1.25rem; font-weight: 900; }
.step-card p { margin: .5rem 0 0; font-size: .875rem; color: var(--muted-foreground); line-height: 1.6; }

/* Cities pills */
.cities { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 2rem; }
@media (min-width: 640px) { .cities { gap: .75rem; } }
.city-pill {
  display: inline-flex; align-items: center; gap: .375rem;
  border-radius: 9999px;
  border: 1px solid color-mix(in oklch, var(--primary) 30%, transparent);
  background: color-mix(in oklch, var(--primary) 5%, transparent);
  padding: .5rem 1rem; font-size: .875rem; font-weight: 600;
  transition: background .3s, border-color .3s, transform .3s;
}
.city-pill:hover { background: color-mix(in oklch, var(--primary) 20%, transparent); border-color: var(--primary); transform: scale(1.05); }
.city-pill svg { color: var(--primary); }

/* Reviews */
.review-card {
  position: relative; overflow: hidden; border-radius: 1.5rem;
  border: 1px solid var(--border); background: var(--gradient-card); box-shadow: var(--shadow-card);
}
.review-card .inner { padding: .75rem; }
.review-card img { aspect-ratio: 9/16; width: 100%; object-fit: cover; border-radius: 1rem; transition: transform .7s; }
.review-card:hover img { transform: scale(1.05); }

/* CTA */
.cta {
  position: relative; overflow: hidden; border-radius: 1.5rem;
  border: 1px solid color-mix(in oklch, var(--primary) 40%, transparent);
  padding: 2rem; text-align: center;
  background: var(--gradient-card); box-shadow: var(--shadow-glow);
}
@media (min-width: 640px) { .cta { padding: 3.5rem; } }
.cta h2 { margin: 1.25rem auto 0; font-size: 1.875rem; font-weight: 900; line-height: 1.05; max-width: 48rem; letter-spacing: -.02em; }
@media (min-width: 640px) { .cta h2 { font-size: 3rem; } }
@media (min-width: 1024px) { .cta h2 { font-size: 3.75rem; } }
.cta p { margin: 1.25rem auto 0; color: var(--muted-foreground); max-width: 36rem; font-size: 1rem; }
@media (min-width: 640px) { .cta p { font-size: 1.125rem; } }
.cta-actions { margin-top: 2rem; display: flex; flex-direction: column; gap: .75rem; justify-content: center; }
@media (min-width: 640px) { .cta-actions { flex-direction: row; } }
.cta .fine { margin-top: 1.5rem; font-size: .75rem; color: var(--muted-foreground); }
.cta-blob-1 { position: absolute; top: -6rem; left: 50%; width: 16rem; height: 16rem; transform: translateX(-50%); border-radius: 9999px; filter: blur(80px); opacity: .5; background: var(--gradient-primary); animation: float-y 6s ease-in-out infinite; }
.cta-blob-2 { position: absolute; bottom: -6rem; right: 2.5rem; width: 16rem; height: 16rem; border-radius: 9999px; filter: blur(80px); opacity: .3; background: var(--gradient-primary); animation: float-y 6s ease-in-out infinite; animation-delay: -2s; }

/* Footer */
footer { border-top: 1px solid var(--border); }
footer .row { display: flex; flex-direction: column; align-items: center; justify-content: space-between; gap: .75rem; padding: 2rem 0; font-size: .75rem; color: var(--muted-foreground); }
@media (min-width: 640px) { footer .row { flex-direction: row; } }
footer .brand-mini { display: flex; align-items: center; gap: .5rem; color: var(--foreground); font-weight: 700; }
footer .brand-mini svg { color: var(--primary); }

/* Icons */
.icon { width: 1rem; height: 1rem; }
.icon-sm { width: .875rem; height: .875rem; }
.icon-md { width: 1.25rem; height: 1.25rem; }
.icon-lg { width: 2rem; height: 2rem; }
