/* =================================================================
   REFRESH A-FRAME REMEȚI — styles.css
   Paletă: lemn cald · teracotă · verde pădure · cremă
   ================================================================= */

/* ---------- Tokens ---------- */
:root{
  --cream:#f5efe5;
  --paper:#fffefb;
  --ink:#252820;
  --ink-soft:#5e6356;
  --muted:#8d8c7e;
  --forest:#2c352a;
  --forest-deep:#212a1f;
  --terra:#bd6240;
  --terra-dk:#a3502f;
  --gold:#d99a3c;
  --sand:#ece1cf;
  --sand-2:#e3d4bd;
  --wa:#25d366;
  --line:rgba(37,40,32,.12);
  --line-light:rgba(255,255,255,.20);

  --sh-sm:0 2px 10px rgba(30,30,20,.06);
  --sh-md:0 16px 44px -20px rgba(30,30,20,.30);
  --sh-lg:0 34px 90px -34px rgba(18,22,12,.55);

  --r:16px; --r-sm:10px; --r-lg:28px; --pill:999px;
  --maxw:1200px;
  --hh:74px; /* header height */

  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ scroll-behavior:smooth; scroll-padding-top:calc(var(--hh) + 12px); -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:1.02rem;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,iframe{ display:block; max-width:100%; }
img{ height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
ul{ list-style:none; padding:0; }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.08; letter-spacing:-.01em; }
::selection{ background:var(--terra); color:#fff; }
:focus-visible{ outline:2.5px solid var(--terra); outline-offset:3px; border-radius:4px; }

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:24px; }
.section{ padding:clamp(66px,9vw,124px) 0; }
.section--tint{ background:var(--sand); }
.section--dark{ background:var(--forest); color:#e9e6dc; }
.section--dark .section__title{ color:#fff; }

.section__head{ max-width:680px; margin-bottom:clamp(34px,5vw,60px); }
.section__head--center{ margin-inline:auto; text-align:center; }
.eyebrow{
  font-family:var(--sans); font-size:.78rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--terra);
  margin-bottom:14px;
}
.eyebrow--light{ color:rgba(255,255,255,.82); }
.section__title{ font-size:clamp(2rem,4.2vw,3.25rem); }
.section__sub{ margin-top:16px; color:var(--ink-soft); font-size:1.08rem; max-width:54ch; }
.section--dark .section__sub{ color:rgba(233,230,220,.8); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  padding:.95em 1.7em; border-radius:var(--pill);
  font-family:var(--sans); font-weight:600; font-size:.98rem; letter-spacing:.01em;
  border:1.6px solid transparent; cursor:pointer; white-space:nowrap;
  transition:transform .25s var(--ease), background .25s, box-shadow .25s, color .25s, border-color .25s;
}
.btn .ico{ width:1.15em; height:1.15em; flex:0 0 auto; }
.btn--primary{ background:var(--terra); color:#fff; box-shadow:0 10px 26px -12px rgba(189,98,64,.8); }
.btn--primary:hover{ background:var(--terra-dk); transform:translateY(-2px); box-shadow:0 16px 34px -12px rgba(189,98,64,.85); }
.btn--whatsapp{ background:var(--wa); color:#06301c; font-weight:700; }
.btn--whatsapp:hover{ background:#1ebe5a; transform:translateY(-2px); box-shadow:0 16px 34px -16px rgba(37,211,102,.9); }
.btn--ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.55); }
.btn--ghost:hover{ background:rgba(255,255,255,.12); border-color:#fff; }
.btn--sm{ padding:.6em 1.15em; font-size:.9rem; }
.btn--block{ width:100%; }

/* ---------- Header / Nav ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  color:#fff;
  background:linear-gradient(to bottom, rgba(15,18,12,.55), rgba(15,18,12,0));
  transition:background .35s var(--ease), color .35s, box-shadow .35s, backdrop-filter .35s;
}
.site-header.is-scrolled{
  background:rgba(255,254,251,.92);
  backdrop-filter:blur(10px);
  color:var(--ink);
  box-shadow:0 1px 0 var(--line), var(--sh-sm);
}
.nav{ display:flex; align-items:center; gap:14px; height:var(--hh); }

.brand{ display:inline-flex; align-items:center; gap:11px; color:inherit; margin-right:auto; }
.brand__mark{ width:34px; height:34px; flex:0 0 auto; color:currentColor; }
.site-header.is-scrolled .brand__mark{ color:var(--terra); }
.brand__text{ font-family:var(--serif); font-size:1.32rem; font-weight:600; line-height:1; display:flex; flex-direction:column; gap:3px; letter-spacing:.01em; }
.brand__sub{ font-family:var(--sans); font-size:.62rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; opacity:.72; }

.nav__menu{ display:flex; align-items:center; gap:30px; }
.nav__menu a{ font-size:.96rem; font-weight:500; position:relative; transition:opacity .2s; }
.nav__menu a:not(.btn)::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background:var(--terra); transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease);
}
.nav__menu a:not(.btn):hover::after{ transform:scaleX(1); }
.nav__cta{ color:#fff !important; }

.nav__toggle{ display:none; width:44px; height:44px; flex-direction:column; justify-content:center; gap:6px; padding:0 9px; }
.nav__toggle span{ height:2px; border-radius:2px; background:currentColor; transition:transform .3s var(--ease), opacity .25s; }
.nav__toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; color:#fff; isolation:isolate; }
.hero__bg{ position:absolute; inset:0; z-index:-2; background-size:cover; background-position:center 35%; }
.hero__veil{
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(to top, rgba(12,15,9,.82) 0%, rgba(12,15,9,.30) 42%, rgba(12,15,9,.12) 70%, rgba(12,15,9,.35) 100%);
}
.hero__inner{ padding-block:clamp(110px,16vh,180px) clamp(48px,8vh,90px); max-width:880px; }
.hero__title{ font-size:clamp(2.7rem,6.6vw,5.2rem); line-height:1.02; text-shadow:0 2px 30px rgba(0,0,0,.35); }
.hero__title em{ font-style:italic; color:#f0c9a0; }
.hero__lead{ margin-top:22px; max-width:46ch; font-size:clamp(1.05rem,1.7vw,1.28rem); color:rgba(255,255,255,.9); }
.hero__actions{ margin-top:34px; display:flex; flex-wrap:wrap; gap:14px; }
.hero__facts{
  margin-top:42px; display:flex; flex-wrap:wrap; align-items:center; gap:14px 30px;
  font-size:.96rem; color:rgba(255,255,255,.88);
  border-top:1px solid rgba(255,255,255,.22); padding-top:24px;
}
.hero__facts li{ display:flex; align-items:center; gap:8px; }
.hero__facts strong{ font-family:var(--serif); font-size:1.35rem; font-weight:600; color:#fff; }
.hero__rating .stars{ color:var(--gold); margin-right:2px; }
.hero__rating span{ opacity:.75; }
.hero__scroll{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:1;
  width:26px; height:42px; border:2px solid rgba(255,255,255,.6); border-radius:14px;
}
.hero__scroll span{ position:absolute; top:8px; left:50%; width:4px; height:8px; margin-left:-2px; border-radius:2px; background:#fff; animation:scrolldot 1.8s var(--ease) infinite; }
@keyframes scrolldot{ 0%{opacity:0;transform:translateY(0)} 40%{opacity:1} 80%{opacity:0;transform:translateY(14px)} 100%{opacity:0} }

/* ---------- Intro ---------- */
.intro__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,6vw,84px); align-items:center; }
.intro__media{ position:relative; }
.intro__media img{ width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:var(--r-lg); box-shadow:var(--sh-md); }
.intro__badge{
  position:absolute; right:-18px; bottom:30px; background:var(--paper); color:var(--ink);
  padding:18px 22px; border-radius:var(--r); box-shadow:var(--sh-md); text-align:center; line-height:1;
}
.intro__badge-num{ display:block; font-family:var(--serif); font-size:1.9rem; color:var(--terra); font-weight:600; }
.intro__badge-txt{ display:block; margin-top:6px; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.intro__text p{ color:var(--ink-soft); margin-top:18px; }
.intro__text > .eyebrow{ margin-top:0; }
.intro__list{ margin-top:24px; display:grid; gap:12px; }
.intro__list li{ position:relative; padding-left:30px; color:var(--ink); }
.intro__list li::before{
  content:""; position:absolute; left:0; top:.5em; width:14px; height:14px;
  background:var(--terra); clip-path:polygon(50% 0,100% 100%,0 100%); /* triunghi A-frame */
}
.intro__sign{ margin-top:26px; font-family:var(--serif); font-style:italic; font-size:1.2rem; color:var(--ink); }
.intro__sign span{ color:var(--terra); }

/* ---------- Facilități ---------- */
.features{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.feature{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r);
  padding:30px 26px; transition:transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.feature:hover{ transform:translateY(-6px); box-shadow:var(--sh-md); border-color:transparent; }
.feature__ico{ display:inline-flex; width:54px; height:54px; align-items:center; justify-content:center;
  background:var(--sand-2); color:var(--terra-dk); border-radius:14px; margin-bottom:18px; }
.feature__ico svg{ width:28px; height:28px; }
.feature h3{ font-size:1.22rem; margin-bottom:8px; }
.feature p{ color:var(--ink-soft); font-size:.96rem; }

/* ---------- Band (highlight) ---------- */
.band{ position:relative; color:#fff; isolation:isolate; padding:clamp(90px,16vw,180px) 0; text-align:center; }
.band__bg{ position:absolute; inset:0; z-index:-2; background-size:cover; background-position:center; }
.band__veil{ position:absolute; inset:0; z-index:-1; background:linear-gradient(rgba(12,15,9,.45),rgba(12,15,9,.62)); }
.band__inner{ max-width:760px; margin-inline:auto; }
.band__title{ font-size:clamp(2rem,4.6vw,3.4rem); margin-top:6px; text-shadow:0 2px 26px rgba(0,0,0,.4); }
.band__lead{ margin-top:20px; font-size:1.12rem; color:rgba(255,255,255,.9); }

/* ---------- Galerie ---------- */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:210px; gap:14px; grid-auto-flow:dense; }
.gallery__item{ position:relative; overflow:hidden; border-radius:var(--r); padding:0; background:var(--sand-2); }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.gallery__item::after{ content:"⤢"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:1.6rem; color:#fff; background:rgba(20,24,14,.0); opacity:0; transition:opacity .3s, background .3s; }
.gallery__item:hover img{ transform:scale(1.07); }
.gallery__item:hover::after{ opacity:1; background:rgba(20,24,14,.28); }
.gallery__item--tall{ grid-row:span 2; }
.gallery__item--wide{ grid-column:span 2; }

/* ---------- Împrejurimi ---------- */
.surroundings__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,6vw,72px); align-items:center; }
.surroundings__text p{ color:rgba(233,230,220,.85); margin-top:16px; }
.surroundings__text > .eyebrow{ margin-top:0; }
.poi{ margin-top:28px; display:grid; gap:0; }
.poi li{ display:flex; justify-content:space-between; align-items:baseline; gap:16px;
  padding:15px 2px; border-bottom:1px solid rgba(255,255,255,.14); }
.poi__name{ font-family:var(--serif); font-size:1.22rem; color:#fff; }
.poi__dist{ font-size:.9rem; color:rgba(233,230,220,.7); white-space:nowrap; }
.surroundings__note{ margin-top:18px; font-size:.82rem; color:rgba(233,230,220,.55); }
.surroundings__map{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-lg); border:1px solid rgba(255,255,255,.12); }
.surroundings__map iframe{ width:100%; height:430px; border:0; filter:saturate(.92) contrast(1.02); }

/* ---------- Recenzii ---------- */
.reviews__score{ display:flex; flex-wrap:wrap; align-items:center; gap:8px 14px; margin-top:18px; }
.reviews__num{ font-family:var(--serif); font-size:2.4rem; font-weight:600; color:var(--terra); line-height:1; }
.reviews__count{ color:var(--ink-soft); font-size:.96rem; }
.stars{ color:var(--gold); letter-spacing:2px; }
.stars--lg{ font-size:1.5rem; }
.reviews__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.review{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:30px 32px; box-shadow:var(--sh-sm); display:flex; flex-direction:column; gap:14px;
}
.review .stars{ font-size:1.05rem; }
.review blockquote{ font-family:var(--serif); font-size:1.2rem; line-height:1.5; color:var(--ink); }
.review figcaption{ display:flex; flex-direction:column; gap:3px; margin-top:auto; }
.review__name{ font-weight:600; }
.review__src{ font-size:.82rem; color:var(--muted); display:inline-flex; align-items:center; gap:7px; }
.review__src::before{ content:""; width:9px; height:9px; border-radius:50%; }
.review__src--airbnb::before{ background:#ff5a5f; }
.review__src--booking::before{ background:#1a64d4; }

/* ---------- Rezervare ---------- */
.booking__cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.bcard{
  display:flex; flex-direction:column; gap:14px; background:var(--paper);
  border:1px solid var(--line); border-radius:var(--r-lg); padding:34px 30px;
  box-shadow:var(--sh-sm); transition:transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.bcard:hover{ transform:translateY(-6px); box-shadow:var(--sh-md); border-color:transparent; }
.bcard__logo{ font-size:1.5rem; font-weight:700; letter-spacing:-.02em; }
.bcard__logo--booking{ color:#1a64d4; font-family:var(--sans); }
.bcard__logo--airbnb{ color:#ff385c; font-family:var(--sans); text-transform:lowercase; }
.bcard__logo--wa{ color:#1a8a4d; display:inline-flex; align-items:center; gap:10px; font-size:1.4rem; }
.bcard__logo--wa .ico{ width:30px; height:30px; }
.bcard__txt{ color:var(--ink-soft); font-size:.98rem; flex:1; }
.bcard__cta{ font-weight:600; color:var(--terra); transition:gap .25s; }
.bcard:hover .bcard__cta{ color:var(--terra-dk); }
.bcard--wa{ background:linear-gradient(165deg,#eafaf0,#fffefb); }
.booking__price{ margin-top:30px; text-align:center; color:var(--ink-soft); font-size:1.05rem; }
.booking__price strong{ font-family:var(--serif); font-size:1.35rem; color:var(--ink); }

/* ---------- Contact ---------- */
.contact__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(34px,6vw,70px); align-items:start; }
.contact__intro p{ color:var(--ink-soft); margin-top:16px; }
.contact__intro > .eyebrow{ margin-top:0; }
.contact__details{ margin:28px 0; display:grid; gap:16px; }
.contact__details li{ display:flex; align-items:center; gap:14px; font-size:1.02rem; }
.contact__details a:hover{ color:var(--terra); }
.contact__ico{ display:inline-flex; width:44px; height:44px; align-items:center; justify-content:center;
  background:var(--sand); color:var(--terra-dk); border-radius:12px; flex:0 0 auto; }
.contact__ico svg{ width:22px; height:22px; }

.contact__form{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(26px,3.5vw,42px); box-shadow:var(--sh-md); }
.field{ display:flex; flex-direction:column; gap:7px; margin-bottom:18px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field--narrow{ max-width:100%; }
.field label{ font-size:.84rem; font-weight:600; letter-spacing:.04em; color:var(--ink-soft); text-transform:uppercase; }
.field input,.field textarea{
  font-family:var(--sans); font-size:1rem; color:var(--ink);
  background:var(--cream); border:1.5px solid var(--line); border-radius:var(--r-sm);
  padding:13px 15px; transition:border-color .25s, box-shadow .25s, background .25s;
}
.field input::placeholder,.field textarea::placeholder{ color:var(--muted); }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--terra); background:var(--paper); box-shadow:0 0 0 4px rgba(189,98,64,.12); }
.field textarea{ resize:vertical; min-height:108px; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.form-status{ margin-top:14px; font-size:.95rem; min-height:1.2em; }
.form-status.is-error{ color:#b3402a; }
.form-status.is-ok{ color:#1c7d46; font-weight:600; }
.form-status.is-loading{ color:var(--ink-soft); }

/* ---------- Footer ---------- */
.footer{ background:var(--forest-deep); color:rgba(233,230,220,.82); padding-top:clamp(56px,8vw,88px); }
.footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:40px; padding-bottom:48px; }
.brand--light .brand__mark{ color:#e7c8a0; }
.footer__tag{ margin-top:18px; max-width:34ch; color:rgba(233,230,220,.62); font-size:.96rem; }
.footer h4{ font-family:var(--sans); font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:#fff; margin-bottom:16px; }
.footer__links{ display:flex; flex-direction:column; gap:11px; }
.footer__links a,.footer__contact a{ color:rgba(233,230,220,.78); width:fit-content; transition:color .2s; }
.footer__links a:hover,.footer__contact a:hover{ color:#fff; }
.footer__contact{ display:flex; flex-direction:column; gap:11px; }
.footer__social{ display:flex; gap:12px; margin-top:10px; }
.footer__social a{ width:42px; height:42px; display:inline-flex; align-items:center; justify-content:center;
  border:1px solid rgba(255,255,255,.18); border-radius:50%; transition:background .25s, border-color .25s, transform .25s; }
.footer__social a:hover{ background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.4); transform:translateY(-3px); }
.footer__social svg{ width:19px; height:19px; }
.footer__bar{ border-top:1px solid rgba(255,255,255,.12); padding:22px 0; display:flex; flex-wrap:wrap;
  justify-content:space-between; gap:8px; font-size:.86rem; color:rgba(233,230,220,.55); }
.footer__bar .container{ display:contents; }

/* ---------- Floating WhatsApp ---------- */
.fab-wa{
  position:fixed; right:22px; bottom:22px; z-index:55;
  width:58px; height:58px; border-radius:50%; background:var(--wa); color:#fff;
  display:inline-flex; align-items:center; justify-content:center;
  box-shadow:0 12px 30px -8px rgba(37,211,102,.7);
  transition:transform .3s var(--ease), box-shadow .3s;
  animation:fabIn .5s var(--ease) .6s both;
}
.fab-wa svg{ width:30px; height:30px; }
.fab-wa::before{ content:""; position:absolute; inset:0; border-radius:50%; box-shadow:0 0 0 0 rgba(37,211,102,.5); animation:pulse 2.6s infinite; }
.fab-wa:hover{ transform:scale(1.08); }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)} 70%{box-shadow:0 0 0 16px rgba(37,211,102,0)} 100%{box-shadow:0 0 0 0 rgba(37,211,102,0)} }
@keyframes fabIn{ from{opacity:0;transform:translateY(20px) scale(.7)} to{opacity:1;transform:none} }

/* ---------- Lightbox ---------- */
.lightbox{ position:fixed; inset:0; z-index:100; display:none; align-items:center; justify-content:center;
  background:rgba(14,16,10,.92); padding:30px; opacity:0; transition:opacity .3s; }
.lightbox.is-open{ display:flex; opacity:1; }
.lightbox__img{ max-width:90vw; max-height:86vh; border-radius:10px; box-shadow:var(--sh-lg); }
.lightbox__close{ position:absolute; top:18px; right:24px; font-size:2.6rem; line-height:1; color:#fff; opacity:.8; }
.lightbox__close:hover{ opacity:1; }
.lightbox__nav{ position:absolute; top:50%; transform:translateY(-50%); width:56px; height:56px; border-radius:50%;
  background:rgba(255,255,255,.12); color:#fff; font-size:2rem; display:flex; align-items:center; justify-content:center;
  transition:background .25s; }
.lightbox__nav:hover{ background:rgba(255,255,255,.25); }
.lightbox__prev{ left:20px; }
.lightbox__next{ right:20px; }

/* ---------- Reveal on scroll ---------- */
html.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
html.js .reveal.is-visible{ opacity:1; transform:none; }
html.js .reveal:nth-child(2){ transition-delay:.08s; }
html.js .reveal:nth-child(3){ transition-delay:.16s; }
html.js .reveal:nth-child(4){ transition-delay:.24s; }

/* ---------- Comutator de limbă ---------- */
.lang{ position:relative; flex:0 0 auto; }
.lang__btn{ display:inline-flex; align-items:center; gap:6px; padding:7px 11px; border-radius:var(--pill);
  border:1.5px solid currentColor; font-size:.82rem; font-weight:600; letter-spacing:.04em; color:inherit;
  opacity:.92; transition:opacity .2s, background .25s, border-color .25s; }
.lang__btn:hover{ opacity:1; background:rgba(127,127,127,.12); }
.site-header.is-scrolled .lang__btn{ border-color:var(--line); }
.lang__globe{ width:16px; height:16px; }
.lang__chev{ width:13px; height:13px; transition:transform .25s var(--ease); }
.lang.is-open .lang__chev{ transform:rotate(180deg); }
.lang__menu{ position:absolute; top:calc(100% + 10px); right:0; min-width:194px; background:var(--paper); color:var(--ink);
  border:1px solid var(--line); border-radius:14px; box-shadow:var(--sh-lg); padding:8px;
  display:flex; flex-direction:column; gap:2px; z-index:80; list-style:none; margin:0;
  opacity:0; visibility:hidden; transform:translateY(-8px) scale(.98); transform-origin:top right;
  transition:opacity .22s var(--ease), transform .22s var(--ease), visibility .22s; }
.lang.is-open .lang__menu{ opacity:1; visibility:visible; transform:none; }
.lang__menu button{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:9px 12px; border-radius:9px; font-size:.95rem; color:var(--ink); cursor:pointer; transition:background .18s; }
.lang__menu button span{ font-size:.7rem; font-weight:700; letter-spacing:.08em; opacity:.5; }
.lang__menu button:hover{ background:var(--sand); }
.lang__menu button[aria-current="true"]{ background:var(--sand-2); color:var(--terra-dk); }
.lang__menu button[aria-current="true"] span{ opacity:.85; color:var(--terra-dk); }

/* ---------- FAQ ---------- */
.faq__wrap{ max-width:840px; }
.faq__list{ display:flex; flex-direction:column; gap:14px; }
.faq__item{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r); overflow:hidden;
  transition:box-shadow .3s var(--ease), border-color .3s; }
.faq__item.is-open{ box-shadow:var(--sh-md); border-color:transparent; }
.faq__q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:18px; text-align:left;
  padding:22px 26px; font-family:var(--serif); font-size:1.18rem; color:var(--ink); cursor:pointer; }
.faq__plus{ position:relative; width:20px; height:20px; flex:0 0 auto; }
.faq__plus::before,.faq__plus::after{ content:""; position:absolute; background:var(--terra); border-radius:2px; transition:transform .35s var(--ease), opacity .35s; }
.faq__plus::before{ top:9px; left:0; width:20px; height:2px; }
.faq__plus::after{ left:9px; top:0; width:2px; height:20px; }
.faq__item.is-open .faq__plus::after{ transform:rotate(90deg); opacity:0; }
.faq__a{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .42s var(--ease); }
.faq__a > div{ overflow:hidden; }
.faq__item.is-open .faq__a{ grid-template-rows:1fr; }
.faq__a p{ padding:0 26px 24px; color:var(--ink-soft); }

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width:1024px){
  .features{ grid-template-columns:repeat(2,1fr); }
  .booking__cards{ grid-template-columns:1fr; max-width:560px; margin-inline:auto; }
}

@media (max-width:900px){
  .nav__toggle{ display:flex; }
  .nav__menu{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:2px;
    background:var(--paper); color:var(--ink);
    padding:14px 24px 26px; box-shadow:var(--sh-lg);
    transform:translateY(-14px); opacity:0; visibility:hidden;
    transition:transform .3s var(--ease), opacity .3s, visibility .3s;
  }
  .nav__menu.is-open{ transform:none; opacity:1; visibility:visible; }
  .nav__menu a{ color:var(--ink); padding:13px 4px; border-bottom:1px solid var(--line); font-size:1.05rem; }
  .nav__menu a:not(.btn)::after{ display:none; }
  .nav__cta{ margin-top:14px; padding:.85em 1.7em; }

  .intro__grid,.surroundings__grid,.contact__grid{ grid-template-columns:1fr; }
  .surroundings__map{ order:-1; }
  .intro__badge{ right:18px; }
  .reviews__grid{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(3,1fr); grid-auto-rows:180px; }
  .surroundings__map iframe{ height:340px; }
}

@media (max-width:600px){
  body{ font-size:.99rem; }
  .container{ padding-inline:20px; }
  .features{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:150px; gap:10px; }
  .gallery__item--wide{ grid-column:span 2; }
  .gallery__item--tall{ grid-row:span 2; }
  .field-row{ grid-template-columns:1fr; }
  .hero__facts{ gap:12px 22px; }
  .hero__actions .btn{ flex:1 1 auto; }
  .intro__media img{ aspect-ratio:3/4; }
  .review{ padding:26px 24px; }
  .fab-wa{ width:54px; height:54px; right:16px; bottom:16px; }
}

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