*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --cream:#F7F3EE;--cream2:#EFE9E0;--cream3:#E5DDD3;
  --terra:#8B4513;--terra-dark:#5d2d0d;
  --gold:#C9A96E;--gold-light:#e8d5a8;
  --olive:#5C6B3F;--sea:#2C5F7A;--sun:#C9991A;
  --dark:#1E1610;--text:#2A1F1A;--muted:#7A6858;
  --serif:'Cormorant Garamond',serif;
  --sans:'Jost',sans-serif;
}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--cream);color:var(--text);}

/* NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;height:80px;transition:all 0.4s;}
#nav.scrolled{background:rgba(30,22,16,0.96);backdrop-filter:blur(12px);height:64px;
  border-bottom:1px solid rgba(201,169,110,0.2);}
/* While the mobile menu is open, drop the backdrop-filter: a non-none
   backdrop-filter turns #nav into a containing block for its fixed-position
   .nav-links overlay, which would otherwise collapse the full-screen menu down
   to the nav bar's height once the page is scrolled.
   transition:none is essential: #nav's base `transition:all 0.4s` would
   otherwise animate backdrop-filter from blur(12px) toward none, keeping it
   non-none (and thus a containing block) for 0.4s — so the menu would open
   collapsed and only snap to full screen once the transition finished. */
#nav.menu-open{backdrop-filter:none !important;-webkit-backdrop-filter:none !important;
  transition:none !important;}
/* Offset smooth-scroll targets (e.g. the hero "Discover" indicator) so they
   land below the fixed nav instead of tucking under it. */
#welcome{scroll-margin-top:80px;}
/* Offset in-page anchor jumps (footer "The Rooms", home room cards) below the fixed nav. */
[id^="room-"]{scroll-margin-top:100px;}
.nav-logo{cursor:pointer;}
.nav-logo-title{font-family:var(--serif);font-size:20px;font-weight:300;
  color:#fff;letter-spacing:5px;text-transform:uppercase;}
.nav-logo-sub{font-size:9px;letter-spacing:6px;color:var(--gold);
  text-transform:uppercase;margin-top:2px;}
.nav-links{display:flex;gap:36px;}
.nav-link{color:rgba(255,255,255,0.85);font-size:10px;letter-spacing:3px;
  text-transform:uppercase;font-weight:500;cursor:pointer;
  border:none;background:none;font-family:var(--sans);
  padding:4px 0;position:relative;transition:color 0.3s;
  text-decoration:none;}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;
  height:1px;background:var(--gold);transition:width 0.3s;}
.nav-link:hover::after,.nav-link.active::after{width:100%;}
.nav-link.active{color:#fff;}
.nav-link:hover{color:#fff;}
.nav-right{display:flex;align-items:center;gap:32px;}
.nav-lang{display:flex;align-items:center;gap:10px;}
.lang-btn{color:rgba(255,255,255,0.45);font-size:11px;letter-spacing:2px;
  font-weight:500;cursor:pointer;border:none;background:none;font-family:var(--sans);
  padding:4px 2px;transition:color 0.3s;text-decoration:none;}
.lang-btn:hover{color:#fff;}
.lang-btn.active{color:var(--gold);pointer-events:none;cursor:default;}
.lang-sep{color:rgba(255,255,255,0.25);font-size:11px;font-weight:300;user-select:none;}

/* PAGES */
.page{display:none;}
.page.active{display:block;}

/* HERO */
.hero{height:100vh;min-height:600px;position:relative;overflow:hidden;}
.hero-img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(30,22,16,0.5) 0%,rgba(30,22,16,0.2) 40%,rgba(30,22,16,0.62) 100%);}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:0 20px;}
.hero-eyebrow{font-size:10px;letter-spacing:6px;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:24px;animation:fadeUp 1s both;}
.hero-title{font-family:var(--serif);font-size:clamp(56px,8vw,96px);
  font-weight:300;color:#fff;line-height:1.05;letter-spacing:2px;
  text-shadow:0 2px 24px rgba(0,0,0,0.45);
  animation:fadeUp 1s 0.15s both;}
.hero-subtitle{font-family:var(--serif);font-size:clamp(18px,2vw,24px);
  font-weight:400;color:#fff;margin-top:20px;
  letter-spacing:2px;font-style:italic;
  text-shadow:0 0 2px #000,0 0 3px #000,0 1px 2px rgba(0,0,0,0.9),0 2px 4px rgba(0,0,0,0.8);
  animation:fadeUp 1s 0.3s both;}
.hero-divider{width:60px;height:1px;background:var(--gold);margin:32px auto;
  animation:fadeUp 1s 0.45s both;}
.hero-cta{display:flex;gap:16px;animation:fadeUp 1s 0.6s both;}
.btn-gold{background:var(--gold);color:var(--dark);border:none;
  display:inline-block;text-decoration:none;
  padding:14px 40px;font-family:var(--sans);font-size:10px;letter-spacing:3px;
  text-transform:uppercase;font-weight:600;cursor:pointer;transition:all 0.3s;}
.btn-gold:hover{background:#b8935a;transform:translateY(-2px);}
.btn-outline{background:transparent;color:#fff;
  display:inline-block;text-decoration:none;
  border:1px solid rgba(255,255,255,0.5);
  padding:14px 40px;font-family:var(--sans);font-size:10px;letter-spacing:3px;
  text-transform:uppercase;font-weight:500;cursor:pointer;transition:all 0.3s;}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,0.08);}
/* Center horizontally with auto margins (not translateX) — the fadeUp
   animation drives `transform`, which would override a transform-based
   centering and shove this off to the right. */
.hero-scroll{position:absolute;bottom:36px;left:0;right:0;margin-inline:auto;
  width:fit-content;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  animation:fadeUp 1s 0.9s both;cursor:pointer;}
.hero-scroll-text{font-size:9px;letter-spacing:4px;text-transform:uppercase;
  color:rgba(255,255,255,0.6);}
.hero-scroll-line{width:1px;height:40px;background:rgba(255,255,255,0.4);
  animation:scrollLine 2s ease-in-out infinite;}

/* SECTION COMMONS */
.section{padding:100px 0;}
.section-inner{max-width:1200px;margin:0 auto;padding:0 48px;}
.section-eyebrow{font-size:10px;letter-spacing:6px;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:16px;}
.section-title{font-family:var(--serif);font-size:clamp(36px,4vw,54px);
  font-weight:300;color:var(--text);line-height:1.15;}
.section-title em{font-style:italic;color:var(--terra);}
.section-divider{width:50px;height:1px;background:var(--gold);margin:24px 0;}
.section-body{font-size:15px;line-height:1.9;color:var(--muted);
  max-width:580px;font-weight:300;}

/* ── WELCOME — EDITORIAL REDESIGN ── */
.welcome-editorial{padding:0;}
.welcome-statement{
  background:var(--dark);
  padding:110px 48px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.welcome-statement::before{
  content:'';
  position:absolute;inset:0;
  background:url("../images/slika1.efead6582991.webp") center/cover no-repeat;
  opacity:0.18;
}
.welcome-statement-inner{position:relative;z-index:1;max-width:900px;margin:0 auto;}
.welcome-quote{
  font-family:var(--serif);
  font-size:clamp(28px,4vw,52px);
  font-weight:300;
  color:#fff;
  line-height:1.35;
  font-style:italic;
  letter-spacing:0.5px;
}
.welcome-quote em{color:var(--gold);font-style:italic;}
.welcome-quote-author{
  margin-top:32px;
  font-size:10px;letter-spacing:5px;text-transform:uppercase;
  color:rgba(255,255,255,0.35);
}
.welcome-facts-strip{
  display:grid;grid-template-columns:repeat(4,1fr);
  background:var(--terra);
}
.welcome-fact{
  padding:36px 24px;
  text-align:center;
  border-right:1px solid rgba(255,255,255,0.12);
}
.welcome-fact:last-child{border-right:none;}
.welcome-fact-num{
  font-family:var(--serif);font-size:46px;font-weight:300;
  color:#fff;line-height:1;
}
.welcome-fact-num sup{font-size:20px;}
.welcome-fact-label{
  font-size:9px;letter-spacing:4px;text-transform:uppercase;
  color:rgba(255,255,255,0.55);margin-top:8px;
}
.welcome-prose{
  display:grid;grid-template-columns:1fr 480px;
  gap:0;
  align-items:stretch;
}
.welcome-prose-text{
  padding:90px 72px 90px 72px;
  display:flex;flex-direction:column;justify-content:center;
  background:var(--cream);
}
.welcome-prose-img-wrap{position:relative;overflow:hidden;}
.welcome-prose-img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  min-height:460px;
}
.welcome-prose-img-caption{
  position:absolute;bottom:0;left:0;right:0;
  padding:20px 24px;
  background:linear-gradient(transparent,rgba(30,22,16,0.7));
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:rgba(255,255,255,0.6);
}

/* ROOMS 2x2 GRID */
.rooms-2x2{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:auto auto;
  gap:3px;
  margin-top:60px;
}
.room-card{position:relative;overflow:hidden;cursor:pointer;}
.room-card img{width:100%;height:420px;object-fit:cover;transition:transform 0.6s;}
.room-card:hover img{transform:scale(1.05);}
.room-card-overlay{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,0.72) 0%,rgba(0,0,0,0.05) 50%);
  transition:opacity 0.3s;}
.room-card-content{position:absolute;bottom:0;left:0;right:0;padding:32px;}
.room-color-bar{width:30px;height:2px;margin-bottom:14px;}
.room-card-name{font-family:var(--serif);font-size:26px;font-weight:300;color:#fff;letter-spacing:1px;}
.room-card-arrow{
  position:absolute;right:28px;bottom:32px;
  width:38px;height:38px;border:1px solid rgba(255,255,255,0.5);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:14px;
  opacity:0;transform:translateX(-8px);transition:all 0.3s;
}
.room-card:hover .room-card-arrow{opacity:1;transform:translateX(0);}

/* SPLIT SECTION */
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;}
.split-img{width:100%;height:520px;object-fit:cover;display:block;}
.split-text{padding:80px 64px;display:flex;flex-direction:column;justify-content:center;}
.split-text.bg-terra{background:var(--terra);}
.split-text.bg-dark{background:var(--dark);}

/* SISTER VILLA BANNER */
.sister-banner{background:var(--cream2);padding:80px 0;text-align:center;}

/* ── PAGE HERO ── */
.page-hero{height:50vh;min-height:360px;position:relative;overflow:hidden;}
.page-hero-img{width:100%;height:100%;object-fit:cover;}
.page-hero-overlay{position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(30,22,16,0.55),rgba(30,22,16,0.55));}
.page-hero-content{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;}
.page-hero-title{font-family:var(--serif);font-size:clamp(40px,5vw,64px);
  font-weight:300;color:#fff;letter-spacing:4px;text-transform:uppercase;
  text-shadow:0 2px 24px rgba(0,0,0,0.45);}
.page-hero-sub{font-family:var(--serif);font-style:italic;font-size:20px;
  color:#fff;margin-top:12px;
  text-shadow:0 0 2px #000,0 0 3px #000,0 1px 2px rgba(0,0,0,0.9),0 2px 4px rgba(0,0,0,0.8);}

/* ROOM DETAIL */
.room-detail{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-bottom:3px;}
.room-detail:nth-child(even) .room-detail-img{order:2;}
.room-detail:nth-child(even) .room-detail-text{order:1;}
.room-detail-img{width:100%;height:500px;object-fit:cover;display:block;}
.room-detail-text{padding:72px 64px;display:flex;flex-direction:column;
  justify-content:center;background:#fff;}
.room-detail-color-bar{width:44px;height:3px;margin-bottom:28px;}
.room-detail-name{font-family:var(--serif);font-size:42px;font-weight:300;
  color:var(--text);line-height:1;}
.room-detail-name em{font-style:italic;}
.room-features{margin-top:36px;display:flex;flex-direction:column;gap:0;}
.room-feature{display:flex;align-items:center;gap:14px;
  padding:11px 0;border-bottom:1px solid #f0ece4;
  font-size:13px;color:var(--muted);letter-spacing:0.3px;font-weight:300;}
.room-feature:last-child{border-bottom:none;}
.room-feature::before{content:'—';color:var(--gold);font-size:10px;flex-shrink:0;}

/* ── SHARED SPACES — EDITORIAL ── */
.shared-editorial{padding:0;}
.shared-editorial-intro{
  padding:90px 48px 70px;
  text-align:center;
  background:var(--cream);
}
.shared-editorial-intro h2{
  font-family:var(--serif);font-size:clamp(36px,4vw,52px);
  font-weight:300;color:var(--text);
  max-width:640px;margin:0 auto;line-height:1.2;
}
.shared-editorial-intro h2 em{font-style:italic;color:var(--terra);}
.shared-editorial-intro p{
  font-size:15px;line-height:1.9;color:var(--muted);font-weight:300;
  max-width:520px;margin:24px auto 0;
}
.shared-feature-large{
  display:grid;grid-template-columns:55% 45%;
  height:560px;
}
.shared-feature-large.reverse{grid-template-columns:45% 55%;}
.shared-feature-large.reverse .shared-feature-img{order:2;}
.shared-feature-large.reverse .shared-feature-body{order:1;}
.shared-feature-img{position:relative;overflow:hidden;}
.shared-feature-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.7s;}
.shared-feature-large:hover .shared-feature-img img{transform:scale(1.04);}
.shared-feature-body{
  padding:64px 56px;
  display:flex;flex-direction:column;justify-content:center;
  background:#fff;
}
.shared-feature-body.bg-cream{background:var(--cream2);}
.shared-feature-body.bg-dark{background:var(--dark);}
.shared-feature-num{
  font-family:var(--serif);font-size:72px;font-weight:300;
  color:var(--gold);opacity:0.4;line-height:1;
  margin-bottom:-10px;
}
.shared-feature-title{
  font-family:var(--serif);font-size:36px;font-weight:300;
  color:var(--text);line-height:1.15;
}
.shared-feature-title.light{color:#fff;}
.shared-feature-desc{
  font-size:14px;line-height:1.9;color:var(--muted);
  margin-top:20px;font-weight:300;max-width:400px;
}
.shared-feature-desc.light{color:rgba(255,255,255,0.55);}
.shared-feature-tags{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:28px;
}
.shared-tag{
  padding:6px 14px;border:1px solid var(--cream3);
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:var(--muted);
}
.shared-tag.light{border-color:rgba(255,255,255,0.2);color:rgba(255,255,255,0.5);}

/* WELLNESS PAIR */
.wellness-pair{
  display:grid;grid-template-columns:1fr 1fr;
  height:420px;
}
.wellness-half{position:relative;overflow:hidden;cursor:default;}
.wellness-half img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s;}
.wellness-half:hover img{transform:scale(1.04);}
.wellness-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(30,22,16,0.75),transparent 50%);
}
.wellness-label{
  position:absolute;bottom:0;left:0;right:0;padding:32px;
}
.wellness-label-title{
  font-family:var(--serif);font-size:28px;font-weight:300;color:#fff;
}
.wellness-label-sub{
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold);margin-top:6px;
}

/* PRICES */
.prices-section{padding:100px 0;}
.price-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;margin-top:60px;}
.price-card{padding:44px 22px 40px;background:#fff;text-align:center;
  position:relative;transition:transform 0.3s,box-shadow 0.3s;
  display:flex;flex-direction:column;}
.price-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(0,0,0,0.09);z-index:1;}
.price-card.featured{background:var(--terra);}
.price-card.featured .price-season,
.price-card.featured .price-period,
.price-card.featured .price-dates,
.price-card.featured .price-amount,
.price-card.featured .price-currency,
.price-card.featured .price-per,
.price-card.featured .price-daily,
.price-card.featured .price-includes{color:#fff;}
.price-card.featured .price-dates{color:var(--gold-light);}
.price-card.featured .price-daily{color:rgba(255,255,255,0.7);}
.price-season{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.price-period{font-family:var(--serif);font-size:15px;font-style:italic;color:var(--muted);margin-bottom:32px;}
.price-dates{font-family:var(--serif);font-size:19px;font-weight:400;color:var(--terra);
  line-height:1.45;letter-spacing:0.3px;min-height:56px;
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2px;}
.price-amount{font-family:var(--serif);font-size:48px;font-weight:300;line-height:1;color:var(--text);}
.price-currency{font-size:18px;vertical-align:top;margin-top:8px;display:inline-block;font-weight:300;}
.price-per{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-top:10px;}
.price-divider{width:32px;height:1px;background:var(--gold);margin:22px auto;}
.price-card.featured .price-divider{background:rgba(255,255,255,0.3);}
.price-daily{font-size:13px;letter-spacing:1px;color:var(--muted);font-weight:400;font-family:var(--serif);font-style:italic;}
.price-includes{font-size:13px;line-height:2.1;color:var(--muted);}

/* BOOKING FORM */
.booking-section{background:var(--dark);padding:100px 0;}
.booking-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
/* min-width:0 lets the form (a grid item) shrink below its min-content width.
   Without it the fixed-width reCAPTCHA iframe (304px) sets a min-content floor
   that forces every field and the button to 304px, overflowing narrow phones. */
.booking-form{display:flex;flex-direction:column;gap:16px;min-width:0;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-field{display:flex;flex-direction:column;gap:8px;min-width:0;}
.form-input,.form-select,.form-textarea{width:100%;}
/* The reCAPTCHA widget is a fixed 304px iframe; scale it down so it fits
   inside the form column on the narrowest phones without forcing overflow. */
.form-captcha{overflow:hidden;min-width:0;}
.form-captcha .g-recaptcha{transform-origin:0 0;}
.form-label{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.45);}
.form-input{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.13);
  color:#fff;padding:14px 16px;font-family:var(--sans);font-size:14px;
  outline:none;transition:border-color 0.3s;}
.form-input:focus{border-color:var(--gold);}
.form-input::placeholder{color:rgba(255,255,255,0.25);}
.form-select{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.13);
  color:#fff;padding:14px 16px;font-family:var(--sans);font-size:14px;
  outline:none;appearance:none;cursor:pointer;}
.form-select option{background:#1E1610;}
.form-textarea{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.13);
  color:#fff;padding:14px 16px;font-family:var(--sans);font-size:14px;
  outline:none;resize:vertical;min-height:120px;}
.booking-info-title{font-family:var(--serif);font-size:42px;font-weight:300;color:#fff;line-height:1.2;}
.booking-info-sub{font-size:14px;line-height:1.9;color:rgba(255,255,255,0.45);margin-top:20px;font-weight:300;}
.booking-info-points{margin-top:36px;display:flex;flex-direction:column;gap:16px;}
.booking-point{display:flex;align-items:flex-start;gap:16px;}
.booking-point-icon{width:8px;height:8px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:6px;}
.booking-point-text{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.7;}

/* LOCATION */
.location-hero-quote{
  background:var(--cream2);
  padding:100px 48px;
  text-align:center;
  border-bottom:1px solid var(--cream3);
}
.location-hero-quote blockquote{
  font-family:var(--serif);
  font-size:clamp(26px,3.5vw,46px);
  font-weight:300;font-style:italic;
  color:var(--text);
  max-width:780px;margin:0 auto;
  line-height:1.4;
}
.location-hero-quote blockquote em{color:var(--terra);}
.location-body{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;
  background:var(--cream);
}
.location-distances-panel{
  padding:80px 64px 80px 72px;
  border-right:1px solid var(--cream3);
}
.location-map-panel{padding:80px 64px;}
.distance-category{
  font-size:9px;letter-spacing:5px;text-transform:uppercase;
  color:var(--gold);margin-top:40px;margin-bottom:8px;
}
.distance-category:first-child{margin-top:0;}
.distance-item{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:13px 0;border-bottom:1px solid var(--cream3);
}
.distance-name{font-size:14px;color:var(--text);font-weight:400;}
.distance-val{
  font-family:var(--serif);font-size:20px;color:var(--terra);font-weight:300;
}
.map-placeholder{
  width:100%;aspect-ratio:4/3;
  background:var(--cream2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:16px;border:1px solid var(--cream3);
  position:relative;overflow:hidden;
}
.map-pin{font-size:48px;}
.map-label{font-family:var(--serif);font-size:22px;color:var(--text);font-weight:300;}
.map-coords{font-size:11px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;}
.location-how-to{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;
  background:var(--cream2);

}
.how-to-item{
  padding:56px 48px;
  border-right:1px solid var(--cream3);
}
.how-to-item:last-child{border-right:none;}
.how-to-icon{
  font-family:var(--serif);font-size:36px;color:var(--gold);
  margin-bottom:20px;font-weight:300;
}
.how-to-title{
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--text);margin-bottom:12px;font-weight:500;
}
.how-to-desc{font-size:13px;line-height:1.8;color:var(--muted);font-weight:300;}
.sister-section{background:var(--dark);padding:80px 0;}
.sister-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.sister-img{width:100%;height:420px;object-fit:cover;}

/* GALLERY */
.gallery-section{padding:80px 0;background:var(--cream);}
.gallery-intro{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:56px;
}
.gallery-masonry{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:120px;
  gap:4px;
}
.gi{overflow:hidden;cursor:pointer;position:relative;}
.gi img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s;display:block;}
.gi:hover img{transform:scale(1.06);}
.gi::after{
  content:'';position:absolute;inset:0;
  background:rgba(30,22,16,0);transition:background 0.3s;
}
.gi:hover::after{background:rgba(30,22,16,0.15);}
/* Grid placement for luxury editorial layout */
.gi-1{grid-column:1/6;grid-row:1/4;}
.gi-2{grid-column:6/9;grid-row:1/3;}
.gi-3{grid-column:9/13;grid-row:1/3;}
.gi-4{grid-column:6/9;grid-row:3/5;}
.gi-5{grid-column:9/13;grid-row:3/5;}
.gi-6{grid-column:1/5;grid-row:4/6;}
.gi-7{grid-column:5/9;grid-row:5/8;}
.gi-8{grid-column:9/13;grid-row:5/7;}
.gi-9{grid-column:1/5;grid-row:6/8;}
.gi-10{grid-column:9/13;grid-row:7/9;}
.gi-11{grid-column:1/5;grid-row:8/10;}
.gi-12{grid-column:5/9;grid-row:8/10;}
.gi-13{grid-column:9/13;grid-row:9/11;}
.gi-14{grid-column:1/9;grid-row:10/12;}

/* CONTACT */
.contact-section{padding:100px 0;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:stretch;}
.contact-item{
  display:flex;flex-direction:column;
  padding:28px 0;border-bottom:1px solid var(--cream3);
}
.contact-item:last-child{border-bottom:none;}
.contact-label{
  font-size:9px;letter-spacing:5px;text-transform:uppercase;
  color:var(--gold);margin-bottom:10px;
}
.contact-value{font-size:16px;color:var(--text);font-weight:300;line-height:1.6;}
.contact-form{display:flex;flex-direction:column;gap:16px;min-width:0;}
.cf-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:var(--muted);display:block;margin-bottom:8px;}
.cf-input{width:100%;padding:14px 16px;border:1px solid var(--cream3);
  font-family:var(--sans);font-size:14px;outline:none;
  background:#fff;transition:border-color 0.3s;}
.cf-input:focus{border-color:var(--terra);}

/* FOOTER */
footer{background:var(--dark);padding:80px 0 40px;
  border-top:1px solid rgba(201,169,110,0.15);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;
  padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,0.07);}
.footer-brand-title{font-family:var(--serif);font-size:24px;font-weight:300;
  color:#fff;letter-spacing:4px;text-transform:uppercase;}
.footer-brand-sub{font-size:9px;letter-spacing:5px;color:var(--gold);
  text-transform:uppercase;margin-top:4px;}
.footer-brand-desc{font-size:13px;line-height:1.8;color:rgba(255,255,255,0.35);
  margin-top:20px;max-width:280px;}
.footer-col-title{font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold);margin-bottom:20px;}
.footer-link{display:block;font-size:13px;color:rgba(255,255,255,0.45);
  margin-bottom:12px;cursor:pointer;border:none;background:none;
  font-family:var(--sans);text-align:left;transition:color 0.2s;padding:0;
  text-decoration:none;}
.footer-link:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:32px;}
.footer-copy{font-size:12px;color:rgba(255,255,255,0.25);}

/* BTN */
.btn-terra{background:var(--terra);color:#fff;border:none;
  display:inline-block;text-decoration:none;
  padding:16px 44px;font-family:var(--sans);font-size:10px;letter-spacing:3px;
  text-transform:uppercase;font-weight:600;cursor:pointer;transition:all 0.3s;}
.btn-terra:hover{background:var(--terra-dark);transform:translateY(-2px);}

/* ANIMATIONS */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(30px);}
  to{opacity:1;transform:translateY(0);}
}
@keyframes scrollLine{
  0%{transform:scaleY(0);transform-origin:top;}
  50%{transform:scaleY(1);transform-origin:top;}
  51%{transform:scaleY(1);transform-origin:bottom;}
  100%{transform:scaleY(0);transform-origin:bottom;}
}

.welcome-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:center;}
.welcome-img-wrap{position:relative;}
.welcome-img{width:100%;height:520px;object-fit:cover;}
.welcome-img-accent{position:absolute;bottom:-24px;right:-24px;
  width:160px;height:160px;border:2px solid var(--gold);z-index:-1;}
.welcome-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;
  background:var(--cream2);margin-top:40px;}
.stat-box{background:var(--cream);padding:28px 24px;text-align:center;}
.stat-num{font-family:var(--serif);font-size:42px;font-weight:300;
  color:var(--terra);line-height:1;}
.stat-label{font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--muted);margin-top:8px;}

/* ── ROOMS PREVIEW ── */
.rooms-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;
  margin-top:60px;}

/* RESPONSIVE */

/* ── TABLET (max 1024px) ── */
@media(max-width:1024px){
  .section-inner{padding:0 32px;}
  .welcome-grid{gap:48px;}
  .price-grid{grid-template-columns:1fr 1fr;}
  .price-card.featured{grid-column:1 / -1;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px;}
  .gallery-masonry{grid-template-columns:repeat(8,1fr);}
  .gi-1{grid-column:1/5;grid-row:1/4;}
  .gi-2{grid-column:5/9;grid-row:1/3;}
  .gi-3{grid-column:5/9;grid-row:3/5;}
  .gi-4,.gi-5,.gi-6{grid-column:span 4;}
  .gi-7,.gi-8,.gi-9{grid-column:span 4;}
  .gi-10,.gi-11,.gi-12,.gi-13,.gi-14{grid-column:span 4;}
}

/* ── MOBILE (max 768px) ── */
@media(max-width:768px){
  /* NAV */
  #nav{padding:0 20px;height:64px;}
  #nav.scrolled{height:56px;}
  .nav-logo-title{font-size:16px;letter-spacing:3px;}
  .nav-right{gap:14px;}
  .nav-lang{gap:6px;}
  .lang-btn{font-size:10px;letter-spacing:1.5px;}
  .nav-links{display:none;}
  .hamburger{display:flex !important;}
  .nav-links.open{
    display:flex;flex-direction:column;gap:0;
    position:fixed;top:0;left:0;right:0;bottom:0;
    background:rgba(30,22,16,0.98);
    align-items:center;justify-content:center;
    z-index:199;
  }
  .nav-links.open .nav-link{
    font-size:14px;letter-spacing:4px;padding:18px 0;
    border-bottom:1px solid rgba(255,255,255,0.08);
    width:200px;text-align:center;
  }
  .hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:201;padding:8px;background:none;border:none;}
  .hamburger span{width:24px;height:1.5px;background:#fff;
    transition:all 0.3s;display:block;}
  .hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
  .hamburger.open span:nth-child(2){opacity:0;}
  .hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

  /* HERO — keep "Casa Rustica" on one line without overflowing the viewport
     (the inline white-space:nowrap means the title can't wrap, so the size
     must be small enough to fit the narrow screen). */
  .hero-title{font-size:clamp(42px,11vw,80px) !important;letter-spacing:2px !important;}
  .hero-subtitle{font-size:16px;letter-spacing:1px;}
  .hero-cta{flex-direction:column;align-items:center;gap:12px;}
  .btn-gold,.btn-outline{width:220px;text-align:center;}

  /* PAGE HERO */
  .page-hero{height:35vh;min-height:240px;}
  .page-hero-title{font-size:clamp(32px,8vw,48px);letter-spacing:2px;}
  .page-hero-sub{font-size:14px;}

  /* SECTION */
  .section{padding:64px 0;}
  .section-inner{padding:0 20px;}
  .section-title{font-size:clamp(28px,6vw,40px);}

  /* WELCOME */
  #welcome-grid{grid-template-columns:1fr !important;gap:0 !important;}
  #welcome-text{order:1 !important;padding:48px 20px 32px !important;}
  #welcome-img-col{order:2 !important;}
  .welcome-img{height:280px;}
  .welcome-img-accent{display:none;}
  #welcome-stats{grid-template-columns:repeat(3,1fr) !important;display:flex !important;justify-content:space-between;}
  #welcome-stats div[style*="font-size:42px"]{font-size:24px !important;}
  #welcome-stats div[style*="padding:24px"]{padding:16px 6px 0 !important;}
  .stat-box{padding:16px 8px;}
  .stat-label{font-size:8px;letter-spacing:2px;}

  /* ROOMS HOME */
  .rooms-2x2{grid-template-columns:1fr !important;}
  #rooms-home-grid{grid-template-columns:1fr !important;}
  .room-card img{height:320px;}

  /* SPLIT SECTIONS (taverna, wellness) */
  .split-grid{grid-template-columns:1fr !important;}
  .split-img{height:280px;}
  .split-text{padding:48px 24px !important;order:2 !important;}
  .split-grid > img{order:1;}

  /* TAVERNA FULL WIDTH */
  div[style*="grid-template-columns:55% 45%"]{
    grid-template-columns:1fr !important;
  }
  div[style*="grid-template-columns:55% 45%"] > div:first-child{
    height:280px;
  }
  div[style*="grid-template-columns:55% 45%"] > div:last-child{
    padding:40px 24px !important;
  }

  /* OFFERS STRIP */
  div[style*="grid-template-columns:repeat(3,1fr)"]{
    grid-template-columns:1fr !important;
  }

  /* SISTER BANNER */
  .sister-banner{padding:56px 0;}
  .sister-grid{grid-template-columns:1fr !important;gap:0 !important;}
  .sister-img{height:260px;}

  /* PRICES */
  .price-grid{grid-template-columns:1fr !important;}
  .price-card.featured{margin-top:0;}

  /* BOOKING */
  .booking-grid{grid-template-columns:1fr !important;gap:40px;}
  .booking-section{padding:64px 0;}
  .form-row{grid-template-columns:1fr !important;}

  /* LOCATION */
  .location-hero-quote{padding:56px 20px;}
  .location-hero-quote blockquote{font-size:clamp(20px,5vw,30px);}
  .location-body{grid-template-columns:1fr !important;}
  .location-distances-panel{padding:48px 20px;border-right:none;border-bottom:1px solid var(--cream3);}
  .location-map-panel{padding:40px 20px;}
  .location-how-to{grid-template-columns:1fr !important;}
  .how-to-item{border-right:none !important;border-bottom:1px solid var(--cream3);padding:40px 20px;}

  /* ACCOMMODATION INTRO */
  #accom-intro-grid{grid-template-columns:1fr !important;gap:0 !important;}

  /* ACCOMMODATION ROOMS — text first, carousel second */
  #room-sea,#room-sun,#room-olive,#room-earth{
    grid-template-columns:1fr !important;
    gap:0 !important;
    margin-bottom:56px !important;
  }
  /* SEA & OLIVE: carousel is first child → push to order 2 */
  #room-sea > div:first-child,
  #room-olive > div:first-child{order:2 !important;}
  #room-sea > div:last-child,
  #room-olive > div:last-child{order:1 !important;padding:32px 20px !important;}
  /* SUN & EARTH: text is first child → keep order 1, carousel order 2 */
  #room-sun > div:first-child,
  #room-earth > div:first-child{order:1 !important;padding:32px 20px !important;}
  #room-sun > div:last-child,
  #room-earth > div:last-child{order:2 !important;}
  /* Carousel on mobile: full-bleed (edge to edge) and taller. The carousel
     lives inside a horizontally-padded wrapper; width:100vw plus the centering
     offsets break it out to the full screen width regardless of that padding. */
  #room-sea > div[style*="position:relative"],
  #room-sun > div[style*="position:relative"],
  #room-olive > div[style*="position:relative"],
  #room-earth > div[style*="position:relative"]{
    height:440px !important;
    width:100vw !important;
    left:50% !important;
    right:50% !important;
    margin-left:-50vw !important;
    margin-right:-50vw !important;
  }
  /* Each slide image must be exactly the track width so the translateX(n*100%)
     steps land on slide boundaries. The inline min-width:100% lets the image's
     intrinsic width leak through (mis-stepping the carousel, last slide bleeds);
     width:100% pins it, height:100% fills the taller frame. */
  #room-sea img,#room-sun img,#room-olive img,#room-earth img{
    width:100% !important;height:100% !important;
  }

  /* SHARED SPACES */
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:24px"]{
    grid-template-columns:1fr !important;
  }

  /* GALLERY */
  .gallery-masonry{display:flex !important;flex-direction:column !important;}
  .gi{height:260px !important;grid-column:auto !important;grid-row:auto !important;}
  .gallery-intro{flex-direction:column;gap:24px;align-items:flex-start;}
  /* Stack the inline-grid gallery into one full-width column on mobile so each
     photo shows at full size, one after another (no micro thumbnails). */
  .gallery-grid{padding:0 16px;}
  .gallery-grid > div{display:block !important;height:auto !important;}
  .gallery-grid > div > div,
  .gallery-grid > div > div > div{height:auto !important;margin-bottom:6px;}
  .gallery-grid img{height:auto !important;}

  /* CONTACT */
  .contact-grid{grid-template-columns:1fr !important;}
  .contact-section{padding:64px 0;}
  .contact-form > div[style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr !important;
  }

  /* FOOTER */
  .footer-grid{grid-template-columns:1fr !important;gap:32px;}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center;}

  /* MISC */
  .btn-terra,.btn-gold{padding:14px 32px;}
  .booking-info-title{font-size:32px;}
  .welcome-facts-strip{grid-template-columns:1fr 1fr !important;}
  .welcome-fact{padding:24px 16px;}
  .price-card{padding:40px 28px;}
  .distance-item{flex-wrap:wrap;gap:4px;}
  .location-distances-panel h2{font-size:28px;}
}

/* ── SMALL MOBILE (max 480px) ── */
@media(max-width:480px){
  .hero-title{font-size:clamp(36px,10vw,60px) !important;}
  .section-inner{padding:0 16px;}
  .welcome-stats{grid-template-columns:1fr 1fr 1fr !important;}
  .welcome-fact-num{font-size:36px;}
  .price-grid{grid-template-columns:1fr !important;}
  .gallery-intro .btn-terra{width:100%;}
}

/* ── NARROW PHONES (max 360px) ── */
/* The reCAPTCHA iframe is a fixed 304px; on the narrowest phones it would still
   exceed the form column, so scale it down to stay fully visible and clickable.
   .form-captcha's overflow:hidden is the backstop that prevents any residual
   page-level horizontal scroll on even smaller widths. */
@media(max-width:360px){
  .form-captcha .g-recaptcha{transform:scale(0.85);}
}

.errorlist{list-style:none;margin:6px 0 0;padding:0;color:#b00020;font-size:12px;letter-spacing:.3px;}
