/* ============================================================
   Elafonisi Couples Retreat — v2 Design System | AGENTHS
   Mediterranean editorial · cream base · olive/sage greens · terracotta
   Mobile-first · EL/EN · left-slide drawer nav
   ============================================================ */

:root{
  --olive:#3a4230; --olive-d:#272d1e; --olive-dd:#1c2015; --sage:#7d886a; --sage-l:#aab09a;
  --terra:#bd6b3c; --terra-d:#9a5530; --terra-l:#d98c5c;
  --cream:#f4efe4; --paper:#faf7ef; --sand:#e9e0cf; --stone:#ded3bf;
  --ink:#241f17; --ink-l:#6c6453; --ink-xl:#938a76;
  --line:rgba(58,66,48,.14); --line-2:rgba(58,66,48,.08);
  --serif:'Fraunces',Georgia,serif; --sans:'Outfit',system-ui,-apple-system,sans-serif;
  --maxw:1280px; --gut:clamp(18px,5vw,40px);
  --ease:cubic-bezier(.19,1,.22,1);
  --shadow:0 30px 70px -40px rgba(36,31,23,.5);
  --hdr-h:84px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);font-weight:300;line-height:1.72;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-.015em;color:var(--ink)}
h1,h2,h3,h4,p,li,a,span{overflow-wrap:break-word}
em{font-style:italic}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--terra);color:#fff}
:focus-visible{outline:2px solid var(--terra);outline-offset:3px;border-radius:2px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);position:relative;z-index:2}
.center{text-align:center}
.tag{display:inline-flex;align-items:center;gap:9px;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--terra-d);font-weight:500;margin-bottom:20px}
.tag::before{content:'';width:26px;height:1px;background:var(--terra);opacity:.7}
.tag.c::before{display:none}
.eyebrow{font-size:12.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--sage);font-weight:500}

/* buttons */
.btn{position:relative;display:inline-flex;align-items:center;gap:10px;padding:15px 32px;background:var(--olive);color:var(--cream);border-radius:46px;font-size:14px;font-weight:400;letter-spacing:.02em;line-height:1;white-space:nowrap;transition:.45s var(--ease);cursor:pointer;border:1.5px solid var(--olive);overflow:hidden}
.btn>span{position:relative;z-index:2}
.btn::after{content:'';position:absolute;inset:0;background:var(--terra);transform:translateY(101%);transition:.5s var(--ease);z-index:1}
.btn:hover{border-color:var(--terra);color:#fff}
.btn:hover::after{transform:translateY(0)}
.btn .ar{transition:transform .45s var(--ease);position:relative;z-index:2}
.btn:hover .ar{transform:translateX(5px)}
.btn-o{background:transparent;color:var(--ink);border-color:rgba(58,66,48,.32)}
.btn-o:hover{color:#fff;border-color:var(--terra)}
.btn-light{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn-light:hover{color:#fff;border-color:var(--terra)}
.btn-light::after{background:var(--terra)}
.link{display:inline-flex;align-items:center;gap:8px;font-weight:500;font-size:14.5px;color:var(--ink);position:relative;white-space:nowrap}
.link::after{content:'';position:absolute;left:0;bottom:-3px;height:2px;width:100%;background:var(--terra);transform:scaleX(0);transform-origin:left;transition:.4s var(--ease)}
.link:hover::after{transform:scaleX(1)}
.link .ar{transition:.4s var(--ease)}
.link:hover .ar{transform:translateX(4px)}

/* reveal motion */
.reveal{opacity:0;transform:translateY(40px);transition:1s var(--ease)}
.reveal.in{opacity:1;transform:none}
[data-d="1"]{transition-delay:.08s}[data-d="2"]{transition-delay:.16s}[data-d="3"]{transition-delay:.24s}
[data-d="4"]{transition-delay:.32s}[data-d="5"]{transition-delay:.4s}[data-d="6"]{transition-delay:.48s}

/* ============ NAV ============ */
header{position:fixed;top:0;left:0;right:0;z-index:60;padding:22px 0;transition:.5s var(--ease)}
header.scrolled{background:rgba(244,239,228,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:11px 0;box-shadow:0 1px 0 var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:22px}
.brand{display:flex;align-items:center;line-height:1;flex-shrink:0}
.brand img{height:54px;width:auto;transition:height .5s var(--ease)}
header.scrolled .brand img{height:44px}
.brand .lg-dark{display:none}
header.light .brand .lg-light{display:block}
header.light .brand .lg-dark{display:none}
header.scrolled .brand .lg-light{display:none}
header.scrolled .brand .lg-dark{display:block}
.nav-links{display:flex;gap:30px;align-items:center;flex:1;justify-content:center}
.nav-links a{font-size:14.5px;letter-spacing:.01em;transition:.3s;position:relative;padding:4px 0;color:var(--ink);white-space:nowrap}
header.light .nav-links a{color:rgba(255,255,255,.94)}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;height:1.5px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:left;transition:.4s var(--ease);opacity:.85}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--terra)}
header.light .nav-links a.active{color:#fff}
.nav-right{display:flex;align-items:center;gap:18px;flex-shrink:0}
.nav-cta{padding:10px 22px;border:1.5px solid currentColor;border-radius:40px;font-size:13px;letter-spacing:.06em;white-space:nowrap;transition:.4s var(--ease)}
.nav-cta:hover{background:var(--terra);border-color:var(--terra);color:#fff!important}
header.light .nav-cta{border-color:rgba(255,255,255,.55)}

/* language switch */
.langsw{display:inline-flex;align-items:center;gap:6px;font-size:13px;letter-spacing:.06em;font-weight:500;color:var(--ink)}
header.light .langsw{color:rgba(255,255,255,.92)}
.langsw button{background:none;border:none;cursor:pointer;font:inherit;color:inherit;opacity:.55;padding:2px 1px;transition:.3s;letter-spacing:.08em}
.langsw button.active{opacity:1;color:var(--terra)}
header.light .langsw button.active{color:#fff;text-decoration:underline;text-underline-offset:4px}
.langsw .sep{opacity:.4}

/* burger */
.burger{display:none;width:46px;height:46px;background:none;border:none;cursor:pointer;color:inherit;flex-direction:column;justify-content:center;align-items:flex-end;gap:6px}
header.light .burger span{background:#fff}
.burger span{display:block;height:1.7px;width:26px;background:var(--ink);transition:.4s var(--ease);transform-origin:center}
.burger span:nth-child(2){width:19px}
.burger.open span:nth-child(1){transform:translateY(3.8px) rotate(45deg);width:26px}
.burger.open span:nth-child(2){transform:translateY(-3.8px) rotate(-45deg);width:26px}

/* left drawer */
.scrim{position:fixed;inset:0;background:rgba(20,24,15,.5);backdrop-filter:blur(2px);z-index:74;opacity:0;visibility:hidden;transition:.45s var(--ease)}
.scrim.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;left:0;height:100%;height:100dvh;width:min(86vw,360px);background:var(--olive-dd);color:var(--cream);z-index:75;transform:translateX(-100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;padding:30px 30px 36px;overflow-y:auto}
.drawer.open{transform:none}
.drawer-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:38px}
.drawer-brand img{height:50px}
.drawer-close{width:42px;height:42px;border:1px solid rgba(255,255,255,.25);border-radius:50%;background:none;color:var(--cream);font-size:24px;line-height:1;cursor:pointer;flex-shrink:0}
.drawer nav{display:flex;flex-direction:column;gap:4px}
.drawer nav a{font-family:var(--serif);font-size:30px;font-weight:400;color:var(--cream);opacity:.9;padding:9px 0;transition:.3s;border-bottom:1px solid rgba(255,255,255,.07)}
.drawer nav a:hover,.drawer nav a.active{color:var(--terra-l);opacity:1;padding-left:8px}
.drawer-foot{margin-top:auto;padding-top:28px}
.drawer .langsw{font-size:15px;margin-bottom:20px;color:rgba(255,255,255,.92)}
.drawer .langsw button.active{color:var(--terra-l)}
.drawer .btn{width:100%;justify-content:center;margin-bottom:20px}
.drawer-contact{font-size:14px;color:rgba(245,241,232,.7);line-height:1.9}
.drawer-contact a{color:rgba(245,241,232,.7)}
.drawer-contact a:hover{color:var(--terra-l)}

/* ============ HERO ============ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;padding-bottom:clamp(48px,8vh,90px);overflow:hidden}
.hero video,.hero .vbg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero .vbg{background-size:cover;background-position:center}
.hero::after{content:'';position:absolute;inset:0;z-index:1;background:radial-gradient(120% 90% at 70% 20%,transparent 30%,rgba(28,32,21,.35) 100%),linear-gradient(180deg,rgba(28,32,21,.34) 0%,transparent 26%,transparent 52%,rgba(28,32,21,.72) 100%)}
.hero-inner{position:relative;z-index:3;color:#fff;width:100%}
.hero-inner .tag{color:#f0d9bf}
.hero-inner .tag::before{background:#f0d9bf}
.hero h1{font-size:clamp(48px,9.5vw,150px);font-weight:500;letter-spacing:-.025em;color:#fff;text-shadow:0 2px 40px rgba(0,0,0,.25)}
.hero h1 em{font-style:italic;color:#f0d9bf;font-weight:400}
.hero .h-line{display:block;overflow:hidden}
.hero .h-line>span{display:block;transform:translateY(105%);transition:1.1s var(--ease)}
.hero.in .h-line>span{transform:none}
.hero .h-line:nth-child(2)>span{transition-delay:.12s}
.hero .row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:26px;margin-top:30px}
.hero p{max-width:440px;font-size:clamp(15.5px,1.4vw,19px);color:rgba(255,255,255,.94);font-weight:300}
.scroll-cue{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.75);font-size:10.5px;letter-spacing:.32em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-cue::after{content:'';width:1px;height:42px;background:linear-gradient(rgba(255,255,255,.8),transparent);animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* page hero */
.phero{position:relative;height:68vh;min-height:420px;display:flex;align-items:flex-end;padding-bottom:56px;overflow:hidden}
.phero .vbg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transform:scale(1.04)}
.phero::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(28,32,21,.42),transparent 42%,rgba(28,32,21,.66))}
.phero .inner{position:relative;z-index:3;color:#fff}
.phero .tag{color:#f0d9bf}.phero .tag::before{background:#f0d9bf}
.phero h1{font-size:clamp(40px,7vw,96px);color:#fff;font-weight:500}
.phero h1 em{font-style:italic;color:#f0d9bf;font-weight:400}
.phero p{color:rgba(255,255,255,.9);max-width:560px;margin-top:14px;font-size:clamp(15.5px,1.4vw,17px)}

/* ============ MARQUEE ============ */
.marq{background:var(--olive);color:var(--cream);padding:16px 0;overflow:hidden;white-space:nowrap;border-block:1px solid rgba(255,255,255,.08)}
.marq .track{display:inline-block;animation:scrollx 34s linear infinite}
.marq span{font-family:var(--serif);font-size:clamp(17px,2.2vw,24px);font-style:italic;padding:0 14px;opacity:.95}
.marq i{color:var(--terra-l);font-style:normal;padding:0 14px}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ SECTIONS ============ */
section.pad{padding:clamp(72px,12vh,140px) 0;position:relative}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:58px}
.sec-head h2{font-size:clamp(32px,5.4vw,68px)}
.sec-head h2 em{font-style:italic;color:var(--terra)}
.sec-head p{max-width:360px;color:var(--ink-l)}
.lead{max-width:900px}
.lead.center{margin:0 auto}
.lead h2{font-size:clamp(30px,4.8vw,60px);margin-bottom:24px;line-height:1.08}
.lead h2 em{font-style:italic;color:var(--terra)}
.lead p{max-width:640px;color:var(--ink-l);font-size:clamp(15.5px,1.4vw,18.5px)}
.lead.center p{margin-inline:auto}

/* feature split */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center;margin-bottom:clamp(56px,9vw,120px)}
.feature:last-child{margin-bottom:0}
.feature.flip .f-media{order:2}
.f-media{position:relative;overflow:hidden;border-radius:10px}
.f-media img{width:100%;height:clamp(380px,52vw,600px);object-fit:cover;transition:1.4s var(--ease)}
.feature:hover .f-media img{transform:scale(1.05)}
.f-media .cap{position:absolute;left:20px;bottom:20px;background:rgba(244,239,228,.92);backdrop-filter:blur(6px);padding:9px 17px;border-radius:30px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--olive);font-weight:500}
.f-body h2{font-size:clamp(28px,4vw,52px);margin-bottom:20px}
.f-body h2 em{font-style:italic;color:var(--terra)}
.f-body p{color:var(--ink-l);font-size:clamp(15.5px,1.4vw,17px);margin-bottom:18px;max-width:520px}
.f-body .link{margin-top:8px}

/* showcase */
.showcase{position:relative;height:clamp(420px,70vh,720px);overflow:hidden;display:flex;align-items:flex-end}
.showcase .bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.showcase::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(28,32,21,.7));z-index:1}
.showcase .sc-in{position:relative;z-index:2;color:#fff;padding-bottom:clamp(36px,7vh,72px)}
.showcase h2{color:#fff;font-size:clamp(32px,5.5vw,72px);max-width:760px}
.showcase h2 em{font-style:italic;color:#f0d9bf}
.showcase p{color:rgba(255,255,255,.9);max-width:520px;margin-top:14px}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;border-block:1px solid var(--line);padding:44px 0}
.stat{text-align:center}
.stat b{font-family:var(--serif);font-size:clamp(38px,5vw,64px);color:var(--olive);display:block;line-height:1;font-weight:500}
.stat b em{color:var(--terra);font-style:italic}
.stat span{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-l);margin-top:8px;display:block}

/* amenity chips */
.amen-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.achip{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:28px 24px;transition:.5s var(--ease)}
.achip:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.achip .ic{width:44px;height:44px;color:var(--terra);margin-bottom:15px}
.achip h4{font-size:20px;margin-bottom:8px}
.achip p{font-size:14px;color:var(--ink-l)}

/* story split */
.story-g{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,80px);align-items:center}
.story-g h2{font-size:clamp(32px,5vw,64px);margin-bottom:24px}
.story-g h2 em{font-style:italic;color:var(--terra)}
.story-g p{color:var(--ink-l);font-size:17px;margin-bottom:16px;max-width:480px}
.media{position:relative}
.media img{width:100%;border-radius:10px;height:clamp(380px,52vw,560px);object-fit:cover}
.badge{position:absolute;bottom:-26px;left:-26px;background:var(--olive);color:#fff;border-radius:50%;width:148px;height:148px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-family:var(--serif);font-size:14px;line-height:1.15;padding:12px;box-shadow:var(--shadow)}
.badge b{font-size:46px;display:block;line-height:1;color:#f0d9bf}

/* room cards */
.r-row{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.rcard{background:var(--paper);border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:.55s var(--ease);display:flex;flex-direction:column}
.rcard:hover{transform:translateY(-10px);box-shadow:var(--shadow);border-color:transparent}
.rcard .ph{height:268px;overflow:hidden;position:relative}
.rcard .ph div{width:100%;height:100%;background-size:cover;background-position:center;transition:1.2s var(--ease)}
.rcard:hover .ph div{transform:scale(1.07)}
.rcard .pool-flag{position:absolute;top:15px;left:15px;background:var(--terra);color:#fff;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:6px 13px;border-radius:30px;font-weight:500;z-index:2}
.rcard .b{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1}
.rcard small{color:var(--terra-d);font-weight:500;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase}
.rcard h3{font-size:26px;margin:10px 0 11px}
.rcard p{color:var(--ink-l);font-size:14.5px;margin-bottom:20px;flex:1}

/* amenities */
.amen{display:grid;grid-template-columns:repeat(3,1fr);gap:12px 30px;list-style:none;margin-top:8px}
.amen li{position:relative;padding-left:24px;color:var(--ink-l);font-size:15px;padding-block:4px}
.amen li::before{content:'';position:absolute;left:0;top:13px;width:7px;height:7px;border-radius:50%;background:var(--terra)}

/* room detail */
.rd{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center;margin-bottom:clamp(48px,8vw,100px)}
.rd:last-of-type{margin-bottom:0}
.rd:nth-child(even) .rd-media{order:2}
.rd-media{position:relative;overflow:hidden;border-radius:10px}
.rd-media img{height:clamp(320px,46vw,520px);object-fit:cover;border-radius:10px;width:100%;transition:1.4s var(--ease)}
.rd:hover .rd-media img{transform:scale(1.05)}
.rd-media .pool-flag{position:absolute;top:16px;left:16px;background:var(--terra);color:#fff;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:7px 15px;border-radius:30px;font-weight:500}
.rd-meta{display:flex;gap:34px;margin:20px 0 24px;flex-wrap:wrap}
.rd-meta div b{font-family:var(--serif);font-size:30px;color:var(--olive);display:block;line-height:1}
.rd-meta div span{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-l)}

/* dark */
.dark{background:var(--olive-dd);color:var(--cream)}
.dark h2,.dark h3,.dark h4{color:#fff}
.dark h2 em{color:#f0d9bf}
.dark p{color:rgba(245,241,232,.82)}
.dark .tag{color:#e9c9ad}.dark .tag::before{background:#e9c9ad}
.dark .eyebrow{color:var(--sage-l)}
.dark .achip h4{color:var(--ink)}
.dark .achip p{color:var(--ink-l)}

/* agro */
.agro-quote{text-align:center}
.agro-quote h2{font-size:clamp(32px,5.2vw,76px);max-width:1000px;margin:0 auto 28px;color:#fff;line-height:1.06}
.agro-quote h2 em{font-style:italic;color:#f0d9bf}
.agro-quote p{max-width:560px;margin:0 auto;font-size:17px}
.prod-row{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:60px}
.prod{text-align:left}
.prod .ph{height:220px;border-radius:10px;background-size:cover;background-position:center;margin-bottom:16px;overflow:hidden}
.prod h4{font-size:20px;color:#fff;margin-bottom:6px}
.prod p{font-size:13.5px}

/* destinations */
.dest-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:240px;gap:14px}
.dc{position:relative;border-radius:12px;overflow:hidden;background-size:cover;background-position:center;display:flex;align-items:flex-end;transition:.6s var(--ease)}
.dc.big{grid-column:span 2;grid-row:span 2}
.dc.tall{grid-row:span 2}
.dc::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 38%,rgba(28,32,21,.85));transition:.4s;z-index:1}
.dc:hover::after{background:linear-gradient(transparent 20%,rgba(28,32,21,.92))}
.dc span{position:relative;z-index:2;color:#fff;font-family:var(--serif);font-size:23px;padding:22px;font-weight:500}
.dc.big span{font-size:clamp(26px,3vw,40px)}
.dc span small{display:block;font-family:var(--sans);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;opacity:.85;margin-top:4px;font-weight:300}

/* testimonials */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tcard{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:34px 30px;position:relative}
.tcard .q{font-family:var(--serif);font-size:60px;line-height:.6;color:var(--terra);opacity:.35;height:30px}
.tcard .stars{color:var(--terra);letter-spacing:3px;font-size:14px;margin-bottom:14px}
.tcard p{font-family:var(--serif);font-size:18.5px;line-height:1.5;color:var(--ink);margin-bottom:18px;font-style:italic}
.tcard .who{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-l)}
.dark .tcard{background:rgba(255,255,255,.04);border-color:rgba(245,241,232,.14)}
.dark .tcard p{color:#fff}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:14px}
.gal a{position:relative;overflow:hidden;border-radius:10px;background-size:cover;background-position:center}
.gal a::after{content:'';position:absolute;inset:0;background:rgba(28,32,21,0);transition:.5s}
.gal a:hover::after{background:rgba(28,32,21,.18)}
.gal a.tall{grid-row:span 2}
.gal a.wide{grid-column:span 2}

/* CTA band */
.band{text-align:center;position:relative;overflow:hidden}
.band h2{font-size:clamp(32px,5.4vw,82px);margin-bottom:18px}
.band h2 em{font-style:italic;color:var(--terra)}
.band.dark h2 em{color:#f0d9bf}
.band p{max-width:480px;margin:0 auto 16px;font-size:17px}
.perks{display:flex;justify-content:center;gap:clamp(26px,5vw,60px);margin:40px 0 42px;flex-wrap:wrap}
.perk b{font-family:var(--serif);font-size:23px;color:var(--terra);display:block;margin-bottom:4px}
.dark .perk b{color:#f0d9bf}
.perk{font-size:14px;color:var(--ink-l)}
.dark .perk{color:rgba(245,241,232,.82)}

/* contact */
.contact-g{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,64px);align-items:start}
.cinfo h3{font-size:29px;margin-bottom:20px}
.cinfo .line-i{display:flex;gap:14px;padding:13px 0;border-bottom:1px solid var(--line);font-size:16px;color:var(--ink-l)}
.cinfo .line-i b{color:var(--ink);min-width:96px;font-weight:500;font-family:var(--sans)}
.socials{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.socials a{padding:10px 20px;border:1.5px solid var(--line);border-radius:40px;font-size:13px;transition:.4s var(--ease)}
.socials a:hover{background:var(--olive);color:var(--cream);border-color:var(--olive)}
form.cf input,form.cf textarea{width:100%;padding:15px 17px;margin-bottom:14px;border:1.5px solid var(--line);border-radius:8px;background:var(--paper);font-family:var(--sans);font-size:15px;color:var(--ink);transition:.3s}
form.cf textarea{min-height:140px;resize:vertical}
form.cf input:focus,form.cf textarea:focus{outline:none;border-color:var(--terra);background:#fff}
.mapwrap{margin-top:52px;border-radius:12px;overflow:hidden;height:400px;border:1px solid var(--line)}
.mapwrap iframe{width:100%;height:100%;border:0;filter:grayscale(.2) sepia(.08)}

/* footer */
footer{background:var(--olive-dd);color:rgba(245,241,232,.72);padding:clamp(60px,9vw,96px) 0 30px;position:relative}
.f-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:46px;margin-bottom:52px}
.f-brand img{height:62px;margin-bottom:18px}
.f-top h4{font-family:var(--serif);color:var(--cream);font-size:19px;margin-bottom:15px;font-weight:500}
.f-top p{font-size:15px;opacity:.82;max-width:280px}
.f-top a{display:block;padding:6px 0;font-size:15px;opacity:.82;transition:.3s}
.f-top a:hover{opacity:1;color:var(--terra-l);transform:translateX(3px)}
.f-bot{border-top:1px solid rgba(245,241,232,.14);padding-top:22px;display:flex;justify-content:space-between;font-size:13px;flex-wrap:wrap;gap:10px;align-items:center}
.agenths{color:var(--terra-l);transition:.3s}
.agenths:hover{color:#fff}

/* ============ BOOKING WIDGET ============ */
.book-wrap{position:relative;z-index:5;margin-top:clamp(-58px,-4vw,-30px);padding:0 var(--gut)}
.book-bar{max-width:980px;margin:0 auto;background:var(--paper);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:18px 20px;display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}
.book-bar .bf{display:flex;flex-direction:column;gap:7px;flex:1 1 140px;min-width:130px}
.book-bar label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-l);font-weight:500}
.book-bar input,.book-bar select{padding:13px 14px;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-family:var(--sans);font-size:15px;color:var(--ink);transition:.3s;width:100%}
.book-bar input:focus,.book-bar select:focus{outline:none;border-color:var(--terra)}
.book-bar .btn{flex:0 0 auto;height:50px}
.book-bar .bf-note{flex:1 1 100%;font-size:12px;color:var(--ink-xl);margin-top:-2px}
@media(max-width:760px){
  .book-wrap{margin-top:22px}
  .book-bar{flex-direction:column;align-items:stretch;gap:12px;padding:18px}
  .book-bar .bf{min-width:0}
  .book-bar .btn{width:100%;justify-content:center}
}

/* scroll progress + back-to-top */
.scrollbar{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--terra),var(--terra-l));z-index:80;transition:width .12s linear;will-change:width}
.totop{position:fixed;right:clamp(16px,3vw,26px);bottom:clamp(16px,3vw,26px);z-index:55;width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;background:var(--olive);color:#fff;font-size:20px;line-height:1;display:grid;place-items:center;box-shadow:0 14px 30px -12px rgba(36,31,23,.6);opacity:0;transform:translateY(14px);visibility:hidden;transition:.45s var(--ease)}
.totop.show{opacity:1;transform:none;visibility:visible}
.totop:hover{background:var(--terra)}

/* preloader */
#pre{position:fixed;inset:0;z-index:9999;background:var(--cream);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .8s ease,visibility .8s}
#pre.done{opacity:0;visibility:hidden}
.pre-logo-img{width:clamp(160px,30vw,280px);height:auto;opacity:0;transform:translateY(10px) scale(.98);animation:preIn 1s var(--ease) .1s forwards}
.pre-line{width:0;height:1.5px;background:var(--terra);margin-top:16px;animation:preLine 1.5s var(--ease) .5s forwards}
@keyframes preIn{to{opacity:1;transform:none}}
@keyframes preLine{to{width:200px}}
.no-scroll{overflow:hidden}

/* ============ TABLET ============ */
@media(max-width:1040px){
  .nav-links{gap:22px}
  .nav-right{gap:14px}
}
@media(max-width:880px){
  /* collapse to drawer nav */
  .nav-links,.nav-cta{display:none}
  .nav-links{flex:0}
  .burger{display:flex}
  .nav-right{gap:10px}
  .feature,.story-g,.contact-g{grid-template-columns:1fr;gap:34px}
  .feature.flip .f-media{order:0}
  .rd{grid-template-columns:1fr;gap:24px}.rd:nth-child(even) .rd-media{order:0}
  .stats{grid-template-columns:1fr 1fr;gap:34px 20px}
  .amen-row{grid-template-columns:1fr 1fr}
  .prod-row{grid-template-columns:1fr 1fr}
  .tcards{grid-template-columns:1fr}
  .f-top{grid-template-columns:1fr 1fr;gap:34px}
  .sec-head{margin-bottom:42px}
}

/* ============ PHONE ============ */
@media(max-width:600px){
  section.pad{padding:60px 0}
  .wrap{padding:0 18px}
  .lead h2{font-size:28px}
  .sec-head h2,.f-body h2,.story-g h2{font-size:30px}
  .showcase h2,.agro-quote h2,.band h2{font-size:34px}
  .hero p,.lead p,.sec-head p,.phero p,.f-body p{font-size:15.5px}

  /* image height caps (kill endless scroll) */
  .f-media img,.media img{height:300px}
  .rd-media img{height:280px}
  .showcase{height:62vh;min-height:360px}
  .phero{height:60vh;min-height:380px}

  /* room cards & products & testimonials -> horizontal snap carousels */
  .r-row,.tcards,.prod-row{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;margin-inline:calc(var(--gut)*-1);padding:4px var(--gut) 14px;scroll-padding-left:var(--gut)}
  .r-row::-webkit-scrollbar,.tcards::-webkit-scrollbar,.prod-row::-webkit-scrollbar,.gal::-webkit-scrollbar{display:none}
  .r-row{scrollbar-width:none}.tcards{scrollbar-width:none}.prod-row{scrollbar-width:none}
  .rcard{flex:0 0 84%;scroll-snap-align:start}
  .tcard{flex:0 0 86%;scroll-snap-align:start}
  .prod{flex:0 0 70%;scroll-snap-align:start}
  .prod .ph{height:180px}

  /* compact 2-col mosaics for destinations + gallery (no endless 1-col) */
  .dest-grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px;gap:10px}
  .dest-grid .dc.big{grid-column:span 2;grid-row:span 2}
  .dest-grid .dc.tall{grid-row:span 1}
  .dc span{font-size:18px;padding:15px}
  .dc.big span{font-size:25px}
  .dc span small{font-size:10.5px;letter-spacing:.1em}
  .gal{grid-template-columns:1fr 1fr;grid-auto-rows:130px;gap:10px}
  .gal a.tall{grid-row:span 2}.gal a.wide{grid-column:span 2}

  .stats{grid-template-columns:1fr 1fr;gap:30px 16px;padding:36px 0}
  .amen-row{grid-template-columns:1fr 1fr;gap:12px}
  .achip{padding:22px 18px}
  .amen{grid-template-columns:1fr 1fr}
  .rd-meta{gap:24px}
  .perks{gap:24px}
  .f-top{grid-template-columns:1fr;gap:30px}
  .hero .row{gap:20px}
  .hero h1{font-size:clamp(46px,13vw,72px)}
  .sec-head{flex-direction:column;align-items:flex-start;gap:12px}
}

/* tiny phones */
@media(max-width:380px){
  .rcard{flex-basis:90%}
  .hero h1{font-size:42px}
}

/* ============================================================
   AMBIENT MOTION — calm "couples + nature" atmosphere
   layers sit at z-index 1 (above section backgrounds, below .wrap content z-index 2)
   ============================================================ */
#ambient{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.9}
.sun-glow{position:fixed;top:-18vmax;right:-12vmax;width:60vmax;height:60vmax;z-index:1;pointer-events:none;
  background:radial-gradient(closest-side,rgba(246,214,170,.5),rgba(246,214,170,.18) 42%,transparent 70%);
  mix-blend-mode:screen;filter:blur(8px);animation:sunBreath 11s ease-in-out infinite;will-change:transform,opacity}
@keyframes sunBreath{0%,100%{transform:scale(1);opacity:.78}50%{transform:scale(1.09);opacity:1}}
.dark .sun-glow,.dark.sun-glow{mix-blend-mode:soft-light}
/* warm sunlit wash on the base page */
body{background:
  radial-gradient(120vmax 80vmax at 85% -10%,rgba(246,219,179,.45),transparent 55%),
  radial-gradient(90vmax 70vmax at -10% 110%,rgba(141,148,118,.16),transparent 60%),
  var(--cream)}
body{background-attachment:fixed}

/* bubbles (pool / wellness sections) */
.bubbles{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.bubbles .bubble{position:absolute;bottom:-30px;border-radius:50%;
  background:radial-gradient(circle at 32% 30%,rgba(255,255,255,.55),rgba(255,255,255,.12) 55%,transparent 72%);
  border:1px solid rgba(255,255,255,.16);animation:rise linear infinite;opacity:0;will-change:transform,opacity}
@keyframes rise{0%{transform:translateY(0) translateX(0) scale(.7);opacity:0}
  10%{opacity:.7}50%{transform:translateY(-50vh) translateX(14px) scale(1)}
  90%{opacity:.5}100%{transform:translateY(-100vh) translateX(-8px) scale(1.05);opacity:0}}
.showcase .sc-in,.dark .wrap{position:relative;z-index:2}

/* organic wave dividers between sections */
.wave{display:block;width:100%;height:clamp(48px,7vw,110px);position:relative;z-index:2;margin:0;color:var(--cream)}
.wave svg{display:block;width:100%;height:100%}
.wave.up{transform:rotate(180deg)}
.wave .w-anim{animation:waveShift 14s ease-in-out infinite alternate}
.wave-top{position:absolute;top:-1px;left:0;width:100%;height:clamp(42px,6vw,88px);z-index:2;line-height:0;pointer-events:none}
.wave-top svg{display:block;width:100%;height:100%}
.wave-top{animation:waveBob 9s ease-in-out infinite}
@keyframes waveBob{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}
@keyframes waveShift{from{transform:translateX(0)}to{transform:translateX(-40px)}}

/* light-up reveal + warm card glow */
.reveal{filter:saturate(.96)}
.reveal.in{filter:saturate(1)}
.rcard:hover,.achip:hover,.tcard:hover{box-shadow:0 30px 70px -40px rgba(36,31,23,.5),0 0 34px -10px rgba(189,107,60,.28)}
.f-media,.rd-media,.media,.showcase .bg{will-change:transform}

@media(max-width:600px){
  .sun-glow{width:80vmax;height:80vmax}
  .cursor-light{display:none}
  #ambient{opacity:.75}
}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  #ambient,.sun-glow,.cursor-light,.bubbles,.wave .w-anim{display:none!important;animation:none!important}
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .hero .h-line>span{transform:none}
  .marq .track{animation:none}
}
