/* =========================================================
   Gardenia Skopje — Stylesheet
   ========================================================= */

:root{
  --green:        #5cbb4f;
  --green-bright: #6ed05e;
  --green-deep:   #2f7d32;
  --gold:         #d9a45b;
  --gold-soft:    #e7c089;

  --bg:           #0e0f0d;
  --bg-2:         #151713;
  --bg-3:         #1c1f1a;
  --panel:        #1a1c18;

  --cream:        #f4f1e8;
  --text:         #e9e7df;
  --muted:        #a9a89d;
  --line:         rgba(244,241,232,.12);

  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Jost", "Segoe UI", system-ui, sans-serif;

  --container: 1180px;
  --radius: 14px;
  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  font-weight:300;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
section{ position:relative; }

/* ---------- Layout ---------- */
.container{ width:min(var(--container), 92%); margin-inline:auto; }
.section{ padding:clamp(64px, 9vw, 130px) 0; }

h1,h2,h3{ font-family:var(--serif); font-weight:600; line-height:1.08; letter-spacing:.3px; }
h2{ font-size:clamp(2rem, 5vw, 3.4rem); color:var(--cream); }
h3{ font-size:1.4rem; color:var(--cream); }

.eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  font-weight:500;
  color:var(--green);
  margin-bottom:1rem;
}
.eyebrow.light{ color:var(--gold-soft); }
.accent{ color:var(--green); font-style:italic; }

.section-head{ margin-bottom:clamp(2.5rem,5vw,4rem); }
.section-head.center{ text-align:center; max-width:680px; margin-inline:auto; }
.section-lead{ color:var(--muted); margin-top:1rem; font-size:1.08rem; }
.light{ color:var(--cream); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  background:var(--green); color:#0c1a0b;
  font-family:var(--sans); font-weight:500; font-size:.92rem;
  letter-spacing:.08em; text-transform:uppercase;
  padding:.95rem 1.9rem; border-radius:50px;
  transition:transform .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease);
  box-shadow:0 8px 24px -10px rgba(92,187,79,.7);
}
.btn:hover{ background:var(--green-bright); transform:translateY(-3px); box-shadow:0 14px 30px -10px rgba(92,187,79,.8); }
.btn-ghost{
  background:transparent; color:var(--cream);
  border:1px solid rgba(244,241,232,.35); box-shadow:none;
}
.btn-ghost:hover{ background:rgba(244,241,232,.08); border-color:var(--cream); }
.btn-sm{ padding:.6rem 1.2rem; font-size:.78rem; }
.btn-block{ width:100%; }

/* ---------- Preloader ---------- */
#preloader{
  position:fixed; inset:0; z-index:2000;
  background:var(--bg);
  display:grid; place-items:center;
  transition:opacity .6s ease, visibility .6s ease;
}
#preloader.hidden{ opacity:0; visibility:hidden; }
.preloader-leaf{ color:var(--green); animation:beat 1.1s var(--ease) infinite; }
@keyframes beat{ 0%,100%{ transform:scale(1); opacity:.6; } 50%{ transform:scale(1.25); opacity:1; } }

/* ---------- Header ---------- */
#header{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:1.1rem 0;
  transition:background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
}
#header.scrolled{
  background:rgba(14,15,13,.92);
  backdrop-filter:blur(10px);
  padding:.6rem 0;
  box-shadow:0 1px 0 var(--line);
}
.nav-wrap{ display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.brand img{ height:42px; width:auto; transition:height .4s var(--ease);
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.5)); }
#header.scrolled .brand img{ height:34px; }

.nav ul{ display:flex; align-items:center; gap:2rem; }
.nav a{
  font-size:.86rem; letter-spacing:.06em; text-transform:uppercase;
  color:var(--text); font-weight:400; position:relative; padding:.2rem 0;
  transition:color .3s;
}
.nav a:not(.btn)::after{
  content:""; position:absolute; left:0; bottom:-3px; height:1.5px; width:0;
  background:var(--green); transition:width .3s var(--ease);
}
.nav a:not(.btn):hover::after, .nav a.active:not(.btn)::after{ width:100%; }
.nav a:not(.btn):hover, .nav a.active:not(.btn){ color:var(--green-bright); }
.nav-cta .btn{ color:#0c1a0b; padding:.62rem 1.9rem; }

/* Hamburger */
.lang-switch{ position:relative; display:flex; align-items:center; margin-left:.4rem; }
.lang-btn{
  display:inline-flex; align-items:center; gap:.42rem; cursor:pointer;
  background:transparent; border:1px solid var(--line); border-radius:999px;
  color:var(--text); padding:.4rem .72rem; line-height:1;
  font-family:var(--sans); font-size:.74rem; font-weight:600; letter-spacing:.05em;
  transition:border-color .25s var(--ease), color .25s var(--ease);
}
.lang-btn:hover, .lang-btn[aria-expanded="true"]{ border-color:var(--green); color:var(--cream); }
.lang-globe{ width:17px; height:17px; color:var(--green); flex:none; }

.lang-menu{
  position:absolute; top:calc(100% + 10px); right:0; z-index:1200;
  min-width:172px; margin:0; padding:6px; list-style:none;
  background:var(--bg-2); border:1px solid var(--line); border-radius:14px;
  box-shadow:0 22px 48px -16px rgba(0,0,0,.85);
}
.lang-menu[hidden]{ display:none; }
.lang-menu li{ margin:0; }
.lang-opt{
  display:block; width:100%; text-align:left; cursor:pointer;
  background:none; border:0; color:var(--text); border-radius:9px;
  font-family:var(--sans); font-size:.92rem; line-height:1.1; padding:.58rem .8rem;
  transition:background .2s var(--ease), color .2s var(--ease);
}
.lang-opt:hover{ background:rgba(244,241,232,.06); color:var(--cream); }
.lang-opt.is-active{ background:var(--green); color:#0c1a0b; font-weight:600; }

.nav-toggle{ display:none; width:42px; height:42px; position:relative; z-index:1100; }
.nav-toggle span{
  display:block; width:24px; height:2px; background:var(--cream);
  margin:5px auto; border-radius:2px; transition:.35s var(--ease);
}
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{ min-height:100svh; display:flex; align-items:center; overflow:hidden; }
.hero-media{
  position:absolute; inset:0; background-size:cover; background-position:center;
  transform:scale(1.08); animation:slowzoom 18s ease-in-out infinite alternate;
}
@keyframes slowzoom{ to{ transform:scale(1); } }
.hero-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(120% 90% at 50% 10%, rgba(14,15,13,.35), rgba(14,15,13,.78) 70%),
    linear-gradient(180deg, rgba(14,15,13,.6) 0%, rgba(14,15,13,.35) 40%, rgba(14,15,13,.95) 100%);
}
.hero-inner{ position:relative; z-index:2; padding:7rem 0 5rem; max-width:760px; }
.hero-title{
  font-size:clamp(2.8rem, 8vw, 6rem); color:var(--cream);
  margin:.6rem 0 1.4rem; letter-spacing:1px;
  text-shadow:0 4px 30px rgba(0,0,0,.5);
}
.hero-sub{ font-size:clamp(1.05rem,2.3vw,1.3rem); color:var(--text); max-width:540px; margin-bottom:2.2rem; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem; }

.scroll-cue{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:2;
  width:26px; height:42px; border:2px solid rgba(244,241,232,.4); border-radius:20px;
}
.scroll-cue span{
  position:absolute; top:8px; left:50%; transform:translateX(-50%);
  width:4px; height:8px; border-radius:2px; background:var(--green);
  animation:cue 1.6s var(--ease) infinite;
}
@keyframes cue{ 0%{ opacity:0; top:8px; } 40%{ opacity:1; } 80%,100%{ opacity:0; top:24px; } }

/* ---------- Marquee ---------- */
.marquee{
  background:var(--green-deep); color:var(--cream);
  padding:.85rem 0; overflow:hidden; white-space:nowrap;
  border-block:1px solid rgba(0,0,0,.15);
}
.marquee-track{ display:inline-flex; align-items:center; gap:2rem; animation:scroll-x 26s linear infinite; }
.marquee-track span{ font-family:var(--serif); font-style:italic; font-size:1.35rem; letter-spacing:.5px; }
.marquee-track i{ color:var(--gold-soft); font-size:.8rem; font-style:normal; }
@keyframes scroll-x{ to{ transform:translateX(-50%); } }

/* ---------- About ---------- */
.about{ background:var(--bg); }
.about-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,5rem); align-items:center; }
.about-images{ position:relative; padding-bottom:2rem; }
.about-img-main{ width:100%; height:520px; object-fit:cover; object-position:center 35%; border-radius:var(--radius);
  box-shadow:0 30px 60px -30px rgba(0,0,0,.8); }
.about-img-float{
  position:absolute; right:-18px; bottom:-12px; width:46%; height:210px; object-fit:cover;
  border-radius:var(--radius); border:5px solid var(--bg);
  box-shadow:0 20px 40px -20px rgba(0,0,0,.9);
}
.about-badge{
  position:absolute; top:-20px; left:-20px;
  width:108px; height:108px; border-radius:50%;
  background:var(--green); color:#0c1a0b;
  display:grid; place-content:center; text-align:center;
  box-shadow:0 14px 30px -10px rgba(92,187,79,.7);
  transform:rotate(-8deg);
}
.badge-num{ font-family:var(--serif); font-weight:700; font-size:1.5rem; line-height:1; }
.badge-text{ font-size:.7rem; text-transform:uppercase; letter-spacing:.1em; font-weight:500; margin-top:.2rem; }
.about-copy p{ color:var(--muted); margin-top:1.1rem; font-size:1.05rem; }
.about-copy h2{ margin-top:.4rem; }
.about-stats{ display:flex; flex-wrap:wrap; gap:2rem; margin-top:2.2rem; padding-top:2rem; border-top:1px solid var(--line); }
.about-stats strong{ display:block; font-family:var(--serif); font-size:1.7rem; color:var(--green-bright); }
.about-stats span{ font-size:.85rem; color:var(--muted); letter-spacing:.03em; }

/* ---------- Experience ---------- */
.experience{ overflow:hidden; }
.exp-bg{ position:absolute; inset:0; background-size:cover; background-position:center; }
.exp-overlay{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(14,15,13,.86), rgba(14,15,13,.92)); }
.experience .container{ position:relative; z-index:2; }
.exp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.exp-card{
  background:rgba(26,28,24,.6); backdrop-filter:blur(4px);
  border:1px solid var(--line); border-radius:var(--radius);
  padding:2.4rem 2rem; text-align:center;
  transition:transform .4s var(--ease), border-color .4s, background .4s;
}
.exp-card:hover{ transform:translateY(-8px); border-color:rgba(92,187,79,.5); background:rgba(26,28,24,.85); }
.exp-icon{
  width:64px; height:64px; margin:0 auto 1.3rem; border-radius:50%;
  display:grid; place-content:center; font-size:1.6rem; color:var(--green);
  border:1px solid rgba(92,187,79,.4); background:rgba(92,187,79,.08);
}
.exp-icon svg{ width:28px; height:28px; display:block; }
.exp-card p{ color:var(--muted); margin-top:.7rem; font-size:1rem; }

/* ---------- Our Services ---------- */
.services{ background:var(--bg); }
.services-list{
  list-style:none; margin:clamp(2rem,4vw,3rem) auto 0; padding:0; max-width:940px;
  display:grid; grid-template-columns:1fr 1fr; gap:0 clamp(2rem,5vw,4rem);
}
.service-item{
  display:flex; align-items:center; gap:1.3rem;
  padding:1.35rem .4rem; border-bottom:1px solid var(--line);
  transition:padding-left .35s var(--ease);
}
.service-item:hover{ padding-left:1rem; }
.service-num{
  font-family:var(--serif); font-weight:700; color:var(--green);
  font-size:2.1rem; line-height:1; min-width:2.6rem; letter-spacing:.02em;
}
.service-text{ color:var(--text); font-size:1.12rem; }

/* ---------- Menu ---------- */
.menu{ background:var(--bg-2); }
.menu-tabs{ display:flex; flex-wrap:wrap; justify-content:center; gap:.6rem; margin-bottom:3rem; }
.menu-tab{
  font-family:var(--sans); font-size:.82rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--muted); padding:.6rem 1.3rem; border-radius:50px;
  border:1px solid var(--line); transition:.3s var(--ease);
}
.menu-tab:hover{ color:var(--cream); border-color:rgba(244,241,232,.3); }
.menu-tab.is-active{ background:var(--green); color:#0c1a0b; border-color:var(--green); font-weight:500; }

.menu-panel{ display:none; }
.menu-panel.is-active{ display:block; animation:fadeUp .5s var(--ease); }
.menu-list{ display:grid; grid-template-columns:1fr 1fr; gap:1.7rem 3.5rem; max-width:980px; margin-inline:auto; }
.menu-list li{ }
.mi-head{ display:flex; align-items:baseline; gap:.5rem; }
.mi-name{ font-family:var(--serif); font-size:1.3rem; color:var(--cream); font-weight:600; white-space:nowrap; }
.mi-dots{ flex:1; border-bottom:1px dotted rgba(244,241,232,.25); transform:translateY(-3px); }
.mi-price{ font-family:var(--serif); font-size:1.25rem; color:var(--gold-soft); font-weight:600; }
.mi-desc{ color:var(--muted); font-size:.96rem; margin-top:.25rem; }
.menu-note{ text-align:center; color:var(--muted); font-size:.9rem; margin-top:3rem; font-style:italic; }

@keyframes fadeUp{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:none; } }

/* ---------- Gallery ---------- */
.gallery{ background:var(--bg); }
.gallery-grid{
  display:grid; grid-template-columns:repeat(4,1fr);
  grid-auto-rows:220px; gap:14px;
}
.g-item{
  position:relative; overflow:hidden; border-radius:12px;
  background:var(--bg-3); cursor:pointer;
}
.g-item img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.g-item::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(14,15,13,.55));
  opacity:0; transition:opacity .4s;
}
.g-item:hover img{ transform:scale(1.08); }
.g-item:hover::after{ opacity:1; }
.g-tall{ grid-row:span 2; }
.g-wide{ grid-column:span 2; }
.g-zoom, .g-play{
  position:absolute; z-index:2; color:var(--cream);
  opacity:0; transition:opacity .4s, transform .4s var(--ease);
}
.g-zoom{
  bottom:14px; left:16px; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  transform:translateY(8px);
}
.g-item:hover .g-zoom{ opacity:1; transform:none; }
.g-play{
  top:50%; left:50%; transform:translate(-50%,-50%) scale(.8);
  width:62px; height:62px; border-radius:50%; display:grid; place-content:center;
  background:rgba(92,187,79,.92); color:#0c1a0b; font-size:1.2rem; padding-left:4px;
  opacity:.92;
}
.g-item:hover .g-play{ opacity:1; transform:translate(-50%,-50%) scale(1); }

/* ---------- Tour Operator References ---------- */
.partners{ background:var(--bg); }
.partner-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
  margin-top:clamp(2rem,4vw,3rem);
}
.partner-card{
  display:grid; place-content:center; padding:22px 24px;
  background:#fff; border-radius:14px; min-height:96px; text-decoration:none;
  box-shadow:0 6px 22px rgba(0,0,0,.22);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
a.partner-card{ cursor:pointer; }
a.partner-card::after{
  content:"↗"; position:absolute; top:8px; right:11px;
  font-size:.78rem; color:var(--green); opacity:0; transition:opacity .35s;
}
a.partner-card{ position:relative; }
a.partner-card:hover::after{ opacity:.9; }
.partner-card img{
  max-width:100%; max-height:54px; width:auto; height:auto; object-fit:contain;
  filter:grayscale(1); opacity:.78;
  transition:filter .45s var(--ease), opacity .45s var(--ease);
}
.partner-card:hover{ transform:translateY(-4px); box-shadow:0 12px 30px rgba(0,0,0,.3); }
.partner-card:hover img{ filter:grayscale(0); opacity:1; }

/* ---------- Reservation ---------- */
.reserve{ background:var(--bg-2); }
.reserve-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.reserve-copy p{ color:var(--muted); margin-top:1rem; font-size:1.05rem; }
.reserve-points{ margin:1.8rem 0; display:grid; gap:.7rem; }
.reserve-points li{ display:flex; align-items:center; gap:.7rem; color:var(--text); }
.reserve-points span{
  width:22px; height:22px; border-radius:50%; background:rgba(92,187,79,.15);
  color:var(--green-bright); display:grid; place-content:center; font-size:.72rem; flex:none;
}
.reserve-direct{ margin-top:1.6rem; }

/* Booking partner cards (shown in place of the form) */
.reserve-book{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.book-card{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.8rem;
  background:#fff; border-radius:14px; padding:22px 18px; min-height:124px; text-decoration:none;
  box-shadow:0 10px 28px -12px rgba(0,0,0,.6);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.book-card img{ max-height:42px; max-width:78%; width:auto; object-fit:contain; }
.book-cta{
  font-size:.74rem; letter-spacing:.04em; font-weight:600; text-transform:uppercase;
  color:#3f7d34; display:inline-flex; align-items:center; gap:.3rem;
}
.book-cta .arr{ transition:transform .35s var(--ease); }
.book-card:hover{ transform:translateY(-5px); box-shadow:0 18px 36px -14px rgba(0,0,0,.7); }
.book-card:hover .arr{ transform:translate(2px,-2px); }

.reserve-form{
  background:var(--panel); border:1px solid var(--line);
  border-radius:var(--radius); padding:clamp(1.5rem,3vw,2.4rem);
  box-shadow:0 30px 60px -40px rgba(0,0,0,.9);
}
.field{ margin-bottom:1.1rem; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field label{ display:block; font-size:.8rem; letter-spacing:.05em; color:var(--muted); margin-bottom:.4rem; text-transform:uppercase; }
.field .opt{ text-transform:none; letter-spacing:0; font-size:.78rem; opacity:.7; }
.field input, .field select, .field textarea{
  width:100%; background:var(--bg); border:1px solid var(--line); color:var(--text);
  padding:.8rem .9rem; border-radius:9px; font-family:var(--sans); font-size:.98rem;
  transition:border-color .3s, box-shadow .3s;
}
.field input::placeholder, .field textarea::placeholder{ color:#6f7268; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--green); box-shadow:0 0 0 3px rgba(92,187,79,.15);
}
.field input.invalid, .field select.invalid{ border-color:#d9534f; box-shadow:0 0 0 3px rgba(217,83,79,.15); }
.field textarea{ resize:vertical; }
.reserve-form .btn{ margin-top:.4rem; }
.form-hint{ text-align:center; font-size:.82rem; color:var(--muted); margin-top:.9rem; }
.form-msg{ text-align:center; font-size:.92rem; margin-top:.6rem; min-height:1.2em; }
.form-msg.ok{ color:var(--green-bright); }
.form-msg.err{ color:#e07b77; }

/* color-scheme for native date/time pickers */
.field input[type="date"], .field input[type="time"]{ color-scheme:dark; }

/* ---------- Visit ---------- */
.visit{ background:var(--bg); }
.visit-grid{ display:grid; grid-template-columns:1fr 1.3fr; gap:clamp(2rem,5vw,3.5rem); }
.info-block{ padding-bottom:1.5rem; margin-bottom:1.5rem; border-bottom:1px solid var(--line); }
.info-block:last-of-type{ border-bottom:none; }
.info-block h3{ font-size:1.05rem; color:var(--green-bright); margin-bottom:.4rem;
  font-family:var(--sans); text-transform:uppercase; letter-spacing:.12em; font-weight:500; }
.info-block p{ color:var(--text); font-size:1.08rem; }
.info-block a:hover{ color:var(--green-bright); }
.visit-socials{ display:flex; gap:1rem; }
.visit-socials a{
  font-size:.82rem; letter-spacing:.05em; text-transform:uppercase; color:var(--muted);
  border:1px solid var(--line); padding:.5rem 1rem; border-radius:50px; transition:.3s;
}
.visit-socials a:hover{ color:var(--cream); border-color:var(--green); }
.visit-map{ position:relative; border-radius:var(--radius); overflow:hidden; min-height:380px; border:1px solid var(--line); background:var(--bg-3); }
.visit-map iframe{ position:relative; z-index:2; width:100%; height:100%; min-height:380px; border:0; filter:grayscale(.3) contrast(1.05); }
.map-fallback{
  position:absolute; inset:0; z-index:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:.4rem; text-align:center;
  background:
    linear-gradient(135deg, rgba(47,125,50,.18), rgba(14,15,13,.5)),
    repeating-linear-gradient(45deg, rgba(244,241,232,.03) 0 14px, transparent 14px 28px);
  color:var(--cream); transition:background .3s;
}
.map-fallback span{ font-family:var(--serif); font-size:1.4rem; color:var(--green-bright); }
.map-fallback small{ color:var(--muted); }
.map-fallback:hover{ background:linear-gradient(135deg, rgba(47,125,50,.28), rgba(14,15,13,.55)); }

/* ---------- Footer ---------- */
.footer{ background:var(--bg-3); padding-top:clamp(3rem,6vw,5rem); border-top:1px solid var(--line); }
.footer-inner{ display:grid; grid-template-columns:1.3fr 1fr 1.2fr; gap:2.5rem; padding-bottom:3rem; }
.footer-brand img{ height:46px; margin-bottom:1rem; }
.footer-brand p{ color:var(--muted); font-family:var(--serif); font-style:italic; font-size:1.15rem; }
.footer-nav{ display:flex; flex-direction:column; gap:.7rem; }
.footer-nav a{ color:var(--muted); transition:color .3s; width:fit-content; }
.footer-nav a:hover{ color:var(--green-bright); }
.footer-contact{ display:flex; flex-direction:column; gap:.7rem; }
.footer-contact a, .footer-contact span{ color:var(--muted); }
.footer-contact a:hover{ color:var(--green-bright); }
.footer-bottom{
  border-top:1px solid var(--line); padding:1.4rem 0;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem;
  width:min(var(--container),92%); margin-inline:auto;
  font-size:.84rem; color:var(--muted);
}

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed; inset:0; z-index:1500; display:none;
  background:rgba(7,8,7,.95); align-items:center; justify-content:center;
  padding:4vmin;
}
.lightbox.open{ display:flex; animation:lbfade .3s ease; }
@keyframes lbfade{ from{ opacity:0; } to{ opacity:1; } }
.lb-stage{ max-width:92vw; max-height:88vh; display:flex; }
.lb-stage img, .lb-stage video{
  max-width:92vw; max-height:88vh; border-radius:8px; object-fit:contain;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.9);
}
.lb-close, .lb-prev, .lb-next{
  position:fixed; z-index:1600; color:var(--cream); font-size:2rem;
  width:54px; height:54px; border-radius:50%;
  background:rgba(255,255,255,.07); display:grid; place-content:center;
  transition:background .3s, transform .3s;
}
.lb-close:hover, .lb-prev:hover, .lb-next:hover{ background:var(--green); color:#0c1a0b; }
.lb-close{ top:20px; right:20px; }
.lb-prev{ left:20px; top:50%; transform:translateY(-50%); }
.lb-next{ right:20px; top:50%; transform:translateY(-50%); }
.lb-prev:hover{ transform:translateY(-50%) scale(1.08); }
.lb-next:hover{ transform:translateY(-50%) scale(1.08); }

/* ---------- Back to top + WhatsApp float ---------- */
#to-top{
  position:fixed; right:22px; bottom:22px; z-index:900;
  width:46px; height:46px; border-radius:50%;
  background:var(--green); color:#0c1a0b; font-size:1.2rem; font-weight:700;
  box-shadow:0 10px 24px -10px rgba(92,187,79,.8);
  opacity:0; visibility:hidden; transform:translateY(12px);
  transition:.4s var(--ease);
}
#to-top.show{ opacity:1; visibility:visible; transform:none; }
#to-top:hover{ background:var(--green-bright); transform:translateY(-3px); }

.wa-float{
  position:fixed; right:22px; bottom:78px; z-index:900;
  width:52px; height:52px; border-radius:50%;
  background:#25D366; color:#fff; display:grid; place-content:center;
  box-shadow:0 10px 26px -8px rgba(37,211,102,.7);
  transition:transform .35s var(--ease);
}
.wa-float:hover{ transform:scale(1.08) translateY(-2px); }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .about-grid{ grid-template-columns:1fr; }
  .about-images{ max-width:520px; margin-inline:auto; }
  .reserve-grid, .visit-grid{ grid-template-columns:1fr; }
  .visit-map{ min-height:320px; }
  .footer-inner{ grid-template-columns:1fr 1fr; }
}

@media (max-width:820px){
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(78%, 320px);
    background:var(--bg-2); border-left:1px solid var(--line);
    transform:translateX(100%); transition:transform .4s var(--ease);
    display:flex; align-items:center; padding:5rem 2rem;
    box-shadow:-20px 0 60px -30px rgba(0,0,0,.9);
  }
  .nav.open{ transform:translateX(0); }
  .nav ul{ flex-direction:column; align-items:flex-start; gap:1.6rem; width:100%; }
  .nav a{ font-size:1.05rem; }
  .nav-cta{ margin-top:.6rem; }
  .nav-cta .btn{ padding:.8rem 1.8rem; }
  .nav-toggle{ display:block; }
  .lang-switch{ margin-left:auto; }
  body.nav-open{ overflow:hidden; }
  .exp-grid{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; }
  .services-list{ grid-template-columns:1fr; max-width:480px; }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:180px; }
  .g-wide{ grid-column:span 2; }
  .menu-list{ grid-template-columns:1fr; gap:1.4rem; }
  .partner-grid{ grid-template-columns:repeat(2,1fr); }
}

@media (max-width:540px){
  .hero-inner{ padding-top:6rem; }
  .hero-actions .btn{ flex:1; }
  .about-img-main{ height:380px; }
  .about-stats{ gap:1.2rem 1.8rem; }
  .field-row{ grid-template-columns:1fr; }
  .footer-inner{ grid-template-columns:1fr; gap:2rem; }
  .footer-bottom{ flex-direction:column; text-align:center; }
  .gallery-grid{ gap:10px; grid-auto-rows:150px; }
  .partner-grid{ gap:12px; }
  .partner-card{ min-height:80px; padding:16px; }
  .partner-card img{ max-height:42px; }
  .marquee-track span{ font-size:1.1rem; }
  .lb-prev{ left:8px; } .lb-next{ right:8px; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}
