/* ================================================================
   Horizon Tours — styles.css
   Theme: Premium White & Gold | Production Ready
================================================================ */

/* ── 1. VARIABLES ───────────────────────────────────────────────── */
:root {
  --gold:      #c9a84c;
  --gold-lt:   #e2c47a;
  --gold-dk:   #9e7a2e;
  --gold-glow: rgba(201,168,76,.35);
  --ink:       #0f0f0f;
  --ink-2:     #2e2e2e;
  --ink-3:     #555;
  --muted:     #888;
  --white:     #ffffff;
  --off-white: #faf8f4;
  --canvas:    #f5f3ee;
  --line:      #e6e0d4;
  --dark:      #0c0a07;
  --dark-2:    #161410;
  --ff-display:'Playfair Display', Georgia, serif;
  --ff-body:   'Inter', system-ui, sans-serif;
  --nav-h:     72px;
  --max-w:     1220px;
  --r:         12px;
  --r-lg:      20px;
  --r-xl:      28px;
  --sh-xs:  0 1px 6px  rgba(0,0,0,.05);
  --sh-sm:  0 2px 14px rgba(0,0,0,.07);
  --sh:     0 8px 32px rgba(0,0,0,.10);
  --sh-lg:  0 20px 60px rgba(0,0,0,.14);
  --ease:   cubic-bezier(.22,1,.36,1);
  --ease2:  cubic-bezier(.4,0,.2,1);
}

/* ── 2. RESET ───────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body {
  font-family:var(--ff-body);
  color:var(--ink-3);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img  { display:block; max-width:100%; height:auto; }
a    { color:inherit; text-decoration:none; }
ul   { list-style:none; }
button,input,select,textarea { font:inherit; border:none; background:none; }
textarea { resize:vertical; }

/* ── 3. LAYOUT ──────────────────────────────────────────────────── */
.container { width:min(var(--max-w), 100% - 2.5rem); margin-inline:auto; }
.section   { padding:6rem 0; }

/* ── 4. SCROLL REVEAL ───────────────────────────────────────────── */
.reveal {
  opacity:0;
  transform:translateY(28px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
  transition-delay:calc(var(--i,0)*90ms + var(--d,0ms));
}
.reveal.in { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce) {
  .reveal { opacity:1; transform:none; transition:none; }
}

/* ── 5. TYPOGRAPHY ──────────────────────────────────────────────── */
h1,h2,h3,h4 {
  font-family:var(--ff-display);
  color:var(--ink);
  font-weight:700;
  line-height:1.1;
}
.eyebrow {
  display:block;
  font-size:.68rem; font-weight:700;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold); margin-bottom:.65rem;
}
.sec-title { font-size:clamp(1.9rem,4vw,3rem); letter-spacing:-.02em; margin-bottom:1rem; }
.sec-lead  { font-size:1.05rem; color:var(--muted); line-height:1.7; max-width:38rem; }
.sec-head  { margin-bottom:3rem; }
.sec-head--center { text-align:center; }
.sec-head--center .sec-lead { margin-inline:auto; }
.sec-head--split {
  display:flex; align-items:flex-end;
  justify-content:space-between; flex-wrap:wrap; gap:1rem;
}

/* ── 6. BUTTONS ─────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  gap:.4rem; padding:.85rem 2rem;
  font-size:.9rem; font-weight:600;
  border-radius:100px; cursor:pointer; white-space:nowrap;
  transition:transform .2s var(--ease2), background .2s, box-shadow .2s, color .2s, border-color .2s;
}
.btn:active { transform:scale(.97); }
.btn-gold {
  background:linear-gradient(135deg,var(--gold),var(--gold-dk));
  color:#fff; box-shadow:0 4px 18px var(--gold-glow);
}
.btn-gold:hover {
  background:linear-gradient(135deg,var(--gold-lt),var(--gold));
  box-shadow:0 6px 28px rgba(201,168,76,.55);
  transform:translateY(-2px);
}
.btn-ghost {
  border:1.5px solid rgba(255,255,255,.55);
  color:#fff; background:rgba(255,255,255,.08);
  backdrop-filter:blur(6px);
}
.btn-ghost:hover { background:rgba(255,255,255,.2); border-color:#fff; }
.btn-outline { border:1.5px solid var(--gold); color:var(--gold); }
.btn-outline:hover { background:var(--gold); color:#fff; }
.btn-sm    { padding:.5rem 1.2rem; font-size:.82rem; }
.btn-block { width:100%; }

/* ── 7. NAVBAR ──────────────────────────────────────────────────── */
/* Logo LEFT — menu links RIGHT */
.navbar {
  position: fixed;
  inset: 0 0 auto;
  z-index: 900;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(18px);
  box-shadow: 0 1px 0 var(--line);
  transition: background .35s, box-shadow .35s;
}
.navbar.solid {
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(18px);
  box-shadow:0 1px 0 var(--line);
}
.navbar__inner {
  display:flex; align-items:center; justify-content:space-between;
  height:var(--nav-h);
  width:min(var(--max-w), 100% - 2.5rem);
  margin-inline:auto;
}
.nav-logo{
  height: 140px;
}
/* Brand — always on the far LEFT */
.brand {
  display:flex;
  align-items:center;
  gap:.55rem;
  font-family:var(--ff-display);
  font-size:1.3rem;
  font-weight:700;
  color:var(--gold);
}

.nav-link {
  font-size:.875rem;
  font-weight:500;
  color:var(--ink);
  transition:color .2s;
  position:relative;
}
.brand-icon { width:32px; height:32px; flex-shrink:0; }
.navbar.solid .brand { color:var(--gold); }

/* Links — pushed to the RIGHT naturally by flex space-between */
.navbar__links { display:none; gap:2rem; align-items:center; }
@media (min-width:960px) { .navbar__links { display:flex; } }

.nav-link {
  font-size:.875rem;
  font-weight:500;
  color:#000 !important;
  transition:color .2s;
  position:relative;
}
.navbar .nav-link {
  color:#000 !important;
}
.nav-link::after {
  content:''; position:absolute; left:0; bottom:-3px;
  width:0; height:1.5px; background:var(--gold-lt);
  transition:width .25s var(--ease2);
}
.nav-link:hover,
.nav-link.active {
  color:var(--ink);
}
.nav-link:hover::after,.nav-link.active::after { width:100%; }
.navbar.solid .nav-link { color:var(--ink-3); }
.navbar.solid .nav-link::after { background:var(--gold); }
.navbar.solid .nav-link:hover,.navbar.solid .nav-link.active { color:var(--ink); }

.navbar__cta { display:none; }
@media (min-width:960px) { .navbar__cta { display:inline-flex; } }

/* Hamburger */
.hamburger { display:flex; flex-direction:column; gap:5px; padding:8px; cursor:pointer; }
@media (min-width:960px) { .hamburger { display:none; } }
.hamburger span {
  display:block; width:22px; height:2px;
  background: var(--ink); border-radius:2px; transition:.3s;
}
.navbar.solid .hamburger span { background:var(--ink); }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile dropdown */
.mobile-menu {
  display:none; flex-direction:column;
  background:var(--white);
  padding:1rem 1.5rem 1.75rem;
  border-top:1px solid var(--line);
  box-shadow:var(--sh);
}
.mobile-menu.open { display:flex; }
.mob-link {
  padding:.9rem 0; font-weight:500; font-size:.95rem;
  border-bottom:1px solid var(--line); color:var(--ink); transition:color .2s;
}
.mob-link:hover { color:var(--gold); }
.mob-cta { margin-top:1rem; text-align:center; }

/* ── 8. HERO — full-width bg, dark overlay, centered content ────── */
.hero {
  position:relative;
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; color:#fff; text-align:center;
}
/* Background layers */
.hero__bg { position:absolute; inset:0; z-index:0; }
.hero__video {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
}
.hero__fallback {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
}
/* Dark gradient overlay */
.hero__overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(
    160deg,
    rgba(8,6,3,.72) 0%,
    rgba(8,6,3,.48) 55%,
    rgba(8,6,3,.72) 100%
  );
}
/* Content — vertically and horizontally centered */
.hero__content {
  position:relative; z-index:2;
  padding:calc(var(--nav-h) + 2rem) 1.5rem 5rem;
  max-width:860px; width:100%;
}
.hero__eyebrow { color:var(--gold-lt); font-size:.75rem; }
.hero__title {
  font-size:clamp(2.5rem,7vw,5.5rem);
  color:#fff; font-weight:700;
  line-height:1.05; letter-spacing:-.03em;
  margin-bottom:1.35rem;
}
.hero__title em { font-style:italic; color:var(--gold-lt); }
.hero__lead {
  font-size:clamp(.95rem,2vw,1.15rem);
  color:rgba(255,255,255,.80); line-height:1.75;
  max-width:560px; margin:0 auto 2.25rem;
}
.hero__ctas {
  display:flex; flex-wrap:wrap; gap:1rem;
  justify-content:center; margin-bottom:3.25rem;
}
/* Stats strip */
.hero__stats {
  display:inline-flex; flex-wrap:wrap;
  align-items:center; justify-content:center;
  gap:.5rem 1.75rem;
  padding:1.25rem 2.25rem;
  background:rgba(255,255,255,.09);
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.16);
  border-radius:var(--r-xl);
}
.hstat { text-align:center; }
.hstat strong {
  display:block; font-family:var(--ff-display);
  font-size:1.65rem; font-weight:700;
  color:var(--gold-lt); line-height:1;
}
.hstat span { font-size:.7rem; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.07em; }
.hstat-sep { width:1px; height:2.5rem; background:rgba(255,255,255,.18); }
@media (max-width:480px) { .hstat-sep { display:none; } }

/* Scroll indicator */
.hero__scroll {
  position:absolute; bottom:2rem; left:50%;
  transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.45rem;
}
.hero__scroll span { font-size:.68rem; color:rgba(255,255,255,.5); letter-spacing:.1em; text-transform:uppercase; }
.scroll-mouse { width:22px; height:36px; border:2px solid rgba(255,255,255,.35); border-radius:11px; position:relative; }
.scroll-wheel {
  width:4px; height:8px; border-radius:2px;
  background:var(--gold-lt);
  position:absolute; left:50%; top:5px; transform:translateX(-50%);
  animation:wheelScroll 1.8s ease-in-out infinite;
}
@keyframes wheelScroll { 0%,100%{opacity:1;top:5px} 50%{opacity:0;top:17px} }

/* ── 9. TRUST STRIP ─────────────────────────────────────────────── */
.trust-strip { background:var(--gold); overflow:hidden; padding:.85rem 0; }
.trust-track {
  display:flex; gap:2rem; align-items:center;
  width:max-content;
  animation:marquee 26s linear infinite;
}
.trust-track span { font-family:var(--ff-display); font-size:1rem; font-weight:600; color:var(--dark); white-space:nowrap; }
.trust-track .sep { font-size:.7rem; opacity:.55; }
@keyframes marquee { to { transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce) { .trust-track { animation:none; } }

/* ── 10. TOUR PACKAGES GRID (replaces old Destinations + Experiences) */
/* GetYourGuide/Viator-style: 3-col desktop / 2-col tablet / 1-col mobile */
.tours { background:var(--off-white); }

/* Filter bar */
.filter-bar {
  display:flex; flex-wrap:wrap; gap:.5rem;
  justify-content:center; margin-bottom:2.5rem;
}
.filter-btn {
  padding:.5rem 1.25rem;
  font-size:.82rem; font-weight:600;
  border-radius:100px;
  border:1.5px solid var(--line);
  background:var(--white); color:var(--muted);
  cursor:pointer; transition:all .22s;
}
.filter-btn:hover,
.filter-btn.active {
  background:var(--gold); border-color:var(--gold);
  color:#fff; box-shadow:0 3px 12px var(--gold-glow);
}

/* 3-col → 2-col → 1-col responsive grid */
.tours-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
@media (max-width:960px) { .tours-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px) { .tours-grid { grid-template-columns:1fr; } }

/* Tour card */
.tour-card {
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  overflow:hidden;
  display:flex; flex-direction:column;
  box-shadow:var(--sh-xs);
  transition:transform .35s var(--ease), box-shadow .35s;
}
.tour-card.in:hover { transform:translateY(-5px); box-shadow:var(--sh); }
.tour-card.hidden   { display:none; }

.tour-card__img {
  position:relative;
  aspect-ratio:16/10;
  overflow:hidden;
}
.tour-card__img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .6s var(--ease);
}
.tour-card:hover .tour-card__img img { transform:scale(1.05); }

/* Type badge */
.tour-card__badge {
  position:absolute; top:.75rem; left:.75rem;
  font-size:.62rem; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  padding:.28rem .65rem; border-radius:100px;
}
.tour-card__badge--guided { background:var(--ink); color:#fff; }
.tour-card__badge--ticket { background:var(--gold); color:#fff; }

/* Card body */
.tour-card__body {
  padding:1.2rem 1.35rem 1.4rem;
  flex:1; display:flex; flex-direction:column;
}
.tour-card__meta {
  display:flex; gap:.75rem; align-items:center;
  font-size:.76rem; color:var(--muted); margin-bottom:.65rem;
}
.tour-card__body h3 {
  font-family:var(--ff-body);
  font-size:.95rem; font-weight:700;
  color:var(--ink); line-height:1.35; margin-bottom:.55rem;
}
.tour-card__body p {
  font-size:.845rem; color:var(--muted);
  line-height:1.6; flex:1; margin-bottom:1rem;
}
.tour-card__foot {
  display:flex; align-items:center;
  justify-content:space-between; gap:.5rem; margin-top:auto;
}
.tour-card__rating { font-size:.8rem; color:var(--gold); font-weight:600; }
.tour-card__rating em { font-style:normal; color:var(--muted); font-weight:400; }

/* ── 11. ABOUT / WHY CHOOSE US ──────────────────────────────────── */
.about { background:var(--dark); }
.about .eyebrow   { color:var(--gold-lt); }
.about .sec-title { color:#fff; }

.about-wrap {
  display:grid; gap:5rem; align-items:center;
}
@media (min-width:900px) { .about-wrap { grid-template-columns:1fr 1fr; } }

/* Image collage */
.about-imgs {
  display:grid;
  grid-template-columns:3fr 2fr;
  grid-template-rows:1fr 1fr;
  height:560px;
  gap:.8rem;
}

.about-img--main {
  grid-row:span 2;
}

.about-img {
  height:100%;
  background-size:cover;
  background-position:center;
  border-radius:var(--r-lg);
}
.about-img {
  border-radius:var(--r-lg);
  background-size:cover; background-position:center;
  box-shadow:var(--sh);
}
.about-img--main { grid-row:span 2; }

.about-visuals { position:relative; }
.about-badge {
  position:absolute; bottom:-1rem; left:50%;
  transform:translateX(-50%);
  background:var(--gold);
  border-radius:var(--r); padding:.8rem 1.5rem;
  text-align:center; box-shadow:var(--sh-lg); white-space:nowrap; z-index:3;
}
.about-badge strong {
  display:block; font-family:var(--ff-display);
  font-size:2rem; color:var(--dark); line-height:1;
}
.about-badge span { font-size:.9rem; color:var(--dark); }
.about-badge em {
  display:block; font-style:normal;
  font-size:.62rem; color:rgba(0,0,0,.55);
  letter-spacing:.1em; text-transform:uppercase;
}

/* Text */
.about-intro { font-size:.97rem; color:rgba(255,255,255,.6); line-height:1.75; margin-bottom:2rem; }
.why-list { display:flex; flex-direction:column; gap:1.35rem; margin-bottom:2.25rem; }
.why-list li { display:flex; gap:.9rem; align-items:flex-start; }
.why-ico { font-size:1.3rem; flex-shrink:0; margin-top:.1rem; }
.why-list strong { display:block; color:#fff; font-weight:600; margin-bottom:.2rem; font-size:.9rem; }
.why-list p { font-size:.825rem; color:rgba(255,255,255,.5); line-height:1.5; }

/* ── 12. HOW IT WORKS ───────────────────────────────────────────── */
.process { background:var(--canvas); }
.steps { display:grid; }
@media (min-width:768px) {
  .steps {
    grid-template-columns: repeat(3,1fr);
    max-width: 1100px;
    margin: 0 auto;
  }
}
.step {
  padding: 2.5rem 2rem;
  text-align: center;
  border-right: 1px solid var(--line);
}

.step:last-child {
  border-right: none;
}
@media (max-width:767px) {
  .step { border-right:none; border-bottom:1px solid var(--line); padding:2rem 1.25rem; }
  .step:last-child { border-bottom:none; }
}
.step__num {
  font-family:var(--ff-display);
  font-size:3.5rem; font-weight:700;
  color:var(--gold); opacity:.3;
  line-height:1; margin-bottom:1rem;
}
.step h3 { font-family:var(--ff-body); font-size:1rem; font-weight:700; color:var(--ink); margin-bottom:.45rem; }
.step p  { font-size:.875rem; color:var(--muted); line-height:1.6; }

/* ── 13. GALLERY ────────────────────────────────────────────────── */
.gallery { background:var(--white); }
.gallery-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:220px;
  gap:.85rem;
}
@media (max-width:900px) { .gallery-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:540px) {

  .gallery-grid {
    display:flex;
    flex-direction:column;
    gap:16px;
  }

  .gal-item,
  .gal-item--tall,
  .gal-item--wide {
    width:100%;
    grid-row:auto;
    grid-column:auto;
  }

  .gal-item img {
    width:100%;
    height:auto;
    display:block;
  }
}

.gal-item { overflow:hidden; border-radius:var(--r); position:relative; cursor:pointer; }
.gal-item--tall { grid-row:span 2; }
.gal-item--wide { grid-column:span 2; }
.gal-item img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); display:block; }
.gal-item:hover img { transform:scale(1.07); }
.gal-hover {
  position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.68));
  display:flex; align-items:flex-end; padding:1rem;
  opacity:0; transition:opacity .3s;
}
.gal-item:hover .gal-hover { opacity:1; }
.gal-hover span { color:#fff; font-size:.78rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; }

/* Lightbox */
.lightbox {
  position:fixed; inset:0; z-index:1000;
  background:rgba(0,0,0,.93);
  display:flex; align-items:center; justify-content:center;
  padding:1.25rem; animation:fadeIn .22s ease;
}
.lightbox[hidden] { display:none; }
@keyframes fadeIn { from{opacity:0}to{opacity:1} }
.lb-box { text-align:center; max-width:900px; width:100%; }
.lb-img { max-height:80vh; max-width:100%; border-radius:var(--r); margin:0 auto; box-shadow:var(--sh-lg); }
.lb-caption { color:rgba(255,255,255,.6); font-size:.85rem; margin-top:.75rem; }
.lb-close,.lb-prev,.lb-next {
  position:fixed;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2);
  color:#fff; cursor:pointer; border-radius:50%;
  width:46px; height:46px; display:grid; place-items:center; font-size:1.15rem;
  transition:background .2s;
}
.lb-close:hover,.lb-prev:hover,.lb-next:hover { background:var(--gold); border-color:var(--gold); }
.lb-close { top:1.25rem; right:1.25rem; font-size:1.5rem; }
.lb-prev  { left:1.25rem; top:50%; transform:translateY(-50%); }
.lb-next  { right:1.25rem; top:50%; transform:translateY(-50%); }

/* ── 14. TESTIMONIALS — all cards identical structure ───────────── */
.testimonials { background:var(--off-white); }

/* 2-col desktop / 1-col mobile — every card is the same */
.reviews-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem;
}
@media (max-width:680px) { .reviews-grid { grid-template-columns:1fr; } }

.review-card {
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:2rem 2rem 1.75rem;
  box-shadow:var(--sh-xs);
  display:flex; flex-direction:column; gap:1rem;
  transition:transform .35s var(--ease), box-shadow .35s;
}
.review-card.in:hover { transform:translateY(-4px); box-shadow:var(--sh); }

/* Stars */
.review-card__stars { color:var(--gold); font-size:1rem; letter-spacing:.08em; }

/* Quote text */
.review-card blockquote {
  font-family:var(--ff-display);
  font-size:clamp(1.05rem,2vw,1.2rem);
  font-style:italic; font-weight:600;
  line-height:1.6; color:var(--ink-2); flex:1;
}

/* Author row — same markup and styling on all 4 cards */
.review-card__footer {
  display:flex; align-items:center; gap:.85rem;
  margin-top:auto; padding-top:1rem;
  border-top:1px solid var(--line);
}
.review-card__avatar {
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-dk));
  color:#fff; display:grid; place-items:center;
  font-weight:700; font-size:.95rem; flex-shrink:0;
}
.review-card__info { flex:1; }
.review-card__info strong { display:block; color:var(--ink); font-size:.875rem; font-weight:600; }
.review-card__info span  { font-size:.75rem; color:var(--muted); }
.review-card__badge {
  font-size:.66rem; font-weight:700;
  color:var(--gold); letter-spacing:.1em; text-transform:uppercase;
  flex-shrink:0;
}

/* ── 15. CONTACT ────────────────────────────────────────────────── */
.contact { background:var(--white); }

.contact-wrap {
  display:grid; gap:4rem; align-items:start;
}
@media (min-width:900px) { .contact-wrap { grid-template-columns:1fr 1.1fr; } }

.contact-info .sec-title { margin-bottom:.75rem; }
.contact-lead { color:var(--muted); font-size:.95rem; line-height:1.75; margin-bottom:2rem; }

.contact-list { display:flex; flex-direction:column; gap:.9rem; margin-bottom:2rem; }
.contact-list li { display:flex; align-items:flex-start; gap:.65rem; }
.contact-list li span:first-child { font-size:.95rem; flex-shrink:0; margin-top:.15rem; }
.contact-list a   { font-size:.9rem; color:var(--ink-2); transition:color .2s; }
.contact-list a:hover { color:var(--gold); }
.contact-list span:last-child { font-size:.9rem; color:var(--muted); }

.contact-socials { display:flex; gap:.6rem; margin-bottom:2rem; }
.social-btn {
  width:40px; height:40px; border-radius:50%;
  border:1.5px solid var(--line);
  display:grid; place-items:center;
  color:var(--muted); transition:background .2s, border-color .2s, color .2s;
}
.social-btn svg { width:16px; height:16px; }
.social-btn:hover { background:var(--gold); border-color:var(--gold); color:#fff; }

.contact-quote {
  font-family:var(--ff-display); font-size:1rem; font-style:italic;
  color:var(--muted); line-height:1.6;
  padding:1.15rem 1.5rem;
  border-left:3px solid var(--gold);
  background:var(--off-white);
  border-radius:0 var(--r) var(--r) 0;
}

/* Form */
.contact-form-wrap {
  background:var(--off-white);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:2.25rem; box-shadow:var(--sh-xs);
}
.contact-form { display:flex; flex-direction:column; gap:1.1rem; }
.form-row { display:grid; gap:1.1rem; grid-template-columns:1fr 1fr; }
@media (max-width:540px) { .form-row { grid-template-columns:1fr; } }
.form-field { display:flex; flex-direction:column; gap:.35rem; }
.form-field label { font-size:.78rem; font-weight:600; color:var(--ink-2); letter-spacing:.03em; }
.form-field input,
.form-field select,
.form-field textarea {
  padding:.75rem 1rem;
  border:1.5px solid var(--line);
  border-radius:var(--r);
  background:var(--white); color:var(--ink);
  font-size:.9rem; outline:none;
  transition:border-color .2s, box-shadow .2s;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,168,76,.14);
}
.form-field input.err,
.form-field textarea.err { border-color:#e05252; }
.ferr { font-size:.73rem; color:#e05252; min-height:1em; }
.form-ok {
  text-align:center; color:#1a7a45; font-weight:600; font-size:.9rem;
  padding:.75rem; background:#eaf5ef; border-radius:var(--r); margin-top:.5rem;
}

/* ── 16. FOOTER — 4 columns including contact details ───────────── */
.footer { background:var(--dark-2); color:rgba(255,255,255,.58); padding:4.5rem 0 0; }

/* Top: brand + tagline */
.footer-top {
  display:flex;
  align-items:center;
  gap:2rem;
  flex-wrap:wrap;
  padding-bottom:2.5rem;
  border-bottom:1px solid rgba(255,255,255,.07);
  margin-bottom:2.75rem;
}
.footer-brand img {
  width: 270px;
  height: auto;
  display: block;
}
.footer-top p {
  font-size:.875rem; line-height:1.7;
  max-width:32rem; margin-top:.5rem;
}

/* 4-column grid */
.footer-grid {
  display:grid; gap:2.5rem;
  padding-bottom:2.75rem;
  border-bottom:1px solid rgba(255,255,255,.07);
}
@media (min-width:640px) { .footer-grid { grid-template-columns:repeat(4,1fr); } }

.footer-col h4 {
  font-family:var(--ff-body); font-size:.68rem; font-weight:700;
  letter-spacing:.15em; text-transform:uppercase;
  color:#fff; margin-bottom:1.1rem;
}
.footer-col ul { display:flex; flex-direction:column; gap:.55rem; }
.footer-col a  { font-size:.875rem; transition:color .2s; }
.footer-col a:hover { color:var(--gold); }

/* Contact column with icons */
.footer-contact { gap:.7rem !important; }
.footer-contact li { display:flex !important; align-items:flex-start; gap:.5rem; }
.footer-contact li span:first-child { font-size:.85rem; flex-shrink:0; margin-top:.1rem; }
.footer-contact li span:last-child { font-size:.85rem; color:rgba(255,255,255,.45); line-height:1.45; }
.footer-contact a { font-size:.85rem; transition:color .2s; }
.footer-contact a:hover { color:var(--gold); }

.footer-social { display:flex; gap:.5rem; flex-wrap:wrap; margin-top:1.25rem; }
.footer .social-btn { border-color:rgba(255,255,255,.12); color:rgba(255,255,255,.5); }

/* Bottom bar */
.footer-bottom {
  display:flex; flex-wrap:wrap;
  justify-content:space-between; align-items:center;
  gap:.75rem; padding:1.5rem 0;
  font-size:.78rem; opacity:.4;
}
.footer-legal { display:flex; gap:.75rem; align-items:center; flex-wrap:wrap; }
.footer-legal a { text-decoration:underline; text-underline-offset:3px; }
.footer-legal a:hover { opacity:.8; }

/* ── 17. BACK TO TOP ────────────────────────────────────────────── */
.back-top {
  position:fixed; bottom:1.75rem; right:1.75rem; z-index:800;
  width:46px; height:46px; border-radius:50%;
  background:var(--gold); color:#fff; font-size:1.1rem; cursor:pointer;
  display:grid; place-items:center;
  box-shadow:0 4px 16px var(--gold-glow);
  opacity:0; transform:translateY(12px);
  transition:opacity .35s, transform .35s;
  pointer-events:none;
}
.back-top.show { opacity:1; transform:none; pointer-events:auto; }
.back-top:hover { background:var(--gold-dk); }
