/* =========================================================
   Château Amour — light cream & gold theme
   The most romantic house in Croatia
   ========================================================= */

:root{
  --bg:        #F7F2E8;   /* glavna krem */
  --bg-deep:   #EFE6D5;   /* dublja krem (alt sekcije) */
  --surface:   #FFFFFF;   /* kartice */
  --surface-2: #FBF7EF;

  --line:      rgba(176,135,58,.30);
  --line-soft: rgba(40,33,22,.10);

  --text:      #3A3228;   /* tijelo */
  --heading:   #231C14;   /* naslovi (tamni espresso) */
  --muted:     #8C8273;

  --gold:      #BE944A;   /* primarno zlato (fill/gumbi/okviri) */
  --gold-soft: #E3D2A8;   /* svijetli champagne */
  --gold-ink:  #9A722B;   /* zlato za tekst (više kontrasta) */
  --rose:      #7B2D3B;

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

  --maxw: 1180px;
  --radius: 14px;
  --shadow: 0 22px 55px rgba(80,60,25,.14);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
/* `hidden` atribut mora pobijediti eksplicitni display (npr. .lightbox{display:flex}) */
[hidden]{ display:none !important; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:300;
  font-size:16px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

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

h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.15; margin:0; color:var(--heading); }

.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.container-narrow{ max-width:820px; }

section[id]{ scroll-margin-top:110px; }

/* ---------- Helpers ---------- */
.eyebrow{
  font-family:var(--sans); text-transform:uppercase; letter-spacing:.28em;
  font-size:.72rem; color:var(--gold-ink); margin:0 0 14px; font-weight:500;
}
/* elegantne zlatne crtice oko centriranih eyebrow labela */
.section-head .eyebrow,
.cta-inner .eyebrow{ display:inline-flex; align-items:center; gap:14px; }
.section-head .eyebrow::before,.section-head .eyebrow::after,
.cta-inner .eyebrow::before,.cta-inner .eyebrow::after{
  content:""; width:34px; height:1px; background:var(--gold); opacity:.75;
}
.section-title{ font-size:clamp(1.9rem,4vw,3rem); margin-bottom:.4em; }
.section-lead{ color:var(--muted); max-width:60ch; margin:0 auto; }
.section{ padding:96px 0; }
.section-alt{ background:transparent; }
.section-head{ text-align:center; max-width:720px; margin:0 auto 56px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--sans); font-size:.82rem; font-weight:500;
  text-transform:uppercase; letter-spacing:.16em;
  padding:15px 30px; border-radius:50px; cursor:pointer;
  border:1px solid transparent; transition:all .35s var(--ease);
}
.btn-sm{ padding:11px 22px; font-size:.74rem; }
.btn-block{ width:100%; }
.btn-gold{
  background:linear-gradient(135deg,var(--gold),#D8BE84);
  color:#2A2012; border-color:var(--gold);
}
.btn-gold:hover{ filter:brightness(1.05); transform:translateY(-2px); box-shadow:0 12px 28px rgba(190,148,74,.35); }
.btn-outline{ border-color:rgba(58,50,40,.35); color:var(--heading); background:transparent; }
.btn-outline:hover{ border-color:var(--gold-ink); color:var(--gold-ink); }
.link-gold{ color:var(--gold-ink); border-bottom:1px solid rgba(154,114,43,.4); }

/* =========================================================
   HEADER / NAV
   (proziran preko hero foto sa svijetlim tekstom -> krem nakon skrola)
   ========================================================= */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  padding:24px 0;
  transition:padding .55s var(--ease), box-shadow .6s var(--ease), border-color .6s var(--ease),
             backdrop-filter .6s var(--ease), -webkit-backdrop-filter .6s var(--ease);
  background:linear-gradient(to bottom, rgba(24,18,11,.62) 0%, rgba(24,18,11,.24) 62%, transparent 100%);
  backdrop-filter:blur(7px) saturate(120%);
  -webkit-backdrop-filter:blur(7px) saturate(120%);
  border-bottom:1px solid transparent;
  box-shadow:0 8px 30px rgba(80,60,25,0);
}
/* Bogatija krem-bijela protkana zlatom — NJEŽNO se pretapa (opacity) preko frosted trake */
.site-header::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  opacity:0; transition:opacity .6s var(--ease);
  background:
    radial-gradient(140% 210% at 16% -65%, rgba(210,170,86,.22) 0%, rgba(210,170,86,0) 55%),
    linear-gradient(108deg, rgba(255,253,247,.985) 0%, rgba(249,241,224,.975) 45%, rgba(242,231,205,.975) 100%);
}
.site-header.scrolled::before{ opacity:1; }
.site-header.scrolled{
  backdrop-filter:blur(16px) saturate(135%);
  -webkit-backdrop-filter:blur(16px) saturate(135%);
  padding:13px 0; border-bottom-color:var(--line);
  box-shadow:0 8px 30px rgba(80,60,25,.12);
}
/* 3 zone: logo lijevo | meni centriran | jezik+CTA desno — puna širina ekrana */
.nav-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; column-gap:10px;
  max-width:none; padding:0 clamp(18px,2.4vw,44px); position:relative; z-index:1; }

.brand{ display:flex; align-items:center; gap:12px; color:#F7F2E8; justify-self:start; }
.brand-mark{ height:120px; width:auto; flex:none; transition:height .5s var(--ease); }
.brand-wordmark{ display:block; height:28px; width:auto; }
.site-header.scrolled .brand{ color:var(--heading); }
.site-header.scrolled .brand-mark{ height:74px; }
.brand-text{ display:flex; flex-direction:column; align-items:center; line-height:1.05; }
.brand-line1{ font-family:var(--serif); font-size:1.18rem; letter-spacing:.16em; text-transform:uppercase; }
.brand-line2{ font-size:.74rem; text-transform:uppercase; letter-spacing:.2em; color:#F2E6C8; margin-top:5px; white-space:nowrap; text-shadow:0 1px 8px rgba(0,0,0,.6); transition:color .5s var(--ease), text-shadow .5s var(--ease); }
.site-header.scrolled .brand-line2{ color:var(--gold-ink); text-shadow:none; }

/* desktop: nav nestaje kao box, djeca (linkovi/akcije) postaju grid ćelije */
.nav{ display:contents; }
.nav-links{ justify-self:center; display:flex; align-items:center; gap:clamp(12px,1.4vw,28px); }
.nav-actions{ justify-self:end; display:flex; align-items:center; gap:16px; }

.nav-links>a{
  font-size:.82rem; letter-spacing:.05em; color:#FBF6EC; opacity:1; white-space:nowrap;
  text-shadow:0 1px 7px rgba(0,0,0,.55);
  position:relative; padding:4px 0; transition:color .5s var(--ease), opacity .5s var(--ease), text-shadow .5s var(--ease);
}
.nav-actions .nav-cta{ white-space:nowrap; padding:12px 18px; letter-spacing:.06em; }
.site-header.scrolled .nav-links>a{ color:var(--text); opacity:.85; text-shadow:none; }
.nav-links>a:hover{ opacity:1; color:var(--gold-soft); }
.site-header.scrolled .nav-links>a:hover{ color:var(--gold-ink); }
.nav-links>a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px;
  background:var(--gold); transition:width .3s var(--ease);
}
.nav-links>a:hover::after{ width:100%; }

.lang-switch{ display:flex; align-items:center; gap:6px; }
.lang-btn{
  background:none; border:none; color:#E9E1D2; cursor:pointer;
  font-family:var(--sans); font-size:.8rem; letter-spacing:.08em; padding:2px; transition:color .5s var(--ease);
}
.site-header.scrolled .lang-btn{ color:var(--muted); }
.lang-btn.is-active{ color:var(--gold-soft); font-weight:600; }
.site-header.scrolled .lang-btn.is-active{ color:var(--gold-ink); }
.lang-btn:hover{ color:#fff; }
.site-header.scrolled .lang-btn:hover{ color:var(--heading); }
.lang-sep{ color:rgba(255,255,255,.4); }
.site-header.scrolled .lang-sep{ color:var(--line); }

.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.nav-toggle span{ width:24px; height:2px; background:#F4EEE2; transition:.3s; }
.site-header.scrolled .nav-toggle span{ background:var(--heading); }
.nav-toggle[aria-expanded="true"] span{ background:var(--heading); }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; min-height:100vh; display:flex; align-items:center; }
.hero-bg{
  position:absolute; inset:0;
  background:#0e0b07 url("../assets/img/hero-dusk.jpg") center/cover no-repeat;
  transform:scale(1.06); animation:heroBlur 11s ease-in-out infinite;
}
/* noćna slika preko cijelog ekrana */
.hero-night{
  position:absolute; inset:0;
  background:#05060a url("../assets/img/hero-night.jpg") center/cover no-repeat;
  opacity:0; transform:scale(1.06);
  animation:heroSwap 11s ease-in-out infinite, heroBlur 11s ease-in-out infinite;
}
.hero-dim{ display:none; }
/* sporo, glatko pretapanje sumrak <-> noc, bez crne; blur na sredini sakriva razliku u kadru */
@keyframes heroSwap{ 0%,27%{ opacity:0; } 50%,77%{ opacity:1; } 100%{ opacity:0; } }
@keyframes heroBlur{ 0%,27%{ filter:blur(0); } 39%{ filter:blur(16px); } 50%,77%{ filter:blur(0); } 89%{ filter:blur(16px); } 100%{ filter:blur(0); } }
@media (prefers-reduced-motion: reduce){
  .hero-bg{ animation:none; filter:none; }
  .hero-night{ animation:none; opacity:0; filter:none; }
}
.hero-overlay{
  position:absolute; inset:0;
  background:radial-gradient(ellipse 120% 90% at 50% 42%, rgba(18,12,7,.16) 0%, rgba(18,12,7,.52) 100%),linear-gradient(to bottom, rgba(26,18,10,.52) 0%, rgba(26,18,10,.34) 38%, rgba(16,11,6,.70) 100%);
}
.hero-content{ position:relative; z-index:2; text-align:center; padding-top:80px; }
.hero-crest{ width:70px; height:78px; color:var(--gold-soft); margin:0 auto 22px; }
.hero .eyebrow{ color:var(--gold-soft); display:inline-flex; align-items:center; gap:14px; }
.hero .eyebrow::before,.hero .eyebrow::after{ content:""; width:30px; height:1px; background:var(--gold-soft); opacity:.8; }
.hero-title{ font-size:clamp(2.8rem,8vw,6rem); margin-bottom:.25em; color:#FBF6EC; letter-spacing:.04em; }
.hero-wordmark{ width:min(820px,92%); height:auto; margin:0 auto .1em; display:block; filter:drop-shadow(0 6px 26px rgba(0,0,0,.5)); }
.hero-sub{ font-size:clamp(1rem,2vw,1.3rem); color:#F4EEE2; opacity:.95; max-width:50ch; margin:0 auto 36px; }
.hero-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.hero .btn-outline{ border-color:rgba(247,242,232,.55); color:#FBF6EC; }
.hero .btn-outline:hover{ border-color:var(--gold-soft); color:var(--gold-soft); }

.scroll-cue{ position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:2; }
.scroll-cue span{ display:block; width:24px; height:40px; border:1px solid rgba(247,242,232,.5); border-radius:14px; position:relative; }
.scroll-cue span::after{
  content:""; position:absolute; left:50%; top:8px; width:3px; height:8px; border-radius:2px;
  background:var(--gold-soft); transform:translateX(-50%); animation:scrollDot 1.8s infinite;
}
@keyframes scrollDot{ 0%{opacity:0;transform:translate(-50%,0);} 40%{opacity:1;} 80%{opacity:0;transform:translate(-50%,12px);} }

/* =========================================================
   ABOUT
   ========================================================= */
.about-grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.about-media{ position:relative; }
.about-media img{ border-radius:var(--radius); box-shadow:var(--shadow); aspect-ratio:4/5; object-fit:cover; }
.about-text p{ color:var(--muted); margin:0 0 18px; }
.highlights{ list-style:none; padding:0; margin:28px 0; display:flex; gap:28px; flex-wrap:wrap; }
.highlights li{ display:flex; flex-direction:column; gap:4px; }
.hl-num{ font-family:var(--serif); font-size:1.6rem; color:var(--gold-ink); }
.highlights span:last-child{ font-size:.82rem; color:var(--muted); }
.signature-quote{
  font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--heading);
  border-left:2px solid var(--gold); padding-left:20px; margin:24px 0 0;
}

/* =========================================================
   CARDS GRID
   ========================================================= */
.cards-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.cards-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }

.exp-card,.pack-card,.review-card{
  background:var(--surface); border:1px solid var(--line-soft); border-radius:var(--radius);
  padding:34px 28px; transition:transform .4s var(--ease), border-color .4s, box-shadow .4s;
}
.exp-card:hover,.pack-card:hover,.review-card:hover{
  transform:translateY(-6px); border-color:var(--line); box-shadow:var(--shadow);
}
.exp-icon{ width:52px; height:52px; color:var(--gold-ink); margin-bottom:20px; }
.exp-icon svg{ width:100%; height:100%; }
.exp-card h3,.pack-card h3{ font-size:1.5rem; margin-bottom:10px; }
.exp-card p,.pack-card p{ color:var(--muted); font-size:.95rem; margin:0 0 18px; }
.exp-tag{ font-size:.72rem; text-transform:uppercase; letter-spacing:.14em; color:var(--gold-ink); }

/* Packages */
.pack-card{ position:relative; }
.pack-price{ font-family:var(--serif); font-size:1.7rem; color:var(--gold-ink); margin:0 0 12px !important; }
.pack-featured{ border-color:var(--gold); background:linear-gradient(180deg, rgba(190,148,74,.10), var(--surface)); }
.pack-badge{
  position:absolute; top:-12px; left:28px; background:linear-gradient(135deg,var(--gold),#D8BE84);
  color:#2A2012; font-size:.66rem; text-transform:uppercase; letter-spacing:.12em;
  padding:5px 12px; border-radius:50px; font-weight:600;
}

/* =========================================================
   GALLERY
   ========================================================= */
.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:14px; grid-auto-flow:dense; }
.gallery-item{ overflow:hidden; border-radius:10px; cursor:pointer; position:relative; background:var(--bg-deep); }
.gallery-item img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.gallery-item:hover img{ transform:scale(1.08); }
.gallery-item::after{
  content:"+"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:2rem; color:#fff; background:rgba(35,28,18,0); opacity:0; transition:.4s;
}
.gallery-item:hover::after{ background:rgba(35,28,18,.32); opacity:1; }
.gallery-item.tall{ grid-row:span 2; }
.gallery-item.wide{ grid-column:span 2; }

/* =========================================================
   AMENITIES
   ========================================================= */
.amenities-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.amenity{
  display:flex; align-items:center; gap:14px; padding:20px 22px;
  background:var(--surface); border:1px solid var(--line-soft); border-radius:12px;
  transition:border-color .3s, transform .3s, box-shadow .3s;
}
.amenity:hover{ border-color:var(--line); transform:translateY(-3px); box-shadow:var(--shadow); }
.amenity svg{ width:26px; height:26px; color:var(--gold-ink); flex:none; }
.amenity span{ font-size:.92rem; }

/* =========================================================
   PRICING
   ========================================================= */
.price-table{
  max-width:880px; margin:0 auto; border:1px solid var(--line-soft); border-radius:var(--radius);
  overflow:hidden; background:var(--surface);
}
.price-row{
  display:grid; grid-template-columns:1.4fr 1.6fr 1fr 1fr; gap:12px;
  padding:18px 26px; border-bottom:1px solid var(--line-soft); align-items:center;
}
.price-row:last-child{ border-bottom:none; }
.price-head{ background:rgba(190,148,74,.12); font-size:.74rem; text-transform:uppercase; letter-spacing:.14em; color:var(--gold-ink); }
.price-amt{ font-family:var(--serif); font-size:1.35rem; color:var(--gold-ink); }
.price-foot{ background:rgba(123,45,59,.07); }
.price-note{ text-align:center; color:var(--muted); font-size:.88rem; max-width:680px; margin:24px auto 0; }

/* =========================================================
   BOOKING (calendar + form)
   ========================================================= */
.booking-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:40px; align-items:start; }

.calendar-wrap{ background:var(--surface); border:1px solid var(--line-soft); border-radius:var(--radius); padding:26px; box-shadow:var(--shadow); }
.calendar-nav{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.cal-label{ font-family:var(--serif); font-size:1.25rem; text-transform:capitalize; color:var(--heading); }
.cal-arrow{
  width:38px; height:38px; border-radius:50%; border:1px solid var(--line-soft);
  background:transparent; color:var(--text); cursor:pointer; font-size:1.2rem; transition:.25s;
}
.cal-arrow:hover:not(:disabled){ border-color:var(--gold); color:var(--gold-ink); }
.cal-arrow:disabled{ opacity:.3; cursor:not-allowed; }

.calendar-months{ display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.cal-month-name{ text-align:center; font-family:var(--serif); font-size:1.05rem; margin-bottom:10px; color:var(--gold-ink); text-transform:capitalize; }
.cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; }
.cal-dow{ font-size:.62rem; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); text-align:center; padding:4px 0; }
.cal-day{
  aspect-ratio:1; display:flex; align-items:center; justify-content:center;
  font-size:.82rem; border-radius:8px; cursor:pointer; transition:.2s; user-select:none;
  border:1px solid transparent; color:var(--text);
}
.cal-day.empty{ cursor:default; }
.cal-day.free:hover{ background:rgba(190,148,74,.18); border-color:var(--gold); }
.cal-day.past{ color:rgba(58,50,40,.30); cursor:not-allowed; text-decoration:line-through; }
.cal-day.booked{ background:rgba(123,45,59,.12); color:#a05a62; cursor:not-allowed; }
.cal-day.selected{ background:linear-gradient(135deg,var(--gold),#D8BE84); color:#2A2012; font-weight:600; }
.cal-day.in-range{ background:rgba(190,148,74,.16); }

.calendar-legend{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-top:18px; font-size:.76rem; color:var(--muted); }
.calendar-legend .lg{ width:14px; height:14px; border-radius:4px; display:inline-block; }
.lg-free{ border:1px solid var(--gold); }
.lg-booked{ background:rgba(123,45,59,.30); }
.lg-sel{ background:var(--gold); }
.calendar-legend span:not(.lg){ margin-right:10px; }

/* Form */
.booking-form{ background:var(--surface); border:1px solid var(--line-soft); border-radius:var(--radius); padding:30px; box-shadow:var(--shadow); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ margin-bottom:16px; display:flex; flex-direction:column; }
.field label{ font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); margin-bottom:7px; }
.field input,.field select,.field textarea{
  background:var(--surface-2); border:1px solid var(--line-soft); border-radius:9px;
  color:var(--text); font-family:var(--sans); font-size:.92rem; padding:12px 14px; transition:border-color .25s;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold); background:#fff; }
.field input.invalid,.field select.invalid{ border-color:var(--rose); }
.field textarea{ resize:vertical; }
input[type="date"]::-webkit-calendar-picker-indicator{ opacity:.55; cursor:pointer; }
.form-success{
  background:rgba(190,148,74,.14); border:1px solid var(--line); color:var(--gold-ink);
  padding:14px; border-radius:9px; text-align:center; margin:16px 0 0;
}
.form-hint{ font-size:.76rem; color:var(--muted); text-align:center; margin:12px 0 0; }

/* =========================================================
   REVIEWS
   ========================================================= */
.stars{ color:var(--gold); letter-spacing:.15em; margin-bottom:14px; }
.review-text{ font-family:var(--serif); font-style:italic; font-size:1.12rem; color:var(--heading); margin:0 0 18px; }
.review-author{ font-size:.86rem; display:flex; flex-direction:column; color:var(--heading); }
.review-author span{ color:var(--muted); font-size:.78rem; }

/* =========================================================
   LOCATION
   ========================================================= */
.location-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:56px; align-items:center; }
.location-text p{ color:var(--muted); }
.loc-list{ list-style:none; padding:0; margin:24px 0; }
.loc-list li{ display:flex; justify-content:space-between; padding:13px 0; border-bottom:1px solid var(--line-soft); }
.loc-dist{ color:var(--gold-ink); font-weight:500; }
.loc-note{ font-size:.84rem; font-style:italic; }
.location-map{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line-soft); }
.location-map iframe{ width:100%; height:420px; border:0; display:block; filter:grayscale(.15) sepia(.12) contrast(1.02); }

/* =========================================================
   FAQ
   ========================================================= */
.faq-item{ border-bottom:1px solid var(--line-soft); }
.faq-q{
  width:100%; background:none; border:none; cursor:pointer; color:var(--heading);
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  padding:22px 4px; text-align:left; font-family:var(--serif); font-size:1.2rem;
}
.faq-icon{ color:var(--gold-ink); font-size:1.5rem; transition:transform .3s; flex:none; }
.faq-q[aria-expanded="true"] .faq-icon{ transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a p{ color:var(--muted); margin:0 0 22px; padding-right:30px; }

/* =========================================================
   CTA BAND + FOOTER
   ========================================================= */
.cta-band{ position:relative; text-align:center; background:var(--bg-deep); }
.cta-inner{ max-width:720px; }
.contact-methods{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin:30px 0 34px; }
.contact-pill{
  display:inline-flex; align-items:center; gap:10px; padding:12px 22px;
  border:1px solid var(--line-soft); border-radius:50px; font-size:.9rem; transition:.3s; background:var(--surface);
}
.contact-pill svg{ width:18px; height:18px; color:var(--gold-ink); }
.contact-pill:hover{ border-color:var(--gold); color:var(--gold-ink); box-shadow:var(--shadow); }

.site-footer{
  position:relative;
  background:#160f0a;
  background-image:
    linear-gradient(180deg, rgba(18,12,8,.88) 0%, rgba(18,12,8,.70) 42%, rgba(13,9,6,.92) 100%),
    url('../assets/img/footer-bg.jpg');
  background-size:cover;
  background-position:center 38%;
  border-top:1px solid rgba(190,148,74,.45);
  padding:64px 0 24px;
}
.brand-footer{ color:#FBF7EF; }
.brand-footer .brand-line1{ font-size:1.25rem; font-family:var(--serif); letter-spacing:.16em; text-transform:uppercase; }
.brand-footer .brand-wordmark{ height:38px; filter:drop-shadow(0 2px 12px rgba(0,0,0,.55)); }
.brand-footer .brand-line2{ color:var(--gold-soft); text-shadow:0 1px 10px rgba(0,0,0,.7); }
.footer-tag{ color:rgba(245,238,224,.82); font-size:.9rem; max-width:34ch; margin:16px 0 0; text-shadow:0 1px 8px rgba(0,0,0,.5); }
.footer-col h4{ font-family:var(--sans); font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; color:var(--gold-soft); margin-bottom:16px; font-weight:600; }
.footer-col a{ display:block; color:rgba(245,238,224,.74); font-size:.9rem; padding:6px 0; transition:color .25s; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{
  position:relative;
  max-width:var(--maxw); margin:48px auto 0; padding:22px 24px 0; border-top:1px solid rgba(245,238,224,.14);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; color:rgba(245,238,224,.6); font-size:.8rem;
}

/* =========================================================
   FLOATING WHATSAPP
   ========================================================= */
.float-wa{
  position:fixed; right:22px; bottom:22px; z-index:90;
  width:54px; height:54px; border-radius:50%;
  background:linear-gradient(135deg,var(--gold),#D8BE84); color:#2A2012;
  display:flex; align-items:center; justify-content:center; box-shadow:0 10px 26px rgba(120,90,30,.35);
  transition:transform .3s;
}
.float-wa svg{ width:26px; height:26px; }
.float-wa:hover{ transform:scale(1.1); }

/* =========================================================
   COOKIE BANNER
   ========================================================= */
.cookie-banner{
  position:fixed; left:0; right:0; bottom:0; z-index:120;
  background:rgba(247,242,232,.97); backdrop-filter:blur(8px); border-top:1px solid var(--line);
  padding:16px 24px; display:flex; align-items:center; justify-content:center; gap:24px; flex-wrap:wrap;
  box-shadow:0 -6px 24px rgba(80,60,25,.08);
}
.cookie-banner p{ margin:0; font-size:.86rem; color:var(--muted); }
.cookie-actions{ display:flex; align-items:center; gap:18px; }

/* =========================================================
   LIGHTBOX (zadržava taman backdrop za prikaz fotografija)
   ========================================================= */
.lightbox{
  position:fixed; inset:0; z-index:200; background:rgba(33,27,18,.94);
  display:flex; align-items:center; justify-content:center; padding:40px;
}
.lb-img{ max-width:90vw; max-height:85vh; border-radius:10px; box-shadow:var(--shadow); }
.lb-close,.lb-prev,.lb-next{
  position:absolute; background:none; border:none; color:#F4EEE2; cursor:pointer;
  font-size:2.4rem; line-height:1; padding:10px; transition:color .25s;
}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{ color:var(--gold-soft); }
.lb-close{ top:18px; right:26px; }
.lb-prev{ left:18px; top:50%; transform:translateY(-50%); font-size:3rem; }
.lb-next{ right:18px; top:50%; transform:translateY(-50%); font-size:3rem; }

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .cards-4{ grid-template-columns:repeat(2,1fr); }
  .amenities-grid{ grid-template-columns:repeat(3,1fr); }
  .gallery-grid{ grid-template-columns:repeat(3,1fr); }
}

/* veći logo + nav ne stanu zajedno ispod ~1180px -> hamburger ranije */
@media (max-width:1180px){
  /* mobitel/tablet: natrag na flex — logo lijevo, hamburger desno */
  .nav-inner{ display:flex; justify-content:space-between; }
  .nav{
    display:flex; position:fixed; inset:0 0 0 auto; width:min(82vw,340px);
    background:rgba(247,242,232,.99); backdrop-filter:blur(14px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:26px;
    padding:48px 40px; transform:translateX(100%); transition:transform .4s var(--ease);
    border-left:1px solid var(--line-soft); overflow-y:auto;
  }
  .nav.open{ transform:translateX(0); }
  .nav-links{ display:flex; flex-direction:column; align-items:flex-start; gap:20px; }
  .nav-actions{ display:flex; flex-direction:column; align-items:flex-start; gap:18px; margin-top:6px; }
  .nav-links>a{ font-size:1.15rem; color:var(--text); opacity:.9; white-space:normal; text-shadow:none; }
  .nav-links>a:hover{ color:var(--gold-ink); }
  .lang-btn{ color:var(--muted); }
  .lang-btn.is-active{ color:var(--gold-ink); }
  .lang-sep{ color:var(--line); }
  .nav-toggle{ display:flex; z-index:101; }
  .nav-toggle span{ background:#F4EEE2; }
  .site-header.scrolled .nav-toggle span{ background:var(--heading); }
  .lang-switch{ margin-top:8px; }
}

@media (max-width:860px){
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(80vw,320px);
    background:rgba(247,242,232,.99); backdrop-filter:blur(14px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:22px;
    padding:40px; transform:translateX(100%); transition:transform .4s var(--ease);
    border-left:1px solid var(--line-soft);
  }
  .nav.open{ transform:translateX(0); }
  .nav-links>a{ font-size:1.1rem; color:var(--text); opacity:.9; }
  .nav-links>a:hover{ color:var(--gold-ink); }
  .lang-btn{ color:var(--muted); }
  .lang-btn.is-active{ color:var(--gold-ink); }
  .lang-sep{ color:var(--line); }
  .nav-toggle{ display:flex; z-index:101; }
  .nav-toggle span{ background:#F4EEE2; }
  .site-header.scrolled .nav-toggle span{ background:var(--heading); }
  .lang-switch{ margin-top:8px; }

  .about-grid,.location-grid,.booking-grid{ grid-template-columns:1fr; gap:36px; }
  .about-media{ order:-1; }
  .cards-3{ grid-template-columns:1fr; }
  .section{ padding:72px 0; }
}

@media (max-width:680px){
  .cards-4{ grid-template-columns:1fr; }
  .amenities-grid{ grid-template-columns:repeat(2,1fr); }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:150px; }
  .calendar-months{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
  .price-row{ grid-template-columns:1fr 1fr; row-gap:4px; font-size:.86rem; }
  .price-head{ display:none; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .footer-bottom{ flex-direction:column; text-align:center; }
  .highlights{ gap:20px; }
}

/* mali ekrani: smanji logo/ime da ne prelazi rub uz hamburger */
@media (max-width:560px){
  .brand-mark{ height:54px; }
  .site-header.scrolled .brand-mark{ height:50px; }
  .brand-wordmark{ height:21px; }
  .brand-line2{ font-size:.6rem; letter-spacing:.12em; margin-top:4px; }
}

@media (max-width:420px){
  .container{ padding:0 18px; }
  .footer-grid{ grid-template-columns:1fr; }
  .contact-methods{ flex-direction:column; }
}

/* =========================================================
   FULL-BLEED BACKGROUND SECTIONS (immersive scroll)
   ========================================================= */
.bg-section{
  position:relative; overflow:hidden;
}
.bg-section > .container{
  position:relative; z-index:2;
}
.section-bg{
  position:absolute; inset:-80px;
  background-size:cover; background-position:center;
  will-change:transform;
}
.section-overlay{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(
    to bottom,
    rgba(35,28,18,.58) 0%,
    rgba(35,28,18,.42) 40%,
    rgba(35,28,18,.62) 100%
  );
}

/* Ken Burns animation variations */
.section-bg.kb-1{ animation:kb1 28s ease-in-out infinite alternate; }
.section-bg.kb-2{ animation:kb2 32s ease-in-out infinite alternate; }
.section-bg.kb-3{ animation:kb3 26s ease-in-out infinite alternate; }
.section-bg.kb-4{ animation:kb4 30s ease-in-out infinite alternate; }
.section-bg.kb-5{ animation:kb5 34s ease-in-out infinite alternate; }

@keyframes kb1{ from{transform:scale(1) translate(0,0);} to{transform:scale(1.15) translate(-2%,-1.5%);} }
@keyframes kb2{ from{transform:scale(1.08) translate(-1%,0);} to{transform:scale(1) translate(1.5%,-2%);} }
@keyframes kb3{ from{transform:scale(1) translate(1%,.5%);} to{transform:scale(1.12) translate(-1%,-1%);} }
@keyframes kb4{ from{transform:scale(1.05) translate(0,-1%);} to{transform:scale(1) translate(-2%,1%);} }
@keyframes kb5{ from{transform:scale(1) translate(-.5%,0);} to{transform:scale(1.1) translate(1%,-1.5%);} }

/* ---------- Light-on-dark text overrides ---------- */
.bg-section .section-title,
.bg-section h2,.bg-section h3,.bg-section h4{ color:#FBF6EC; }
.bg-section p,
.bg-section .section-lead{ color:rgba(244,238,226,.88); }
.bg-section .eyebrow{ color:var(--gold-soft); }
.bg-section .section-head .eyebrow::before,
.bg-section .section-head .eyebrow::after,
.bg-section .cta-inner .eyebrow::before,
.bg-section .cta-inner .eyebrow::after{ background:var(--gold-soft); }

/* About text overrides */
.bg-section .about-text p{ color:rgba(244,238,226,.88); }
.bg-section .highlights .hl-num{ color:var(--gold-soft); }
.bg-section .highlights span:last-child{ color:rgba(244,238,226,.7); }
.bg-section .signature-quote{ color:#FBF6EC; border-left-color:var(--gold-soft); }
.bg-section .about-media img{
  border:2px solid rgba(247,242,232,.18);
  box-shadow:0 20px 50px rgba(0,0,0,.45);
}

/* ---------- Glassmorphism cards ---------- */
.bg-section .exp-card,
.bg-section .review-card,
.bg-section .pack-card{
  background:rgba(247,242,232,.10);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border-color:rgba(247,242,232,.16);
}
.bg-section .exp-card:hover,
.bg-section .review-card:hover,
.bg-section .pack-card:hover{
  background:rgba(247,242,232,.16);
  border-color:rgba(247,242,232,.28);
  box-shadow:0 22px 55px rgba(0,0,0,.35);
}
.bg-section .exp-card h3,
.bg-section .pack-card h3{ color:#FBF6EC; }
.bg-section .exp-card p,
.bg-section .pack-card p{ color:rgba(244,238,226,.82); }
.bg-section .exp-tag{ color:var(--gold-soft); }
.bg-section .exp-icon{ color:var(--gold-soft); }
.bg-section .pack-price{ color:var(--gold-soft); }
.bg-section .pack-featured{
  border-color:var(--gold-soft);
  background:rgba(190,148,74,.12);
}
.bg-section .pack-badge{
  background:linear-gradient(135deg,var(--gold),#D8BE84);
  color:#2A2012;
}

/* Review cards */
.bg-section .stars{ color:var(--gold-soft); }
.bg-section .review-text{ color:#FBF6EC; }
.bg-section .review-author{ color:#F4EEE2; }
.bg-section .review-author span{ color:rgba(244,238,226,.65); }

/* Amenity glass pills */
.bg-section .amenity{
  background:rgba(247,242,232,.08);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-color:rgba(247,242,232,.14);
}
.bg-section .amenity:hover{
  background:rgba(247,242,232,.15);
  border-color:rgba(247,242,232,.26);
  box-shadow:0 18px 40px rgba(0,0,0,.3);
}
.bg-section .amenity svg{ color:var(--gold-soft); }
.bg-section .amenity span{ color:#F4EEE2; }

/* Contact pills on bg */
.bg-section .contact-pill{
  background:rgba(247,242,232,.10);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-color:rgba(247,242,232,.18);
  color:#F4EEE2;
}
.bg-section .contact-pill svg{ color:var(--gold-soft); }
.bg-section .contact-pill:hover{
  background:rgba(247,242,232,.18);
  border-color:var(--gold-soft);
  color:#FBF6EC;
}

/* Location on bg */
.bg-section .loc-list li{ border-bottom-color:rgba(247,242,232,.15); }
.bg-section .loc-dist{ color:var(--gold-soft); }
.bg-section .loc-note{ color:rgba(244,238,226,.7); }
.bg-section .location-map{
  border-color:rgba(247,242,232,.18);
  box-shadow:0 20px 50px rgba(0,0,0,.4);
}

/* FAQ on bg */
.bg-section .faq-item{ border-bottom-color:rgba(247,242,232,.15); }
.bg-section .faq-q{ color:#FBF6EC; }
.bg-section .faq-icon{ color:var(--gold-soft); }
.bg-section .faq-a p{ color:rgba(244,238,226,.82); }

/* Price table on bg */
.bg-section .price-table{
  background:rgba(247,242,232,.10);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-color:rgba(247,242,232,.16);
}
.bg-section .price-row{ border-bottom-color:rgba(247,242,232,.12); }
.bg-section .price-head{ background:rgba(190,148,74,.18); color:var(--gold-soft); }
.bg-section .price-amt{ color:var(--gold-soft); }
.bg-section .price-foot{ background:rgba(123,45,59,.14); }
.bg-section .price-note{ color:rgba(244,238,226,.7); }

/* Booking form on bg */
.bg-section .calendar-wrap,
.bg-section .booking-form{
  background:rgba(247,242,232,.10);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border-color:rgba(247,242,232,.16);
  box-shadow:0 22px 55px rgba(0,0,0,.35);
}
.bg-section .cal-label{ color:#FBF6EC; }
.bg-section .cal-month-name{ color:var(--gold-soft); }
.bg-section .cal-arrow{ border-color:rgba(247,242,232,.2); color:#F4EEE2; }
.bg-section .cal-arrow:hover:not(:disabled){ border-color:var(--gold-soft); color:var(--gold-soft); }
.bg-section .cal-day{ color:#F4EEE2; }
.bg-section .cal-day.free:hover{ background:rgba(190,148,74,.25); border-color:var(--gold-soft); }
.bg-section .cal-day.past{ color:rgba(244,238,226,.25); }
.bg-section .cal-day.booked{ background:rgba(123,45,59,.25); color:#d98a92; }
.bg-section .cal-dow{ color:rgba(244,238,226,.55); }
.bg-section .calendar-legend{ color:rgba(244,238,226,.6); }
.bg-section .field label{ color:rgba(244,238,226,.7); }
.bg-section .field input,
.bg-section .field select,
.bg-section .field textarea{
  background:rgba(247,242,232,.08);
  border-color:rgba(247,242,232,.15);
  color:#F4EEE2;
}
.bg-section .field input:focus,
.bg-section .field select:focus,
.bg-section .field textarea:focus{
  border-color:var(--gold-soft);
  background:rgba(247,242,232,.14);
}
.bg-section .form-success{
  background:rgba(190,148,74,.18);
  border-color:rgba(190,148,74,.35);
  color:var(--gold-soft);
}
.bg-section .form-hint{ color:rgba(244,238,226,.55); }


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