/* ═══════════════════════════════════════════════════════════════════
   hampiAutoRides.com — Rocky's Premium Auto Rides
   Design System · "Imperial Void"
   Near-Black Void · Amber Saffron · Antique Gold · Warm Pearl
   Fonts: Cormorant Garamond (display) · DM Sans (body)
   ═══════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

/* ── DESIGN TOKENS ── */
:root {
  /* VOID BACKGROUNDS — near-black with deep indigo resonance */
  --void:    #03040C;
  --deep:    #070919;
  --surface: #0C0E26;
  --raised:  #12152E;
  --glass-nav: rgba(3,4,12,.94);
  --glass-card: rgba(12,14,38,.82);

  /* PRIMARY — Vivid Amber-Saffron · fire of temple lamps */
  --amber:     #E07012;
  --amber-dk:  #C05E08;
  --amber-lt:  #F09030;
  --amber-glow: rgba(224,112,18,.50);
  --amber-dim:  rgba(224,112,18,.14);

  /* GOLD — Antique temple gold · 24k heritage */
  --gold:      #C8A022;
  --gold-lt:   #EEC038;
  --gold-pale: #F8D860;
  --gold-dim:  rgba(200,160,34,.20);
  --gold-faint:rgba(200,160,34,.10);

  /* LIGHT SURFACES — pearl, ivory, warm stone */
  --pearl:  #F6F3EE;
  --ivory:  #EDE7DC;
  --stone:  #D6CEBC;
  --sand:   #C8BEA8;

  /* INK */
  --ink:      #14122A;
  --ink-body: #2A2644;
  --ink-muted:#6A6290;
  --ink-w:    rgba(255,255,255,.93);
  --ink-dim:  rgba(255,255,255,.56);
  --ink-faint:rgba(255,255,255,.28);

  /* SHADOWS */
  --sh-0: 0 1px 4px rgba(3,4,12,.10);
  --sh-1: 0 2px 14px rgba(3,4,12,.12), 0 1px 4px rgba(3,4,12,.08);
  --sh-2: 0 8px 36px rgba(3,4,12,.16), 0 2px 10px rgba(3,4,12,.10);
  --sh-3: 0 24px 72px rgba(3,4,12,.24), 0 6px 24px rgba(3,4,12,.14);
  --sh-amber: 0 6px 32px rgba(224,112,18,.52);
  --sh-gold:  0 4px 24px rgba(200,160,34,.38);
  --sh-card:  0 8px 40px rgba(3,4,12,.40), 0 2px 10px rgba(3,4,12,.25);

  /* BORDERS */
  --b-lt:   1px solid rgba(224,112,18,.14);
  --b-md:   1px solid rgba(224,112,18,.28);
  --b-gold: 1px solid rgba(200,160,34,.28);
  --b-surf: 1px solid rgba(255,255,255,.07);
  --b-pearl:1px solid rgba(20,18,42,.10);

  /* RADII */
  --r:   22px;
  --r-sm:14px;
  --r-xs:9px;
  --pill:999px;

  /* EASINGS */
  --spring: cubic-bezier(.34,1.56,.64,1);
  --smooth: cubic-bezier(.22,.68,0,1.2);
  --silk:   cubic-bezier(.4,0,.2,1);
}

/* ── RESET & BASE ── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; font-size:16px; }
img  { max-width:100%; display:block; }
a    { color:inherit; text-decoration:none; }
body {
  font-family:'DM Sans', system-ui, sans-serif;
  background:var(--pearl);
  color:var(--ink-body);
  line-height:1.7;
  padding-bottom:100px;
}

/* ── NAVIGATION ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:var(--glass-nav);
  backdrop-filter:blur(24px) saturate(1.8);
  -webkit-backdrop-filter:blur(24px) saturate(1.8);
  border-bottom:1px solid rgba(224,112,18,.18);
  box-shadow:0 1px 0 rgba(224,112,18,.08), 0 4px 28px rgba(3,4,12,.35);
}
.nav-inner { display:flex; align-items:center; justify-content:space-between; padding:13px 20px; }
.nav-brand {
  font-family:'Cormorant Garamond', serif;
  font-size:20px; font-weight:600; letter-spacing:-.2px;
  color:#fff; line-height:1.1;
}
.nav-brand em { font-style:italic; color:var(--amber-lt); }
.nav-brand span { display:block; font-size:9px; font-weight:400; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); margin-top:1px; font-family:'DM Sans',sans-serif; }
.nav-toggle { background:none; border:1px solid rgba(255,255,255,.14); border-radius:8px; cursor:pointer; padding:8px 10px; display:flex; flex-direction:column; gap:4.5px; }
.nav-toggle span { display:block; width:20px; height:1.6px; background:rgba(255,255,255,.75); border-radius:2px; transition:all .3s; }
.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0; transform:scaleX(0);}
.nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}
.nav-links { max-height:0; overflow:hidden; transition:max-height .38s var(--silk), padding .3s; display:flex; flex-direction:column; gap:4px; padding:0 16px; }
.nav-links.open { max-height:360px; padding:8px 16px 18px; }
.nav-link {
  padding:10px 18px; color:var(--ink-dim); text-decoration:none;
  border-radius:var(--r-xs); font-size:13.5px; font-weight:500; text-align:center;
  transition:background .2s, color .2s;
}
.nav-link:hover { background:rgba(255,255,255,.07); color:#fff; }
.nav-link.active { background:var(--amber); color:#fff; font-weight:600; }
.nav-link.cta { background:var(--amber); color:#fff; font-weight:600; box-shadow:var(--sh-amber); }

/* ── HERO ── */
.hero {
  background:var(--void);
  min-height:100svh;
  padding:100px 22px 50px;
  display:flex; flex-direction:column; justify-content:center;
  position:relative; overflow:hidden;
}
.hero::before {
  content:''; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 90% 60% at 100% -5%, rgba(224,112,18,.15) 0%, transparent 55%),
    radial-gradient(ellipse 70% 50% at 0% 100%, rgba(200,160,34,.08) 0%, transparent 55%);
}
.hero::after { display:none; }
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:10px; position:relative; z-index:1;
  font-family:'DM Sans',sans-serif; font-size:9px; font-weight:600;
  letter-spacing:3px; text-transform:uppercase; color:var(--gold);
  padding:5px 18px; border:1px solid rgba(200,160,34,.28); border-radius:var(--pill);
  background:rgba(200,160,34,.07); margin-bottom:26px; align-self:flex-start;
  animation:fadeUp .5s .1s ease both;
}
.hero-display {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(48px,11vw,90px);
  font-weight:600; line-height:0.95; letter-spacing:-.8px;
  color:#fff; position:relative; z-index:1;
  margin-bottom:20px; animation:fadeUp .6s .2s ease both;
}
.hero-display em { font-style:italic; font-weight:300; color:var(--gold-lt); display:block; }
.hero-display strong { color:var(--amber-lt); font-weight:700; }
.hero-rule {
  width:80px; height:1px; position:relative; z-index:1;
  background:linear-gradient(90deg, var(--amber), var(--gold), transparent);
  margin:20px 0; animation:fadeUp .5s .32s ease both;
}
.hero-sub {
  font-size:15px; color:var(--ink-dim); max-width:420px; line-height:1.76;
  position:relative; z-index:1; margin-bottom:8px;
  animation:fadeUp .5s .38s ease both; font-weight:300;
}
.hero-tagline {
  font-size:12px; color:var(--gold); font-weight:500; letter-spacing:.4px;
  position:relative; z-index:1; margin-bottom:32px;
  animation:fadeUp .5s .44s ease both;
}
.hero-ctas {
  display:flex; gap:12px; flex-wrap:wrap; position:relative; z-index:1;
  animation:fadeUp .5s .50s ease both;
}

/* ── BUTTONS ── */
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--amber); color:#fff;
  padding:15px 34px; border-radius:var(--pill);
  font-family:'DM Sans',sans-serif; font-size:14.5px; font-weight:600;
  box-shadow:var(--sh-amber); letter-spacing:.2px;
  transition:transform .24s var(--spring), box-shadow .24s;
}
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 14px 44px var(--amber-glow); }
.btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.07); border:1.5px solid rgba(255,255,255,.20);
  color:rgba(255,255,255,.88); padding:14px 28px; border-radius:var(--pill);
  font-family:'DM Sans',sans-serif; font-size:14px; font-weight:500;
  transition:background .22s, border-color .22s;
}
.btn-ghost:hover { background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.40); }
.btn-amber-outline {
  display:inline-flex; align-items:center; gap:7px;
  background:transparent; border:1.5px solid var(--amber);
  color:var(--amber); padding:12px 26px; border-radius:var(--pill);
  font-family:'DM Sans',sans-serif; font-size:13.5px; font-weight:600;
  transition:background .22s, color .22s;
}
.btn-amber-outline:hover { background:var(--amber); color:#fff; }

/* ── ORNAMENTAL DIVIDER ── */
.ornament {
  display:flex; align-items:center; justify-content:center;
  gap:14px; padding:14px 0; max-width:320px; margin:0 auto;
}
.ornament::before, .ornament::after {
  content:''; flex:1; height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-dim), transparent);
}
.ornament-symbol {
  font-size:14px; color:var(--gold); letter-spacing:4px; opacity:.8;
}

/* ── STATS BAND ── */
.stats-band {
  background:#fff; border-bottom:1px solid var(--stone);
  box-shadow:var(--sh-1); display:grid; grid-template-columns:repeat(4,1fr);
}
.stat-cell { padding:22px 8px; text-align:center; border-right:1px solid var(--stone); }
.stat-cell:last-child { border-right:none; }
.stat-val {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(28px,5.5vw,42px); font-weight:700; color:var(--amber);
  line-height:1; letter-spacing:-.5px;
}
.stat-lbl { font-size:9px; color:var(--ink-muted); font-weight:600; text-transform:uppercase; letter-spacing:1.2px; margin-top:5px; }

/* ── SECTION HEADERS ── */
.sec-wrap { padding:56px 20px 24px; text-align:center; max-width:900px; margin:0 auto; }
.sec-label {
  display:inline-block; font-size:9px; font-weight:700; letter-spacing:3px;
  text-transform:uppercase; color:var(--amber); margin-bottom:14px;
  padding:4px 14px; border:1px solid rgba(224,112,18,.24); border-radius:var(--pill);
  background:var(--amber-dim);
}
.sec-head {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(30px,6.5vw,52px); font-weight:600; color:var(--ink);
  line-height:1.1; letter-spacing:-.4px; margin-bottom:12px;
}
.sec-head em { font-style:italic; font-weight:300; color:var(--amber); }
.sec-sub { font-size:14.5px; color:var(--ink-muted); max-width:460px; margin:0 auto; line-height:1.72; font-weight:300; }

.sec-wrap.dark .sec-head { color:#fff; }
.sec-wrap.dark .sec-sub  { color:var(--ink-dim); }

/* ── RIDE CARDS (Tour Packages) ── */
.rides-grid {
  display:grid; grid-template-columns:1fr; gap:20px;
  padding:0 16px 10px; max-width:980px; margin:0 auto;
  background:var(--pearl);
}
.ride-card {
  background:var(--void); border-radius:var(--r); overflow:hidden;
  border:var(--b-surf); box-shadow:var(--sh-card);
  display:flex; flex-direction:column;
  transition:transform .3s var(--spring), box-shadow .28s;
}
.ride-card:hover { transform:translateY(-6px); box-shadow:0 28px 80px rgba(3,4,12,.45), 0 0 0 1px rgba(224,112,18,.25); }
.ride-card-img {
  position:relative; height:200px; overflow:hidden;
  background:var(--deep);
}
.ride-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--silk); filter:brightness(.92) saturate(1.05); }
.ride-card:hover .ride-card-img img { transform:scale(1.06); }
.ride-card-img-overlay { position:absolute; inset:0; background:linear-gradient(180deg,rgba(3,4,12,.0) 40%,rgba(3,4,12,.82) 100%); }
.ride-badge {
  position:absolute; top:14px; left:14px;
  font-size:9px; font-weight:700; letter-spacing:1.4px; text-transform:uppercase;
  background:var(--amber); color:#fff;
  padding:4px 12px; border-radius:var(--pill); box-shadow:0 2px 10px var(--amber-glow);
}
.ride-duration {
  position:absolute; bottom:13px; right:13px;
  font-size:11px; font-weight:600; color:#fff;
  background:rgba(3,4,12,.60); backdrop-filter:blur(8px);
  padding:4px 11px; border-radius:var(--pill); border:1px solid rgba(255,255,255,.14);
}
.ride-body { padding:22px 22px 10px; flex:1; background:var(--void); }
.ride-title {
  font-family:'Cormorant Garamond', serif;
  font-size:24px; font-weight:600; color:#FFFFFF; margin-bottom:5px; line-height:1.15;
}
.ride-sub { font-size:11.5px; color:#F5A840; font-weight:700; letter-spacing:.3px; margin-bottom:12px; text-transform:uppercase; }
.ride-desc { font-size:13.5px; color:rgba(255,255,255,.88); line-height:1.76; margin-bottom:14px; font-weight:300; }
.ride-stops { list-style:none; margin:0 0 16px; display:flex; flex-direction:column; gap:6px; }
.ride-stops li {
  display:flex; align-items:flex-start; gap:10px;
  font-size:13px; color:#FFFFFF;
  padding:8px 12px; border-radius:var(--r-xs);
  background:rgba(255,255,255,.09); border-left:2px solid var(--amber);
  line-height:1.5;
}
.ride-chips { display:flex; flex-wrap:wrap; gap:6px; padding:0 0 16px; }
.ride-chip {
  font-size:10px; font-weight:600; color:var(--gold); letter-spacing:.2px;
  background:var(--gold-faint); border:1px solid var(--gold-dim);
  padding:3px 10px; border-radius:var(--pill);
}
.ride-cta {
  display:block; text-align:center; padding:14px;
  background:linear-gradient(135deg, var(--amber), var(--amber-lt));
  color:#fff; font-weight:700; font-size:14px;
  border-radius:0 0 var(--r) var(--r);
  transition:opacity .2s, box-shadow .2s; letter-spacing:.2px;
}
.ride-cta:hover { opacity:.92; box-shadow:0 -4px 20px var(--amber-glow); }

/* ── EXPERIENCE STRIP ── */
.exp-strip { background:var(--void); padding:70px 0 60px; position:relative; overflow:hidden; }
.exp-strip::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 0%, rgba(224,112,18,.08) 0%, transparent 60%);
  pointer-events:none;
}
.exp-strip-inner { padding:0 20px; max-width:980px; margin:0 auto; }
.exp-pillars { display:grid; grid-template-columns:1fr; gap:16px; margin-top:40px; }
.exp-pillar {
  padding:26px 24px; border-radius:var(--r); position:relative; overflow:hidden;
  background:var(--surface); border:var(--b-surf);
  box-shadow:var(--sh-card);
  transition:transform .28s var(--spring), box-shadow .25s;
}
.exp-pillar:hover { transform:translateY(-5px); box-shadow:var(--sh-3), 0 0 0 1px rgba(224,112,18,.22); }
.exp-pillar::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--amber), var(--gold-lt), transparent);
}
.exp-icon { font-size:32px; margin-bottom:14px; }
.exp-title { font-family:'Cormorant Garamond', serif; font-size:22px; color:#fff; font-weight:600; margin-bottom:8px; line-height:1.15; }
.exp-desc { font-size:13.5px; color:var(--ink-dim); line-height:1.76; font-weight:300; }

/* ── GALLERY PREVIEW ── */
.gp-section { background:var(--void); padding:0 16px 10px; }
.gp-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; max-width:980px; margin:0 auto; }
.gp-card {
  border-radius:var(--r-sm); overflow:hidden; position:relative; cursor:pointer;
  background:var(--surface); aspect-ratio:1;
  box-shadow:var(--sh-card); border:var(--b-surf);
  transition:transform .3s var(--spring);
}
.gp-card:hover { transform:scale(1.025); }
.gp-card img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--silk), filter .4s; }
.gp-card:hover img { transform:scale(1.08); filter:brightness(1.06) saturate(1.1); }
.gp-card-overlay {
  position:absolute; inset:0;
  background:linear-gradient(transparent 45%, rgba(3,4,12,.88) 100%);
  opacity:0; transition:opacity .3s;
}
.gp-card:hover .gp-card-overlay { opacity:1; }
.gp-card-label {
  position:absolute; bottom:12px; left:12px;
  font-family:'Cormorant Garamond', serif; font-size:13px; font-weight:600; color:#fff;
  opacity:0; transform:translateY(5px); transition:opacity .3s, transform .3s;
}
.gp-card:hover .gp-card-label { opacity:1; transform:translateY(0); }
.gp-card.wide { grid-column:span 2; aspect-ratio:16/7; }
.gp-see-all {
  display:block; text-align:center; margin:18px auto 6px;
  padding:13px 36px; background:transparent;
  border:1.5px solid rgba(224,112,18,.40); color:var(--amber);
  border-radius:var(--pill); font-weight:600; font-size:13.5px;
  max-width:240px; transition:background .22s, color .22s;
}
.gp-see-all:hover { background:var(--amber); color:#fff; }

/* ── PROFILE CARD ── */
.profile-section { padding:0 16px; max-width:980px; margin:0 auto; }
.profile-card {
  background:var(--raised); border-radius:var(--r); padding:30px 24px;
  border:var(--b-surf); box-shadow:var(--sh-card); position:relative; overflow:hidden;
}
.profile-card::before {
  content:''; position:absolute; top:-80px; right:-80px;
  width:280px; height:280px;
  background:radial-gradient(circle, rgba(224,112,18,.10) 0%, transparent 70%);
  pointer-events:none;
}
.profile-card::after {
  content:''; position:absolute; bottom:-60px; left:-60px;
  width:220px; height:220px;
  background:radial-gradient(circle, rgba(200,160,34,.07) 0%, transparent 70%);
  pointer-events:none;
}
.profile-avatar {
  width:88px; height:88px; border-radius:50%; object-fit:cover;
  border:2px solid var(--gold); box-shadow:0 0 0 5px rgba(200,160,34,.14), var(--sh-gold);
  flex-shrink:0; position:relative; z-index:1;
}
.profile-name {
  font-family:'Cormorant Garamond', serif; font-size:28px; font-weight:700;
  color:#fff; letter-spacing:-.2px; position:relative; z-index:1;
}
.profile-role {
  font-size:9.5px; font-weight:700; color:var(--amber-lt); letter-spacing:2px;
  text-transform:uppercase; margin:4px 0 12px; position:relative; z-index:1;
}
.profile-bio {
  font-size:14px; color:var(--ink-dim); line-height:1.78; margin-bottom:16px;
  font-weight:300; position:relative; z-index:1;
}
.profile-pills { display:flex; flex-wrap:wrap; gap:7px; position:relative; z-index:1; }
.profile-pill {
  font-size:10.5px; font-weight:500; color:var(--gold-lt);
  background:rgba(200,160,34,.10); border:1px solid rgba(200,160,34,.22);
  border-radius:var(--pill); padding:4px 13px;
}

/* ── MANIFESTO STRIP ── */
.manifesto {
  background:var(--deep); padding:56px 20px; text-align:center;
  position:relative; overflow:hidden;
}
.manifesto::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 50% at 50% 50%, rgba(224,112,18,.07) 0%, transparent 70%);
}
.manifesto-quote {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(22px,5.5vw,42px); font-style:italic; font-weight:300;
  color:rgba(255,255,255,.88); line-height:1.45; max-width:720px;
  margin:0 auto; position:relative; z-index:1; letter-spacing:-.2px;
}
.manifesto-quote em { color:var(--gold-lt); font-style:italic; }
.manifesto-attr {
  font-size:11px; color:var(--ink-faint); margin-top:18px;
  letter-spacing:2px; text-transform:uppercase; font-weight:600; position:relative; z-index:1;
}

/* ── CITIES ── */
.cities-section { background:var(--pearl); padding:0 16px 10px; }
.cities-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; max-width:980px; margin:0 auto; }
.city-card {
  background:#fff; border-radius:var(--r-sm); padding:18px 16px;
  border:var(--b-pearl); box-shadow:var(--sh-1);
  text-decoration:none; display:flex; flex-direction:column;
  transition:transform .28s var(--spring), box-shadow .25s, border-color .25s;
}
.city-card:hover { transform:translateY(-4px); box-shadow:var(--sh-2); border-color:rgba(224,112,18,.28); }
.city-icon { font-size:22px; margin-bottom:8px; }
.city-name { font-family:'Cormorant Garamond', serif; font-size:18px; font-weight:600; color:var(--ink); margin-bottom:3px; }
.city-dist { font-size:10.5px; color:var(--amber); font-weight:700; letter-spacing:.3px; margin-bottom:6px; }
.city-desc { font-size:12px; color:var(--ink-muted); line-height:1.6; margin-bottom:12px; flex:1; }
.city-link { font-size:11.5px; font-weight:700; color:var(--amber); letter-spacing:.2px; }
.city-card.span2 { grid-column:span 2; flex-direction:row; align-items:center; gap:16px; }
.city-card.span2 .city-icon { font-size:28px; flex-shrink:0; margin-bottom:0; }

/* ── TESTIMONIALS ── */
.testi-section { padding:0 16px; max-width:980px; margin:0 auto; }
.testi-grid { display:flex; flex-direction:column; gap:14px; }
.rating-card {
  background:#fff; border:var(--b-pearl); border-radius:var(--r);
  padding:26px 22px; text-align:center; box-shadow:var(--sh-1); cursor:pointer;
  transition:transform .26s var(--spring), box-shadow .25s;
}
.rating-card:hover { transform:translateY(-4px); box-shadow:var(--sh-2); }
.rating-stars { font-size:20px; letter-spacing:2px; color:var(--amber); }
.rating-num {
  font-family:'Cormorant Garamond', serif; font-size:38px; font-weight:700;
  color:var(--ink); margin-top:8px; letter-spacing:-1px; line-height:1;
}
.rating-lbl { font-size:13px; color:var(--ink-muted); margin-top:4px; }
.rating-action { display:block; color:#4285F4; font-weight:500; font-size:12.5px; margin-top:14px; }
.testi-card {
  background:#fff; border:var(--b-pearl); border-radius:var(--r);
  padding:22px 22px 20px; box-shadow:var(--sh-1); position:relative; overflow:hidden;
}
.testi-card::before {
  content:'\201C'; font-family:'Cormorant Garamond', serif; font-size:80px; line-height:1;
  color:var(--amber); opacity:.10; position:absolute; top:2px; left:10px;
}
.testi-text {
  font-size:14px; color:var(--ink-body); line-height:1.78;
  font-style:italic; margin-bottom:16px; padding-top:12px;
  position:relative; z-index:1; font-weight:300;
  font-family:'Cormorant Garamond', serif;
}
.testi-author { display:flex; align-items:center; gap:10px; }
.testi-av {
  width:38px; height:38px; border-radius:50%;
  background:linear-gradient(135deg, var(--void), var(--amber));
  display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0;
}
.testi-name { font-size:13.5px; font-weight:600; color:var(--ink); }
.testi-from { font-size:11px; color:var(--ink-muted); }
.testi-stars { font-size:11px; color:var(--amber-lt); margin-left:auto; }

/* ── BOOK CTA BLOCK ── */
.cta-block {
  background:var(--void); padding:64px 20px; text-align:center;
  position:relative; overflow:hidden;
}
.cta-block::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 70% at 50% 100%, rgba(224,112,18,.14) 0%, transparent 60%);
  pointer-events:none;
}
.cta-block-eyebrow { font-size:9px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:18px; position:relative; z-index:1; }
.cta-block-head {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(30px,7vw,56px); font-weight:600; color:#fff;
  line-height:1.1; letter-spacing:-.4px; margin-bottom:14px; position:relative; z-index:1;
}
.cta-block-head em { font-style:italic; color:var(--gold-lt); }
.cta-block-sub { font-size:14px; color:var(--ink-dim); margin-bottom:32px; font-weight:300; position:relative; z-index:1; max-width:380px; margin-left:auto; margin-right:auto; line-height:1.72; }
.cta-block-btns { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; position:relative; z-index:1; }

/* ── SITE FOOTER ── */
.site-footer { background:var(--deep); padding:50px 20px 20px; border-top:1px solid rgba(224,112,18,.14); }
.footer-grid { display:grid; grid-template-columns:1fr; gap:36px; max-width:980px; margin:0 auto; }
.footer-brand-col { }
.footer-logo {
  font-family:'Cormorant Garamond', serif; font-size:22px; font-weight:600;
  color:#fff; margin-bottom:6px; line-height:1.1;
}
.footer-logo em { font-style:italic; color:var(--amber-lt); }
.footer-tagline { font-size:12.5px; color:var(--ink-faint); line-height:1.6; margin-bottom:16px; font-weight:300; max-width:260px; }
.footer-social { display:flex; gap:12px; }
.footer-social a img { width:32px; height:32px; transition:transform .22s var(--spring), filter .2s; }
.footer-social a:hover img { transform:scale(1.18) translateY(-3px); filter:drop-shadow(0 3px 8px rgba(224,112,18,.50)); }
.footer-col-title { font-size:9.5px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--amber); margin-bottom:14px; }
.footer-links { display:flex; flex-direction:column; gap:8px; }
.footer-link { font-size:13.5px; color:var(--ink-faint); transition:color .2s; line-height:1.4; }
.footer-link:hover { color:var(--ink-dim); }
.footer-contact-item { font-size:13px; color:var(--ink-faint); line-height:1.6; margin-bottom:6px; }
.footer-contact-item a { color:var(--amber-lt); }
.footer-divider { height:1px; background:rgba(255,255,255,.06); margin:28px 0; max-width:980px; margin-left:auto; margin-right:auto; }
.footer-bottom { max-width:980px; margin:0 auto; display:flex; flex-wrap:wrap; gap:8px; justify-content:center; align-items:center; font-size:11.5px; color:rgba(255,255,255,.28); text-align:center; }
.footer-bottom a { color:var(--gold); font-weight:600; }

/* ── FLOATING DOCK ── */
.dock {
  position:fixed; bottom:16px; left:50%; transform:translateX(-50%);
  background:rgba(3,4,12,.90);
  backdrop-filter:blur(24px) saturate(1.6);
  -webkit-backdrop-filter:blur(24px) saturate(1.6);
  border:1px solid rgba(224,112,18,.20);
  border-radius:var(--pill); padding:10px 22px;
  display:flex; align-items:center; justify-content:center; gap:16px;
  z-index:1000; min-width:280px;
  box-shadow:0 8px 40px rgba(3,4,12,.55), 0 2px 8px rgba(3,4,12,.30), inset 0 1px 0 rgba(255,255,255,.06);
  animation:dockUp .55s .2s var(--spring) both;
}
.dock a img { width:32px; height:32px; transition:transform .22s var(--spring), filter .2s; filter:none; }
.dock a:hover img { transform:scale(1.28) translateY(-5px); filter:drop-shadow(0 3px 8px rgba(255,255,255,.28)); }
.dock a[href*="wa.me"] img { animation:waPulse 3.2s ease-in-out infinite; }
@keyframes waPulse { 0%,90%,100%{box-shadow:none;transform:scale(1);}95%{transform:scale(1.09);box-shadow:0 0 14px rgba(34,197,94,.65);} }
@keyframes dockUp { from{opacity:0;transform:translateX(-50%) translateY(24px);}to{opacity:1;transform:translateX(-50%) translateY(0);} }

/* ── LANDMARK HERO ── */
.lm-hero {
  min-height:50vh; padding:96px 20px 50px;
  background-size:cover; background-position:center;
  display:flex; flex-direction:column; align-items:center; justify-content:flex-end;
  text-align:center; position:relative; overflow:hidden;
}
.lm-hero-overlay { position:absolute; inset:0; background:linear-gradient(180deg, rgba(3,4,12,.45) 0%, rgba(3,4,12,.28) 40%, rgba(3,4,12,.84) 100%); }
.lm-hero > * { position:relative; z-index:1; }
.lm-hero h1 { font-family:'Cormorant Garamond', serif; font-size:clamp(30px,7.5vw,52px); font-weight:600; color:#fff; line-height:1.1; margin-bottom:10px; }
.lm-hero h1 em { font-style:italic; font-weight:300; color:var(--gold-lt); }
.lm-hero p { color:rgba(255,255,255,.72); font-size:14px; max-width:440px; margin:0 auto 22px; line-height:1.72; font-weight:300; }
.breadcrumb { display:flex; align-items:center; gap:7px; justify-content:center; flex-wrap:wrap; margin-bottom:14px; }
.breadcrumb a { font-size:11px; color:rgba(255,255,255,.44); transition:color .2s; }
.breadcrumb a:hover { color:var(--gold-lt); }
.breadcrumb span { font-size:11px; color:rgba(255,255,255,.22); }
.breadcrumb strong { font-size:11px; color:var(--gold-lt); font-weight:600; }
.hero-eyebrow-lm { font-size:9px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }

/* ── CITY HERO ── */
.city-hero {
  background:var(--void); padding:96px 20px 50px; text-align:center;
  position:relative; overflow:hidden;
}
.city-hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 80% 0%, rgba(224,112,18,.18) 0%, transparent 52%),
             radial-gradient(ellipse at 10% 100%, rgba(200,160,34,.10) 0%, transparent 50%);
  pointer-events:none;
}
.city-hero > * { position:relative; z-index:1; }
.city-hero h1 { font-family:'Cormorant Garamond', serif; font-size:clamp(30px,7vw,50px); font-weight:600; color:#fff; line-height:1.16; margin-bottom:10px; }
.city-hero h1 em { color:var(--gold-pale); font-style:italic; font-weight:300; }
.city-hero p { color:var(--ink-dim); font-size:14px; max-width:460px; margin:0 auto 24px; line-height:1.72; font-weight:300; }
.city-body { padding:0 16px; max-width:800px; margin:0 auto; }
.city-section {
  background:#fff; border:var(--b-pearl); border-radius:var(--r);
  padding:24px 22px; margin:14px 0; box-shadow:var(--sh-1);
}
.city-section h2 {
  font-family:'Cormorant Garamond', serif; font-size:22px; font-weight:600;
  color:var(--ink); margin-bottom:14px; padding-bottom:11px;
  border-bottom:1px solid var(--stone);
}

/* ── FORM ── */
.form-wrap { padding:0 16px 24px; max-width:680px; margin:0 auto; }
.form-hero { background:var(--void); padding:96px 20px 50px; text-align:center; position:relative; overflow:hidden; }
.form-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 50% 0%, rgba(224,112,18,.15) 0%, transparent 55%); }
.form-hero > * { position:relative; z-index:1; }
.form-hero h1 { font-family:'Cormorant Garamond', serif; font-size:clamp(28px,7vw,44px); font-weight:600; color:#fff; margin-bottom:8px; }
.form-hero h1 em { font-style:italic; color:var(--gold-lt); }
.form-hero p { font-size:13.5px; color:var(--ink-dim); max-width:380px; margin:0 auto; font-weight:300; }
.form-card { background:#fff; border:var(--b-pearl); border-radius:var(--r); padding:24px 22px; margin:16px 0; box-shadow:var(--sh-1); }
.field-label { display:block; font-size:11px; font-weight:700; color:var(--ink); margin-bottom:7px; letter-spacing:.5px; text-transform:uppercase; }
.field-req { color:var(--amber); }
.field-input, .field-select, .field-textarea {
  width:100%; padding:12px 15px; border:1.5px solid var(--stone);
  border-radius:var(--r-xs); font-family:'DM Sans',sans-serif; font-size:14px;
  color:var(--ink); background:#fff; transition:border-color .22s, box-shadow .22s;
  outline:none; appearance:none;
}
.field-input:focus, .field-select:focus, .field-textarea:focus {
  border-color:var(--amber); box-shadow:0 0 0 3px rgba(224,112,18,.10);
}
.field-textarea { resize:vertical; min-height:100px; }
.field-group { margin-bottom:18px; }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:13px; }
.submit-btn {
  width:100%; padding:16px; background:linear-gradient(135deg, var(--amber), var(--amber-lt));
  color:#fff; border:none; border-radius:var(--r-sm); font-family:'DM Sans',sans-serif;
  font-size:16px; font-weight:700; cursor:pointer;
  box-shadow:var(--sh-amber); transition:transform .2s var(--spring), box-shadow .2s;
}
.submit-btn:hover { transform:translateY(-2px); box-shadow:0 14px 44px var(--amber-glow); }
.success-screen { display:none; text-align:center; background:#fff; border:var(--b-pearl); border-radius:var(--r); padding:44px 26px; box-shadow:var(--sh-1); }
.success-screen.show { display:block; }
.service-badge { background:var(--void); color:#fff; border-radius:var(--r); padding:16px 18px; margin-bottom:20px; display:flex; align-items:center; gap:14px; border:var(--b-surf); box-shadow:var(--sh-card); }

/* ── CONTACT CARDS ── */
.contact-card { background:#fff; border:var(--b-pearl); border-radius:var(--r); padding:24px 22px; margin:14px 0; box-shadow:var(--sh-1); }
.contact-card h3 { font-family:'Cormorant Garamond', serif; font-size:21px; font-weight:600; color:var(--ink); margin-bottom:14px; }
.contact-btn-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.cta-call {
  display:flex; flex-direction:column; align-items:center; text-align:center;
  background:var(--void); color:#fff; padding:16px; border-radius:var(--r-sm);
  text-decoration:none; font-weight:600; font-size:14px;
}
.cta-call span { font-size:11.5px; opacity:.65; margin-top:3px; font-weight:400; }
.cta-wa {
  display:flex; flex-direction:column; align-items:center; text-align:center;
  background:#22C55E; color:#fff; padding:16px; border-radius:var(--r-sm);
  text-decoration:none; font-weight:600; font-size:14px;
  box-shadow:0 4px 18px rgba(34,197,94,.28);
}
.cta-wa span { font-size:11.5px; opacity:.78; margin-top:3px; font-weight:400; }
.map-frame { border-radius:var(--r-sm); overflow:hidden; position:relative; padding-bottom:56%; }
.map-frame iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }
.map-caption { font-size:12px; color:var(--ink-muted); margin-top:8px; text-align:center; }
.social-row { display:flex; gap:14px; flex-wrap:wrap; align-items:center; padding:6px 0; }
.social-row a img { width:44px; height:44px; transition:transform .22s var(--spring); }
.social-row a:hover img { transform:scale(1.18) translateY(-3px); }
.train-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.train-cell { background:var(--pearl); border-radius:var(--r-xs); padding:12px 13px; border:var(--b-pearl); }
.train-cell h5 { font-size:12px; font-weight:700; color:var(--ink); margin-bottom:5px; }
.train-cell p { font-size:12px; color:var(--ink-muted); line-height:1.55; }
.tip-strip { background:linear-gradient(135deg, var(--amber-dim), rgba(200,160,34,.08)); border:1px solid rgba(224,112,18,.20); border-radius:var(--r-xs); padding:11px 15px; margin:9px 0; font-size:12.5px; color:var(--ink-body); font-weight:500; }
.tip-strip strong { color:var(--amber); }
.adv-strip { background:linear-gradient(135deg, rgba(224,112,18,.07), rgba(200,160,34,.06)); border:1px solid rgba(224,112,18,.18); border-radius:var(--r-xs); padding:11px 15px; margin:9px 0; font-size:12.5px; color:var(--ink-body); font-weight:500; }
.adv-strip strong { color:var(--amber); }

/* ── LM BODY ── */
.lm-body { padding:0 16px; max-width:700px; margin:0 auto; }
.lm-section { background:#fff; border:var(--b-pearl); border-radius:var(--r); padding:24px 22px; margin:15px 0; box-shadow:var(--sh-1); }
.lm-section h2 { font-family:'Cormorant Garamond', serif; font-size:22px; font-weight:600; color:var(--ink); margin-bottom:14px; padding-bottom:11px; border-bottom:1px solid var(--stone); }
.lm-section h2 span { color:var(--amber); }
.lm-section p { font-size:14px; color:var(--ink-body); line-height:1.82; margin-bottom:10px; }
.lm-list { list-style:none; margin:6px 0; }
.lm-list li { display:flex; align-items:flex-start; gap:10px; padding:9px 12px; background:var(--pearl); border-radius:var(--r-xs); margin-bottom:5px; font-size:13.5px; color:var(--ink-body); border-left:3px solid var(--amber); }
.lm-tip { background:linear-gradient(135deg, rgba(224,112,18,.06), rgba(200,160,34,.05)); border:1px solid rgba(224,112,18,.18); border-radius:var(--r-xs); padding:13px 17px; margin:10px 0; font-size:13.5px; line-height:1.68; }
.lm-tip strong { color:var(--amber); }
.lm-img { border-radius:var(--r); overflow:hidden; box-shadow:var(--sh-2); margin:15px 0; line-height:0; }
.lm-img img { width:100%; height:230px; object-fit:cover; }
.lm-cta { background:var(--void); border-radius:var(--r); padding:28px 22px; text-align:center; margin:15px 0; border:var(--b-surf); position:relative; overflow:hidden; }
.lm-cta::before { content:''; position:absolute; top:-50px; right:-50px; width:180px; height:180px; background:radial-gradient(circle, rgba(224,112,18,.14) 0%, transparent 70%); }
.lm-cta h3 { font-family:'Cormorant Garamond', serif; color:var(--gold-lt); font-size:22px; font-weight:600; margin-bottom:8px; position:relative; z-index:1; }
.lm-cta p { color:var(--ink-dim); font-size:13px; margin-bottom:18px; line-height:1.62; font-weight:300; position:relative; z-index:1; }
.lm-cta-btns { display:grid; grid-template-columns:1fr 1fr; gap:10px; position:relative; z-index:1; }
.btn-call { display:block; text-align:center; background:var(--amber); color:#fff; padding:14px; border-radius:var(--r-sm); font-weight:700; font-size:14px; transition:background .2s; box-shadow:0 4px 18px var(--amber-glow); }
.btn-call:hover { background:var(--amber-dk); }
.btn-wa { display:block; text-align:center; background:#22C55E; color:#fff; padding:14px; border-radius:var(--r-sm); font-weight:700; font-size:14px; box-shadow:0 4px 18px rgba(34,197,94,.28); }
.btn-wa:hover { opacity:.88; }
.related-places { padding:0 16px 18px; max-width:700px; margin:0 auto; }
.related-places h3 { font-family:'Cormorant Garamond', serif; font-size:20px; font-weight:600; color:var(--ink); margin-bottom:14px; text-align:center; }
.related-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.related-card { background:#fff; border-radius:var(--r); overflow:hidden; border:var(--b-pearl); box-shadow:var(--sh-0); text-decoration:none; transition:transform .22s var(--spring), box-shadow .22s; display:block; }
.related-card:hover { transform:translateY(-3px); box-shadow:var(--sh-2); }
.related-card-inner { padding:15px 13px; }
.related-card-icon { font-size:22px; margin-bottom:6px; }
.related-card h4 { font-size:13px; color:var(--ink); font-weight:600; margin-bottom:3px; }
.related-card p { font-size:11px; color:var(--ink-muted); }

/* ── GALLERY (standalone) ── */
.gallery-hero { background:var(--void); padding:86px 20px 28px; text-align:center; position:relative; overflow:hidden; }
.gallery-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 50% at 50% -10%, rgba(224,112,18,.18) 0%, transparent 55%); }
.gallery-hero > * { position:relative; z-index:1; }
.gallery-hero h1 { font-family:'Cormorant Garamond', serif; font-size:clamp(28px,6.5vw,48px); font-weight:600; color:#fff; letter-spacing:-.3px; margin-bottom:6px; }
.gallery-hero h1 em { font-style:italic; color:var(--gold-lt); }
.gallery-hero p { font-size:13px; color:var(--ink-faint); }
.g-tabs { position:sticky; top:52px; z-index:100; background:rgba(3,4,12,.94); backdrop-filter:blur(16px); border-bottom:1px solid rgba(224,112,18,.14); display:flex; }
.g-tab { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; padding:12px 6px 10px; background:none; border:none; cursor:pointer; color:var(--ink-faint); font-family:'DM Sans',sans-serif; transition:color .22s, background .22s; position:relative; }
.g-tab::after { content:''; position:absolute; bottom:0; left:10%; right:10%; height:2px; background:linear-gradient(90deg, var(--amber), var(--gold-lt)); border-radius:2px 2px 0 0; transform:scaleX(0); transition:transform .24s var(--spring); }
.g-tab.active { color:#fff; }
.g-tab.active::after { transform:scaleX(1); }
.g-tab:hover:not(.active) { color:var(--ink-dim); background:rgba(255,255,255,.03); }
.g-tab-icon { font-size:18px; }
.g-tab-label { font-size:10.5px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; }
.g-tab-pill { font-size:9px; font-weight:700; background:var(--amber-dim); color:var(--amber); border-radius:50px; padding:1px 7px; border:1px solid rgba(224,112,18,.28); }
.g-tab.active .g-tab-pill { background:var(--gold-faint); color:var(--gold-lt); border-color:var(--gold-dim); }
.gallery-panel { display:none; background:var(--void); }
.gallery-panel.active { display:block; }
.masonry { columns:2; column-gap:8px; padding:12px 8px 96px; max-width:1340px; margin:0 auto; }
.g-card { break-inside:avoid; margin-bottom:8px; border-radius:var(--r-sm); overflow:hidden; position:relative; cursor:pointer; background:var(--surface); border:var(--b-surf); box-shadow:var(--sh-card); transition:transform .34s var(--spring), box-shadow .3s; -webkit-mask-image:-webkit-radial-gradient(white,black); }
.g-card:hover { transform:translateY(-6px) scale(1.012); box-shadow:0 0 0 1.5px rgba(224,112,18,.45), var(--sh-card), 0 0 28px rgba(224,112,18,.18); }
.g-card img { width:100%; height:auto; display:block; transition:transform .52s var(--silk), filter .4s; }
.g-card:hover img { transform:scale(1.05); filter:brightness(1.05) saturate(1.08); }
.g-card.feat { column-span:all; }
.g-card.feat img { width:100%; height:280px; object-fit:cover; }
.g-cap { position:absolute; bottom:0; left:0; right:0; padding:40px 14px 14px; background:linear-gradient(transparent, rgba(3,4,12,.46) 30%, rgba(3,4,12,.90) 100%); }
.g-tag { display:inline-block; font-size:7.5px; font-weight:700; letter-spacing:1.4px; text-transform:uppercase; color:var(--gold-lt); background:rgba(200,160,34,.14); border:1px solid rgba(200,160,34,.30); padding:2px 8px; border-radius:50px; margin-bottom:5px; }
.g-title { font-family:'Cormorant Garamond', serif; font-size:13px; color:#fff; font-weight:600; line-height:1.3; text-shadow:0 1px 8px rgba(0,0,0,.6); }
.g-sub { font-size:10.5px; color:var(--ink-dim); margin-top:4px; max-height:0; opacity:0; overflow:hidden; transition:max-height .26s, opacity .26s; }
.g-card:hover .g-sub { max-height:40px; opacity:1; }
.g-card.feat .g-cap { padding:60px 18px 18px; }
.g-card.feat .g-title { font-size:16px; }
.vid-wrap { position:relative; overflow:hidden; line-height:0; }
.vid-wrap video { width:100%; height:auto; display:block; transition:transform .52s var(--silk); }
.g-card:hover .vid-wrap video { transform:scale(1.05); }
.play-ring { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:52px; height:52px; border-radius:50%; background:rgba(3,4,12,.65); backdrop-filter:blur(10px); border:2px solid rgba(224,112,18,.65); display:flex; align-items:center; justify-content:center; pointer-events:none; transition:opacity .25s, border-color .25s, box-shadow .25s; box-shadow:0 0 0 6px rgba(224,112,18,.10); }
.g-card:hover .play-ring { border-color:var(--gold-lt); box-shadow:0 0 0 8px rgba(200,160,34,.12), var(--sh-gold); }
.play-ring svg { width:20px; height:20px; fill:none; stroke:var(--gold-lt); stroke-width:1.8; margin-left:3px; }
.g-card.playing .play-ring { opacity:0; }
.g-card.feat .vid-wrap video { height:280px; object-fit:cover; }
.g-card.feat .play-ring { width:64px; height:64px; }
.lightbox { position:fixed; inset:0; z-index:9999; display:none; flex-direction:column; align-items:center; justify-content:center; background:rgba(2,3,9,.97); backdrop-filter:blur(6px); }
.lightbox.open { display:flex; }
.lb-img-wrap { position:relative; max-width:94vw; max-height:78vh; }
#lb-img { max-width:94vw; max-height:78vh; object-fit:contain; border-radius:10px; box-shadow:0 24px 72px rgba(0,0,0,.72), 0 0 0 1px rgba(255,255,255,.06); }
.lb-close { position:absolute; top:14px; right:14px; background:rgba(3,4,12,.88); border:1px solid rgba(255,255,255,.14); color:rgba(255,255,255,.80); font-size:18px; line-height:1; padding:6px 11px; border-radius:8px; cursor:pointer; transition:background .2s; z-index:10; }
.lb-close:hover { background:var(--amber); color:#fff; }
.lb-nav { position:absolute; top:50%; transform:translateY(-50%); background:rgba(3,4,12,.75); border:1px solid rgba(255,255,255,.12); color:rgba(255,255,255,.80); font-size:22px; line-height:1; padding:12px 16px; border-radius:10px; cursor:pointer; transition:background .2s; z-index:10; }
.lb-nav:hover { background:var(--amber); color:#fff; }
.lb-prev { left:-50px; } .lb-next { right:-50px; }
.lb-cap { padding:16px 14px 0; text-align:center; }
.lb-cap .g-title { font-size:15px; }
.gallery-book { background:linear-gradient(135deg, rgba(224,112,18,.18), rgba(3,4,12,.35), rgba(200,160,34,.12)); border:1px solid rgba(224,112,18,.35); border-radius:var(--r); margin:0 8px 8px; padding:18px 20px; display:flex; flex-direction:column; gap:12px; align-items:center; text-align:center; position:relative; overflow:hidden; }
.gallery-book::before { content:''; position:absolute; top:-60px; right:-60px; width:200px; height:200px; background:radial-gradient(circle, rgba(200,160,34,.10) 0%, transparent 70%); pointer-events:none; }
.gallery-book h3 { font-family:'Cormorant Garamond', serif; font-size:17px; color:var(--gold-lt); font-weight:600; position:relative; z-index:1; }
.gallery-book p { font-size:12.5px; color:var(--ink-dim); line-height:1.62; font-weight:300; position:relative; z-index:1; }
.gallery-book-btns { display:flex; gap:8px; flex-wrap:wrap; justify-content:center; position:relative; z-index:1; }
.gbtn-call { background:var(--amber); color:#fff; padding:11px 22px; border-radius:50px; font-weight:700; font-size:13px; box-shadow:0 4px 18px var(--amber-glow); transition:transform .2s; }
.gbtn-call:hover { transform:translateY(-2px); }
.gbtn-wa { background:#25D366; color:#fff; padding:11px 22px; border-radius:50px; font-weight:700; font-size:13px; box-shadow:0 4px 16px rgba(37,211,102,.28); transition:transform .2s; }
.gbtn-wa:hover { transform:translateY(-2px); }
.g-footer-bar { background:var(--void); border-top:1px solid rgba(224,112,18,.16); padding:10px 0; display:flex; justify-content:center; gap:26px; position:fixed; bottom:0; left:0; width:100%; z-index:1000; backdrop-filter:blur(16px); }
.g-footer-bar a img { width:36px; height:36px; transition:transform .22s var(--spring); }
.g-footer-bar a:hover img { transform:scale(1.22) translateY(-4px); }
.g-copyright { background:#02030A; color:rgba(255,255,255,.30); font-size:12px; text-align:center; padding:11px; display:flex; flex-wrap:wrap; justify-content:center; gap:8px; margin-bottom:80px; border-top:1px solid rgba(255,255,255,.05); }
.g-copyright a { color:var(--gold); font-weight:700; }

/* ── ANIMATIONS ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:translateY(0);} }
@keyframes shimmer { 0%,100%{opacity:.7;}50%{opacity:1;} }
.reveal { opacity:0; transform:translateY(22px); animation:fadeUp .55s ease forwards; animation-play-state:paused; }
.reveal.visible { animation-play-state:running; }

/* ── DESKTOP 768px+ ── */
@media(min-width:768px){
  .gp-card.wide { grid-column:span 4; aspect-ratio:21/7; }
  .nav { display:flex; align-items:center; justify-content:space-between; padding:0 52px; }
  .nav-inner { padding:14px 0; flex:0 0 auto; }
  .nav-toggle { display:none; }
  .nav-links { display:flex!important; flex-direction:row!important; max-height:none!important; overflow:visible!important; padding:0!important; gap:4px; align-items:center; }
  .nav-link { padding:8px 16px; font-size:13px; border-radius:var(--r-xs); }
  .hero { padding:120px 72px 80px; flex-direction:row; align-items:center; justify-content:flex-start; min-height:100vh; }
  .hero-display { font-size:clamp(54px,6vw,88px); }
  .hero-text-col { max-width:560px; }
  .stats-band { width:100%; }
  .stat-val { font-size:clamp(32px,3.5vw,48px); }
  .rides-grid { grid-template-columns:1fr 1fr; }
  .exp-pillars { grid-template-columns:1fr 1fr; }
  .gp-grid { grid-template-columns:repeat(4,1fr); }
  .cities-grid { grid-template-columns:repeat(3,1fr); }
  .city-card.span2 { grid-column:span 1; flex-direction:column; align-items:flex-start; }
  .city-card.span2 .city-icon { margin-bottom:8px; font-size:22px; }
  .testi-grid { flex-direction:row; flex-wrap:wrap; }
  .rating-card { flex:0 0 220px; }
  .testi-card { flex:1; min-width:240px; }
  .footer-grid { grid-template-columns:1.4fr 1fr 1fr 1fr; }
  .lm-body { max-width:840px; padding:0 36px; }
  .lm-section { padding:30px 34px; }
  .lm-img img { height:300px; }
  .related-places { max-width:840px; padding:0 36px 26px; }
  .related-grid { grid-template-columns:repeat(4,1fr); }
  .city-body { max-width:880px; padding:0 36px; }
  .city-section { padding:30px 34px; }
  .lm-hero { min-height:380px; padding:130px 72px 68px; }
  .masonry { columns:3; column-gap:12px; padding:16px 20px 96px; }
  .g-card.feat img { height:380px; }
  .g-card.feat .vid-wrap video { height:380px; }
  .gallery-book { flex-direction:row; text-align:left; justify-content:space-between; margin:0 20px 16px; }
  .dock { gap:22px; padding:12px 28px; }
  .dock a img { width:34px; height:34px; }
  .form-wrap { padding:30px 26px 80px; }
  .profile-card { display:flex; gap:24px; align-items:flex-start; }
}
@media(min-width:1100px){
  .nav { padding:0 72px; }
  .rides-grid { grid-template-columns:repeat(3,1fr); padding:0 52px 18px; }
  .exp-pillars { grid-template-columns:repeat(4,1fr); }
  .masonry { columns:4; }
  .g-card.feat img { height:440px; }
  .hero { padding:130px 100px 90px; }
}
