/* =========================================================
   Cabana Ross-A — A-frame, dark & cinematic
   Palette: noapte charcoal · cedru amber · apus ember · ceata cream
   ========================================================= */

:root {
  --noapte:   #13151a;
  --noapte-2: #0d0f13;
  --carbon:   #1b1e25;
  --carbon-2: #23272f;
  --cedru:    #cf9060;
  --cedru-2:  #e3b487;
  --apus:     #e2623c;
  --apus-2:   #ef7a4f;
  --ceata:    #f3ede4;
  --ceata-2:  #e9e0d2;
  --ink:      #22242a;   /* text on cream */
  --ink-soft: #5f5b53;
  --mist:     #b3b7c0;   /* muted on dark */
  --mist-2:   #83879044;
  --line:     rgba(255,255,255,.10);
  --line-cream: rgba(34,36,42,.12);

  --ff-display: "Fraunces", Georgia, "Times New Roman", serif;
  --ff-body: "Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --wrap: 1200px;
  --gutter: clamp(1.15rem, 4vw, 3rem);
  --radius: 14px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  font-family: var(--ff-body);
  background: var(--noapte);
  color: var(--ceata);
  line-height: 1.7;
  font-size: 1.0625rem;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-variant-ligatures: no-common-ligatures;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }

h1, h2, h3 { font-family: var(--ff-display); font-weight: 400; line-height: 1.05; margin: 0; text-wrap: balance; letter-spacing: -.02em; }

.wrap { width: 100%; max-width: var(--wrap); margin-inline: auto; padding-inline: var(--gutter); }
section { position: relative; }

/* ---------- Reusable eyebrow + section title ---------- */
.eyebrow {
  font-family: var(--ff-body);
  font-size: .74rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--cedru-2);
  display: inline-flex;
  align-items: center;
  gap: .6em;
  margin: 0 0 1.1rem;
}
.eyebrow::before {
  content: "";
  width: 0; height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 10px solid var(--cedru);
}
.section-title { font-size: clamp(2rem, 5vw, 3.4rem); }
.section-lead { color: var(--mist); max-width: 60ch; margin: 1.2rem 0 0; }

.on-cream .eyebrow { color: #a9713f; }
.on-cream .eyebrow::before { border-bottom-color: var(--apus); }
.on-cream .section-lead { color: var(--ink-soft); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .6em;
  padding: .95rem 1.7rem;
  border-radius: 100px;
  font-weight: 600; font-size: .98rem; letter-spacing: .01em;
  border: 1px solid transparent;
  transition: transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
  min-height: 48px;
}
.btn svg { width: 20px; height: 20px; flex: none; }
.btn--ember { background: var(--apus); color: #fff; box-shadow: 0 10px 30px -12px rgba(226,98,60,.7); }
.btn--ember:hover { background: var(--apus-2); transform: translateY(-2px); box-shadow: 0 16px 40px -12px rgba(226,98,60,.8); }
.btn--ghost { background: rgba(255,255,255,.06); color: #fff; border-color: rgba(255,255,255,.28); backdrop-filter: blur(6px); }
.btn--ghost:hover { background: rgba(255,255,255,.14); transform: translateY(-2px); }
.btn--dark { background: var(--ink); color: var(--ceata); }
.btn--dark:hover { background: #34373f; transform: translateY(-2px); }
@media (prefers-reduced-motion: reduce) { .btn:hover { transform: none; } }

/* ---------- Header / nav ---------- */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 60;
  transition: background .4s var(--ease), backdrop-filter .4s var(--ease), border-color .4s var(--ease);
  border-bottom: 1px solid transparent;
}
.site-header.scrolled {
  background: rgba(15,17,21,.82);
  backdrop-filter: blur(14px) saturate(120%);
  border-bottom-color: var(--line);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 74px; }
.brand { display: inline-flex; align-items: center; gap: .6rem; font-family: var(--ff-display); font-size: 1.28rem; letter-spacing: -.01em; color: #fff; }
.brand__peak { width: 20px; height: 18px; flex: none; color: var(--cedru); }
.brand em { font-style: italic; }
.nav__links { display: none; gap: 2rem; align-items: center; }
.nav__links a { font-size: .92rem; color: var(--ceata); opacity: .82; transition: opacity .2s, color .2s; letter-spacing: .01em; }
.nav__links a:hover { opacity: 1; color: var(--cedru-2); }
.nav__cta { display: none; }
@media (min-width: 900px) {
  .nav__links { display: flex; }
  .nav__cta { display: inline-flex; }
}

/* ---------- Hero ---------- */
.hero { min-height: 100svh; display: grid; align-items: end; position: relative; isolation: isolate; overflow: hidden; }
.hero__img { position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%; object-fit: cover; object-position: 50% 40%; }
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(to top, rgba(11,13,17,.94) 2%, rgba(11,13,17,.35) 42%, rgba(11,13,17,.55) 100%);
}
.hero__inner { padding-block: clamp(3rem, 12vh, 8rem) clamp(3rem, 9vh, 6rem); }
.hero__loc { display: inline-flex; align-items: center; gap: .55rem; font-size: .82rem; letter-spacing: .22em; text-transform: uppercase; font-weight: 600; color: var(--cedru-2); margin-bottom: 1.3rem; }
.hero__loc svg { width: 15px; height: 15px; }
.hero h1 { font-size: clamp(3.1rem, 12.5vw, 8.5rem); color: #fff; }
.hero h1 em { font-style: italic; color: var(--cedru-2); }
.hero__sub { font-size: clamp(1.05rem, 2.3vw, 1.35rem); color: var(--ceata); opacity: .9; max-width: 34ch; margin: 1.4rem 0 0; font-weight: 300; }
.hero__actions { display: flex; flex-wrap: wrap; gap: .85rem; margin-top: 2.2rem; }
.hero__scroll { position: absolute; left: 50%; bottom: 1.4rem; transform: translateX(-50%); z-index: 2; color: #fff; opacity: .6; display: grid; place-items: center; gap: .4rem; font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; }
.hero__scroll span { width: 1px; height: 34px; background: linear-gradient(var(--cedru-2), transparent); animation: scrolldrop 2.2s var(--ease) infinite; }
@keyframes scrolldrop { 0% { transform: scaleY(0); transform-origin: top; } 45% { transform: scaleY(1); transform-origin: top; } 55% { transform: scaleY(1); transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }

/* ---------- Intro strip ---------- */
.intro { background: var(--noapte-2); padding-block: clamp(4.5rem, 11vw, 8rem); text-align: center; }
.intro__mark { width: 46px; height: 40px; margin: 0 auto 2rem; color: var(--cedru); }
.intro p { font-family: var(--ff-display); font-weight: 300; font-size: clamp(1.5rem, 4.2vw, 2.7rem); line-height: 1.3; max-width: 20ch; margin: 0 auto; color: var(--ceata); }
.intro p em { font-style: italic; color: var(--cedru-2); }
.facts { display: flex; flex-wrap: wrap; justify-content: center; gap: .75rem clamp(1.5rem, 5vw, 3.5rem); margin-top: 3rem; }
.facts .fact { display: inline-flex; flex-direction: column; align-items: center; min-width: 120px; }
.facts .fact b { font-family: var(--ff-display); font-size: 1.8rem; color: #fff; font-weight: 500; }
.facts .fact span { font-size: .8rem; letter-spacing: .06em; color: var(--mist); text-transform: uppercase; }
.facts .fact + .fact { position: relative; }

/* ---------- Facilities ---------- */
.facilities { background: var(--carbon); padding-block: clamp(4.5rem, 11vw, 8rem); }
.facilities__head { max-width: var(--wrap); }
.fac-grid { display: grid; grid-template-columns: 1fr; gap: 1px; margin-top: 3rem; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
@media (min-width: 620px) { .fac-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 940px) { .fac-grid { grid-template-columns: repeat(3, 1fr); } }
.fac {
  background: var(--carbon-2);
  padding: 2.1rem 1.8rem;
  display: flex; flex-direction: column; gap: .9rem;
  transition: background .3s var(--ease);
}
.fac:hover { background: #2a2f38; }
.fac__ico { width: 40px; height: 40px; color: var(--cedru); }
.fac__ico svg { width: 100%; height: 100%; }
.fac h3 { font-size: 1.32rem; color: #fff; }
.fac p { margin: 0; font-size: .95rem; color: var(--mist); line-height: 1.6; }

/* ---------- Gallery ---------- */
.gallery { background: var(--noapte); padding-block: clamp(4.5rem, 11vw, 8rem); }
.gal-grid { columns: 2; column-gap: clamp(.6rem, 1.5vw, 1rem); margin-top: 3rem; }
@media (min-width: 720px) { .gal-grid { columns: 3; } }
@media (min-width: 1040px) { .gal-grid { columns: 4; } }
.gal { position: relative; overflow: hidden; border-radius: 10px; margin: 0 0 clamp(.6rem, 1.5vw, 1rem); background: var(--carbon-2); cursor: zoom-in; break-inside: avoid; }
.gal img { width: 100%; height: auto; display: block; transition: transform .7s var(--ease); }
.gal:hover img { transform: scale(1.05); }
.gal::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(to top, rgba(11,13,17,.55), transparent 55%); opacity: 0; transition: opacity .4s; }
.gal:hover::after { opacity: 1; }
.gal figcaption { position: absolute; left: 1rem; bottom: .85rem; z-index: 2; pointer-events: none; font-size: .82rem; letter-spacing: .05em; color: #fff; opacity: 0; transform: translateY(6px); transition: opacity .4s, transform .4s; }
.gal:hover figcaption { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .gal:hover img { transform: none; } }

/* ---------- Panorama band ---------- */
.band { position: relative; min-height: 62vh; display: grid; place-items: center; text-align: center; overflow: hidden; isolation: isolate; }
.band img { position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%; object-fit: cover; object-position: 50% 60%; }
.band::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(to bottom, rgba(11,13,17,.55), rgba(11,13,17,.35)); }
.band__quote { font-family: var(--ff-display); font-style: italic; font-weight: 300; font-size: clamp(1.7rem, 5vw, 3.4rem); color: #fff; max-width: 18ch; padding-inline: var(--gutter); text-shadow: 0 2px 30px rgba(0,0,0,.4); }
@media (min-width: 900px) { .band { background-attachment: fixed; } }

/* ---------- Surroundings (cream) ---------- */
.on-cream { background: var(--ceata); color: var(--ink); }
.surround { padding-block: clamp(4.5rem, 11vw, 8rem); }
.surround__grid { display: grid; gap: 3rem; margin-top: 3rem; }
@media (min-width: 900px) { .surround__grid { grid-template-columns: .9fr 1.1fr; align-items: start; } }
.surround__lead h2 { color: var(--ink); }
.surround__note { margin-top: 1.4rem; color: var(--ink-soft); font-size: 1rem; max-width: 40ch; }
.surround__badge { display: inline-flex; align-items: center; gap: .5rem; margin-top: 2rem; padding: .7rem 1.1rem; background: #fff; border: 1px solid var(--line-cream); border-radius: 100px; font-size: .9rem; font-weight: 600; color: var(--ink); }
.surround__badge svg { width: 18px; height: 18px; color: var(--apus); }

.places { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--line-cream); }
.place { display: flex; align-items: baseline; gap: 1.1rem; padding: 1.05rem .2rem; border-bottom: 1px solid var(--line-cream); transition: padding-left .3s var(--ease); }
.place:hover { padding-left: .6rem; }
.place__km { font-family: var(--ff-display); font-size: 1.15rem; font-weight: 500; color: var(--apus); min-width: 4.7rem; flex: none; }
.place__km small { font-size: .72rem; color: var(--ink-soft); font-family: var(--ff-body); font-weight: 500; }
.place__name { font-weight: 600; color: var(--ink); font-size: 1.05rem; }
.place__desc { display: block; font-weight: 400; color: var(--ink-soft); font-size: .88rem; margin-top: .1rem; }

/* ---------- Booking / info ---------- */
.book { background: var(--noapte-2); padding-block: clamp(4.5rem, 11vw, 8rem); }
.book__grid { display: grid; gap: 2rem; align-items: center; }
@media (min-width: 880px) { .book__grid { grid-template-columns: 1.1fr .9fr; gap: 4rem; } }
.book h2 { font-size: clamp(2rem, 5vw, 3.2rem); color: #fff; }
.book h2 em { font-style: italic; color: var(--cedru-2); }
.book__lead { color: var(--mist); margin: 1.2rem 0 2rem; max-width: 46ch; }
.book__actions { display: flex; flex-wrap: wrap; gap: .85rem; }
.info-card { background: var(--carbon); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.9rem; display: grid; gap: 1.15rem; }
.info-row { display: flex; align-items: center; gap: 1rem; }
.info-row svg { width: 22px; height: 22px; color: var(--cedru); flex: none; }
.info-row .k { font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; color: var(--mist); }
.info-row .v { font-family: var(--ff-display); font-size: 1.18rem; color: #fff; }
.info-row .v a:hover { color: var(--cedru-2); }
.info-card hr { border: 0; border-top: 1px solid var(--line); margin: 0; }

/* ---------- Map ---------- */
.map-section { background: var(--noapte); padding-block: clamp(3.5rem, 8vw, 6rem); }
.map-wrap { position: relative; margin-top: 2.4rem; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); aspect-ratio: 16/8; background: var(--carbon-2); }
@media (max-width: 640px){ .map-wrap { aspect-ratio: 4/5; } }
.map-ph { position: absolute; inset: 0; display: grid; place-content: center; justify-items: center; gap: 1.1rem; text-align: center; padding: 2rem;
  background:
    radial-gradient(circle at 30% 20%, rgba(207,144,96,.10), transparent 55%),
    repeating-linear-gradient(-38deg, rgba(255,255,255,.03) 0 2px, transparent 2px 26px),
    var(--carbon-2);
}
.map-ph svg.pin { width: 34px; height: 34px; color: var(--cedru); }
.map-ph p { margin: 0; color: var(--ceata); font-size: 1rem; }
.map-ph p b { font-family: var(--ff-display); font-size: 1.3rem; display: block; margin-bottom: .2rem; font-weight: 500; }
.map-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* ---------- Footer ---------- */
.site-footer { background: var(--noapte-2); border-top: 1px solid var(--line); padding-block: clamp(3rem, 7vw, 4.5rem) 2rem; }
.foot-top { display: grid; gap: 2.4rem; }
@media (min-width: 780px){ .foot-top { grid-template-columns: 1.4fr 1fr 1fr; } }
.foot-brand .brand { font-size: 1.5rem; margin-bottom: 1rem; }
.foot-brand p { color: var(--mist); font-size: .92rem; max-width: 34ch; margin: 0; }
.foot-col h4 { font-family: var(--ff-body); font-size: .76rem; letter-spacing: .16em; text-transform: uppercase; color: var(--cedru-2); margin: 0 0 1.1rem; }
.foot-col a, .foot-col p { display: block; color: var(--mist); font-size: .95rem; margin: 0 0 .6rem; transition: color .2s; }
.foot-col a:hover { color: #fff; }
.socials { display: flex; gap: .7rem; margin-top: .3rem; }
.socials a { width: 42px; height: 42px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 50%; color: var(--ceata); transition: background .25s, border-color .25s, transform .25s; }
.socials a:hover { background: var(--cedru); color: var(--noapte); border-color: var(--cedru); transform: translateY(-2px); }
.socials svg { width: 19px; height: 19px; }

.legal { margin-top: 3rem; padding-top: 1.6rem; border-top: 1px solid var(--line); display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem; }
.legal p { margin: 0; font-size: .74rem; color: #7c8089; line-height: 1.6; }
.legal a { color: #9a9ea7; text-decoration: underline; text-underline-offset: 2px; }
.legal a:hover { color: var(--cedru-2); }
.anpc { display: flex; gap: .7rem; align-items: center; }
.anpc a { display: inline-flex; }
.anpc img { height: 40px; width: auto; opacity: .8; transition: opacity .2s; }
.anpc a:hover img { opacity: 1; }

/* ---------- Floating WhatsApp ---------- */
.wa-float { position: fixed; right: 1.15rem; bottom: 1.15rem; z-index: 80; width: 58px; height: 58px; border-radius: 50%; background: #25d366; display: grid; place-items: center; box-shadow: 0 10px 30px -8px rgba(0,0,0,.5); transition: transform .25s var(--ease); }
.wa-float svg { width: 30px; height: 30px; color: #fff; }
.wa-float::before { content: ""; position: absolute; inset: 0; border-radius: 50%; background: #25d366; z-index: -1; animation: wapulse 2.4s var(--ease) infinite; }
.wa-float:hover { transform: scale(1.08); }
@keyframes wapulse { 0% { transform: scale(1); opacity: .55; } 70%, 100% { transform: scale(1.9); opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .wa-float::before { animation: none; } .wa-float:hover { transform: none; } }

/* ---------- Lightbox ---------- */
.lb { position: fixed; inset: 0; z-index: 100; background: rgba(9,10,13,.94); display: none; place-items: center; padding: 2rem; opacity: 0; transition: opacity .3s; backdrop-filter: blur(4px); }
.lb.open { display: grid; opacity: 1; }
.lb img { max-width: min(94vw, 1200px); max-height: 88vh; border-radius: 8px; object-fit: contain; box-shadow: 0 30px 80px -20px rgba(0,0,0,.8); }
.lb__close { position: absolute; top: 1.1rem; right: 1.3rem; width: 46px; height: 46px; border-radius: 50%; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); color: #fff; display: grid; place-items: center; padding: 0; }
.lb__close svg { width: 20px; height: 20px; display: block; }
.lb__close:hover { background: rgba(255,255,255,.2); }
.lb__nav { position: absolute; top: 50%; transform: translateY(-50%); width: 50px; height: 50px; border-radius: 50%; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); color: #fff; display: grid; place-items: center; }
.lb__nav:hover { background: rgba(255,255,255,.2); }
.lb__nav.prev { left: 1rem; } .lb__nav.next { right: 1rem; }
@media (max-width: 640px){ .lb__nav { top: auto; bottom: 1rem; transform: none; } .lb__nav.prev { left: 30%; } .lb__nav.next { right: 30%; } }

/* ---------- Scroll reveal ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; } .reveal.d2 { transition-delay: .16s; } .reveal.d3 { transition-delay: .24s; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }
