
:root{
 --green:#5f7d4a;--green-2:#6f8e57;--green-d:#2f3a26;--green-d2:#26301f;
 --gold:#c2974f;--gold-d:#a87f3c;--gold-soft:#e8d7b6;
 --cream:#f4f0e7;--cream-2:#ece5d6;--paper:#fbf9f3;
 --ink:#28311f;--ink-soft:#5d6a52;--line:rgba(40,49,31,.14);--line-d:rgba(244,240,231,.18);
 --serif:"Cormorant Garamond",Georgia,serif;--sans:"Jost",system-ui,sans-serif;--maxw:1240px;
 --sh:0 24px 60px -30px rgba(40,49,31,.4);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html{overflow-x:clip}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);font-size:16px;line-height:1.7;font-weight:300;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:.005em}
::selection{background:var(--green);color:#fff}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-size:.74rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-d)}
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--sans);font-weight:500;font-size:.82rem;
 letter-spacing:.13em;text-transform:uppercase;padding:1.05em 2em;cursor:pointer;border:0;border-radius:6px;transition:.35s cubic-bezier(.2,.8,.2,1)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-d);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-d);transform:translateY(-2px)}
.btn-out{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.6)}
.btn-out:hover{background:#fff;color:var(--ink);transform:translateY(-2px)}

/* HEADER */
header{position:fixed;inset:0 0 auto 0;z-index:1000;padding:16px 0;transition:.4s}
header.scrolled{padding:8px 0;background:var(--paper);box-shadow:0 2px 24px -12px rgba(40,49,31,.4)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px}
.logo{display:flex;align-items:center;gap:12px;flex:none}
.logo-mark{height:52px;width:auto;flex:none;transition:height .4s}
header.scrolled .logo-mark{height:44px}
.logo .lt{font-family:var(--serif);font-size:1.6rem;font-weight:600;line-height:1;letter-spacing:.04em;color:var(--gold-d);display:block;white-space:nowrap}
.logo small{display:block;font-size:.56rem;letter-spacing:.34em;font-weight:500;text-transform:uppercase;color:rgba(255,255,255,.82);margin-top:4px;transition:color .4s;white-space:nowrap}
header.scrolled .logo small{color:var(--green)}
.nav-links{display:flex;gap:22px;list-style:none;flex-wrap:nowrap}
.nav-links a{font-size:.74rem;font-weight:400;letter-spacing:.08em;text-transform:uppercase;color:#fff;opacity:.92;position:relative;padding:4px 0;transition:color .4s}
header.scrolled .nav-links a{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--gold);transition:width .35s}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:#fff}
header.scrolled .nav-links a.active{color:var(--gold-d)}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-phone{display:flex;align-items:center;gap:8px;color:#fff;font-size:.92rem;font-weight:400;transition:color .4s;white-space:nowrap}
header.scrolled .nav-phone{color:var(--ink)}
.nav-phone svg{width:18px;height:18px;color:var(--gold)}
.menu-btn{display:none;width:30px;height:20px;background:none;border:0;position:relative;cursor:pointer;z-index:1100}
.menu-btn span{position:absolute;left:0;height:2px;width:100%;background:#fff;transition:.35s}
header.scrolled .menu-btn span{background:var(--ink)}
.menu-btn span:nth-child(1){top:0}.menu-btn span:nth-child(2){top:9px}.menu-btn span:nth-child(3){top:18px}
body.menu-open .menu-btn span:nth-child(1){top:9px;transform:rotate(45deg);background:#fff}
body.menu-open .menu-btn span:nth-child(2){opacity:0}
body.menu-open .menu-btn span:nth-child(3){top:9px;transform:rotate(-45deg);background:#fff}

/* PAGE HERO (inner pages) */
.phero{position:relative;min-height:62vh;display:flex;align-items:flex-end;overflow:hidden;isolation:isolate}
.phero-bg{position:absolute;inset:0;z-index:-2}
.phero-bg img{width:100%;height:100%;object-fit:cover}
.phero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,30,16,.7) 0%,rgba(20,30,16,.35) 45%,rgba(20,30,16,.78) 100%)}
.phero-inner{position:relative;z-index:2;color:#fff;padding:160px 0 56px}
.phero .eyebrow{color:var(--gold-soft)}
.phero h1{font-size:clamp(2.4rem,5.4vw,4rem);margin:.18em 0 .25em;font-weight:500}
.phero p{max-width:54ch;color:rgba(255,255,255,.9);font-size:1.05rem}
.crumb{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:18px}
.crumb a:hover{color:var(--gold-soft)}

/* HOME HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(20,30,16,.78) 0%,rgba(20,30,16,.45) 42%,rgba(20,30,16,.2) 100%)}
.hero-inner{position:relative;z-index:2;color:#fff;padding:120px 0 200px;max-width:760px}
.hero .eyebrow{color:var(--gold-soft);opacity:0;animation:up .9s .2s forwards}
.hero h1{font-size:clamp(3rem,7vw,5.6rem);margin:.22em 0 .35em;font-weight:500}
.hero h1 span{display:inline-block;opacity:0;animation:up 1s forwards}
.hero p.lead{font-size:1.15rem;font-weight:300;max-width:48ch;color:rgba(255,255,255,.9);margin-bottom:38px;opacity:0;animation:up 1s .9s forwards}
.hero-cta{opacity:0;animation:up 1s 1.05s forwards;display:flex;gap:14px;flex-wrap:wrap}
@keyframes up{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* BOOKING BAR */
.bookbar-wrap{position:relative;z-index:5;margin-top:-86px}
.bookbar{background:rgba(38,48,31,.92);backdrop-filter:blur(8px);border-radius:14px;box-shadow:var(--sh);
 padding:20px 22px;display:grid;grid-template-columns:repeat(4,1fr) auto;gap:14px;align-items:end;color:#fff}
.bf{display:flex;flex-direction:column;gap:7px;border-right:1px solid rgba(255,255,255,.14);padding-right:14px}
.bf:nth-child(5){border-right:0}
.bf label{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.bf .ctl{display:flex;align-items:center;gap:9px}
.bf .ctl svg{width:18px;height:18px;color:var(--gold);flex:none}
.bf input,.bf select{background:transparent;border:0;color:#fff;font-family:var(--sans);font-size:.98rem;width:100%;font-weight:400}
.bf select option{color:#222}
.bf input::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.6}
.bookbar .btn{align-self:stretch;white-space:nowrap}
.avail-pill{position:absolute;top:-14px;left:22px;background:var(--green);color:#fff;font-size:.7rem;font-weight:600;
 letter-spacing:.1em;text-transform:uppercase;padding:.5em 1em;border-radius:100px;box-shadow:var(--sh);display:flex;align-items:center;gap:7px}
.avail-pill::before{content:"";width:8px;height:8px;border-radius:50%;background:#bfe3a0;animation:blip 1.8s infinite}
@keyframes blip{0%{box-shadow:0 0 0 0 rgba(191,227,160,.6)}70%{box-shadow:0 0 0 7px rgba(191,227,160,0)}100%{box-shadow:0 0 0 0 rgba(191,227,160,0)}}

/* SECTION */
.section{padding:clamp(70px,9vw,118px) 0}
.sec-center{text-align:center;max-width:680px;margin:0 auto 56px}
.sec-center h2{font-size:clamp(2.2rem,4.6vw,3.4rem);margin:.25em 0 .5em}
.divider{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:6px;color:var(--gold)}
.divider i{height:1px;width:46px;background:var(--gold);opacity:.6}
.reveal{opacity:0;transform:translateY(38px);transition:opacity 1s cubic-bezier(.2,.8,.2,1),transform 1s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

/* FEATURES */
.features{background:var(--cream)}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.feat{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:34px 26px;transition:.4s}
.feat:hover{transform:translateY(-7px);box-shadow:var(--sh)}
.feat .ic{width:62px;height:62px;border-radius:50%;background:var(--green);display:grid;place-items:center;margin-bottom:20px}
.feat .ic svg{width:28px;height:28px;color:#fff}
.feat h3{font-size:1.4rem;margin-bottom:.3em}
.feat p{font-size:.92rem;color:var(--ink-soft);margin-bottom:1em;min-height:48px}
.feat .more{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-d);font-weight:500;display:inline-flex;gap:7px;align-items:center;transition:gap .3s}
.feat:hover .more{gap:12px}

/* TRUST */
.trust{background:var(--green-d);color:#fff}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.trust .ti{display:flex;align-items:flex-start;gap:16px;padding:38px 28px;border-right:1px solid var(--line-d)}
.trust .ti:last-child{border-right:0}
.trust .ti svg{width:32px;height:32px;color:var(--gold);flex:none;margin-top:3px}
.trust .ti b{font-family:var(--serif);font-size:1.25rem;font-weight:600;display:block;line-height:1.2}
.trust .ti span{font-size:.85rem;color:rgba(255,255,255,.72)}

/* ABOUT */
.about{background:var(--paper)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.about-visual{position:relative}
.about-visual img{width:100%;aspect-ratio:4/3.4;object-fit:cover;border-radius:14px;box-shadow:var(--sh)}
.about-visual .badge{position:absolute;right:-22px;bottom:-22px;background:var(--gold);color:#fff;border-radius:12px;padding:22px 24px;text-align:center;box-shadow:var(--sh)}
.about-visual .badge b{font-family:var(--serif);font-size:2.3rem;font-weight:600;display:block;line-height:1}
.about-visual .badge small{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;opacity:.9}
.about-text h2{font-size:clamp(2rem,4.4vw,3.2rem);margin:.25em 0 .55em}
.about-text p{color:var(--ink-soft);margin-bottom:1.1em;font-size:1.02rem}
.about-text .sign{font-family:var(--serif);font-style:italic;font-size:1.35rem;color:var(--green-d);margin-top:.3em}
.about-text ul{list-style:none;margin:.4em 0 1.4em;display:grid;grid-template-columns:1fr 1fr;gap:10px 18px}
.about-text ul li{display:flex;gap:10px;align-items:flex-start;font-size:.95rem;color:var(--ink-soft)}
.about-text ul svg{width:20px;height:20px;color:var(--green);flex:none;margin-top:2px}

/* ROOMS */
.rooms{background:var(--cream)}
.room-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.room{background:var(--paper);border:1px solid var(--line);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:.4s}
.room:hover{transform:translateY(-8px);box-shadow:var(--sh)}
.room-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--cream-2)}
.room-img img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.room:hover .room-img img{transform:scale(1.07)}
.room-avail{position:absolute;top:12px;right:12px;background:rgba(95,125,74,.95);color:#fff;font-size:.66rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.45em .9em;border-radius:100px;display:flex;align-items:center;gap:6px}
.room-avail::before{content:"";width:6px;height:6px;border-radius:50%;background:#cdeab0}
.room-body{padding:24px;display:flex;flex-direction:column;flex:1}
.room-body h3{font-size:1.6rem;margin-bottom:.15em}
.room-body p{font-size:.92rem;color:var(--ink-soft);margin:.3em 0 1em;flex:1}
.room-amen{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.room-amen span{font-size:.74rem;border:1px solid var(--line);padding:.35em .8em;border-radius:6px;color:var(--green-d)}
.room-foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:16px}
.room-price b{font-family:var(--serif);font-size:1.6rem;font-weight:600}
.room-price small{display:block;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.room .btn{padding:.85em 1.4em;font-size:.74rem}

/* GALLERY */
.gallery{background:var(--paper)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:12px}
.gal-grid figure{overflow:hidden;border-radius:10px;background:var(--cream-2);position:relative;cursor:pointer}
.gal-zoom{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.7);width:46px;height:46px;border-radius:50%;background:rgba(20,28,16,.72);color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:.35s;z-index:2;pointer-events:none}
.gal-zoom svg{width:22px;height:22px}
.gal-grid figure:hover .gal-zoom{opacity:1;transform:translate(-50%,-50%) scale(1)}
.gal-grid img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.gal-grid figure:hover img{transform:scale(1.08)}
.gal-grid figure::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(38,48,31,.4));opacity:0;transition:.4s}
.gal-grid figure:hover::after{opacity:1}
.gal-grid .big{grid-column:span 2;grid-row:span 2}
.gal-grid .wide{grid-column:span 2}

/* ACTIVITIES (image cards) */
.acts{background:var(--cream)}
.act-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.actc{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:.4s}
.actc:hover{transform:translateY(-8px);box-shadow:var(--sh)}
.actc .pic{position:relative;aspect-ratio:16/10;overflow:hidden}
.actc .pic svg{width:100%;height:100%;display:block;transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.pic img{width:100%;height:100%;display:block;object-fit:cover;transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.actc:hover .pic img{transform:scale(1.06)}
.actc:hover .pic svg{transform:scale(1.05)}
.actc .tag{position:absolute;top:12px;left:12px;background:rgba(38,48,31,.86);color:#fff;font-size:.66rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.45em .9em;border-radius:100px;backdrop-filter:blur(3px)}
.actc .feat-badge{position:absolute;top:12px;right:12px;background:var(--gold);color:#fff;font-size:.64rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.45em .85em;border-radius:100px}
.actc-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.actc-body h3{font-size:1.5rem;margin-bottom:.25em}
.actc-body p{font-size:.93rem;color:var(--ink-soft)}
.actc .meta{margin-top:auto;padding-top:16px;display:flex;gap:16px;font-size:.78rem;color:var(--green-d);border-top:1px solid var(--line);margin-top:16px}
.actc .meta span{display:flex;align-items:center;gap:6px}
.actc .meta svg{width:15px;height:15px;color:var(--gold)}

/* RESERVATION */
.reserve{background:var(--cream)}
.reserve-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh);
 display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(34px,5vw,60px);padding:clamp(30px,4.5vw,54px)}
.reserve-card>*{min-width:0}
.form-grid>*{min-width:0}
.reserve-side h2{font-size:clamp(2rem,4.4vw,3rem);margin:.2em 0 .5em}
.reserve-side p{color:var(--ink-soft);margin-bottom:1.2em}
.avail-list{display:flex;flex-direction:column;gap:8px;margin-top:18px}
.avail-list .ai{display:flex;align-items:center;justify-content:space-between;font-size:.88rem;padding:9px 12px;border:1px solid var(--line);border-radius:8px}
.avail-list .ai b{font-weight:500}
.avail-list .ai .ok{color:var(--green);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;display:flex;align-items:center;gap:6px}
.avail-list .ai .ok::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:.96rem;font-weight:300;padding:.8em .9em;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);transition:.25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--green)}
.field textarea{resize:vertical;min-height:80px}
.form-note{font-size:.78rem;color:var(--ink-soft);margin-top:10px;text-align:center}
.form-msg{grid-column:1/-1;padding:14px 16px;font-size:.92rem;display:none;border:1px solid;border-radius:8px}
.form-msg.ok{display:block;background:rgba(95,125,74,.1);color:var(--green-d);border-color:rgba(95,125,74,.3)}
.form-msg.err{display:block;background:rgba(180,80,40,.1);color:#9a4720;border-color:rgba(180,80,40,.3)}

/* CONTACT / FOOTER */
.contact{background:var(--green-d2);color:#fff}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px}
.contact-info h2{font-size:clamp(2rem,4.4vw,3rem);margin-bottom:.4em}
.contact-list{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:20px}
.contact-list li{display:flex;gap:15px;align-items:flex-start}
.contact-list svg{width:24px;height:24px;color:var(--gold);flex:none;margin-top:3px}
.contact-list b{display:block;font-family:var(--serif);font-size:1.25rem;font-weight:600}
.contact-list span{color:rgba(255,255,255,.74);font-size:.92rem}
.contact-list a span:hover{color:var(--gold-soft)}
.socials{display:flex;gap:12px;margin-top:26px}
.socials a{width:42px;height:42px;border-radius:50%;border:1px solid var(--line-d);display:grid;place-items:center;transition:.35s}
.socials a:hover{background:var(--gold);border-color:var(--gold);transform:translateY(-3px)}
.socials svg{width:18px;height:18px}
.contact-map{border-radius:14px;overflow:hidden;min-height:330px;border:1px solid var(--line-d)}
.contact-map iframe{width:100%;height:100%;min-height:330px;border:0;filter:grayscale(.25) contrast(1.05)}
.foot{background:var(--green-d2);color:#fff;border-top:1px solid var(--line-d)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:56px 0 10px}
.foot-brand .logo-mark{height:56px;margin-bottom:14px}
.foot-brand .bname{font-family:var(--serif);font-size:1.5rem;color:var(--gold)}
.foot-brand .bname small{display:block;font-family:var(--sans);font-size:.6rem;letter-spacing:.32em;color:rgba(255,255,255,.6);margin-top:4px}
.foot-brand p{color:rgba(255,255,255,.62);font-size:.9rem;margin-top:14px;max-width:34ch}
.foot-col h4{font-family:var(--sans);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a,.foot-col span{color:rgba(255,255,255,.7);font-size:.92rem;transition:color .25s}
.foot-col a:hover{color:var(--gold-soft)}
.foot-bottom{border-top:1px solid var(--line-d);margin-top:30px;padding:22px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem;color:rgba(255,255,255,.55)}
.foot-bottom a:hover{color:var(--gold-soft)}

/* CTA band */
.ctaband{background:var(--green-d);color:#fff;text-align:center}
.ctaband h2{font-size:clamp(2rem,4.6vw,3.2rem);margin-bottom:.3em}
.ctaband p{color:rgba(255,255,255,.8);max-width:52ch;margin:0 auto 28px}

/* WHATSAPP */
.wa-launcher{position:fixed;right:22px;bottom:22px;z-index:5000;width:60px;height:60px;border-radius:50%;background:#25d366;border:0;cursor:pointer;display:grid;place-items:center;box-shadow:0 14px 34px -10px rgba(37,211,102,.65);transition:transform .35s}
.wa-launcher:hover{transform:scale(1.07)}
.wa-launcher svg{width:32px;height:32px}
.wa-launcher::before{content:"";position:absolute;inset:0;border-radius:50%;background:#25d366;opacity:.5;animation:wap 2.4s ease-out infinite;z-index:-1}
@keyframes wap{0%{transform:scale(1);opacity:.5}100%{transform:scale(1.9);opacity:0}}
.wa-dot{position:absolute;top:-2px;right:-2px;width:20px;height:20px;background:var(--gold);color:#fff;border-radius:50%;font-size:.7rem;font-weight:600;display:grid;place-items:center;border:2px solid var(--cream)}
.wa-panel{position:fixed;right:22px;bottom:94px;z-index:5000;width:336px;max-width:calc(100vw - 36px);background:var(--paper);border-radius:16px;overflow:hidden;box-shadow:0 30px 70px -22px rgba(40,49,31,.55);transform:translateY(20px) scale(.96);opacity:0;pointer-events:none;transform-origin:bottom right;transition:transform .4s cubic-bezier(.2,.85,.25,1),opacity .35s}
.wa-panel.open{transform:none;opacity:1;pointer-events:auto}
.wa-head{background:#075e54;color:#fff;padding:15px 16px;display:flex;align-items:center;gap:11px}
.wa-avatar{width:42px;height:42px;border-radius:50%;background:#fff;display:grid;place-items:center;flex:none;overflow:hidden}
.wa-avatar img{width:34px;height:auto}
.wa-head b{font-size:.98rem;display:block;line-height:1.2}
.wa-head small{font-size:.74rem;opacity:.85;display:flex;align-items:center;gap:6px}
.wa-head small::before{content:"";width:8px;height:8px;border-radius:50%;background:#7fe09a}
.wa-close{margin-left:auto;background:none;border:0;color:#fff;cursor:pointer;font-size:1.4rem;opacity:.85;line-height:1}
.wa-body{padding:20px 16px;background:#ece5dd;min-height:120px}
.wa-bubble{background:#fff;padding:11px 13px;border-radius:0 12px 12px 12px;max-width:90%;font-size:.9rem;color:#1f2c2a;box-shadow:0 1px 1px rgba(0,0,0,.08)}
.wa-bubble small{display:block;font-size:.68rem;color:#8a9690;text-align:right;margin-top:3px}
.wa-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:13px}
.wa-chips button{font-family:var(--sans);font-size:.78rem;font-weight:400;background:#fff;border:1px solid #cfd8d2;color:#075e54;padding:.45em .85em;border-radius:100px;cursor:pointer;transition:.25s}
.wa-chips button:hover{background:#075e54;color:#fff;border-color:#075e54}
.wa-foot{display:flex;gap:8px;padding:11px;background:var(--paper);border-top:1px solid var(--line)}
.wa-foot input{flex:1;border:1px solid var(--line);border-radius:100px;padding:.65em 1em;font-family:var(--sans);font-size:.9rem;background:#fff;font-weight:300}
.wa-foot input:focus{outline:none;border-color:#25d366}
.wa-foot button{width:44px;height:44px;border-radius:50%;border:0;background:#25d366;color:#fff;cursor:pointer;display:grid;place-items:center;flex:none;transition:.25s}
.wa-foot button:hover{background:#1da851}.wa-foot svg{width:20px;height:20px}

/* RESPONSIVE */
@media(max-width:1024px){
 .feat-grid{grid-template-columns:repeat(2,1fr)}
 .trust .wrap{grid-template-columns:repeat(2,1fr)}
 .trust .ti:nth-child(2){border-right:0}.trust .ti{border-bottom:1px solid var(--line-d)}
 .room-grid,.act-grid{grid-template-columns:repeat(2,1fr)}
 .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:920px){
 .about-grid,.reserve-card,.contact-grid{grid-template-columns:1fr;gap:40px}
 .bookbar{grid-template-columns:1fr 1fr}
 .bf:nth-child(3){border-right:0}
 .bookbar .btn{grid-column:1/-1}
 .about-text ul{grid-template-columns:1fr}
}
@media(max-width:1300px){ .nav-phone span{display:none} }
@media(max-width:1200px){ .nav-right .btn{display:none} }
@media(max-width:1024px){
 .menu-btn{display:block}
 .nav-links{position:fixed;inset:0;background:var(--green-d);flex-direction:column;justify-content:center;align-items:center;gap:24px;transform:translateX(100%);transition:transform .5s cubic-bezier(.2,.8,.2,1);text-align:center;padding:0 16px}
 body.menu-open .nav-links{transform:none}
 .nav-links a,header.scrolled .nav-links a{color:#fff;font-size:1.5rem;font-family:var(--serif);letter-spacing:.05em}
 body.rtl .nav-links{left:0;right:0;transform:translateX(-100%)}
 body.rtl.menu-open .nav-links{transform:none}
}
@media(max-width:720px){
 .bookbar-wrap{margin-top:-40px}
 .bookbar{grid-template-columns:1fr}.bf{border-right:0;border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:12px}
 .feat-grid,.room-grid,.gal-grid,.act-grid{grid-template-columns:1fr}
 .gal-grid{grid-auto-rows:230px}.gal-grid .big,.gal-grid .wide{grid-column:span 1;grid-row:span 1}
 .form-grid{grid-template-columns:1fr}
 .about-visual .badge{right:14px}
 .foot-grid{grid-template-columns:1fr;gap:28px}
 .logo .lt{font-size:1.4rem}.logo-mark{height:46px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}.hero h1 span,.hero .eyebrow,.hero p.lead,.hero-cta{opacity:1}}


.route{display:none}.route.active{display:block;animation:routefade .45s ease}
@keyframes routefade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.lang-switch{display:inline-flex;align-items:center;gap:2px;border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:2px;margin-right:6px}
header.scrolled .lang-switch{border-color:rgba(47,58,38,.25)}
.lang-switch button{font-family:'Jost',sans-serif;font-size:.74rem;font-weight:600;letter-spacing:.04em;color:#fff;background:transparent;border:0;cursor:pointer;padding:5px 9px;border-radius:999px;line-height:1;transition:.2s}
header.scrolled .lang-switch button{color:var(--ink,#2f3a26)}
.lang-switch button:hover{color:var(--gold-soft,#e8d7b6)}
.lang-switch button.active{background:var(--gold,#c2974f);color:#fff}
header.scrolled .lang-switch button.active{color:#fff}
.lang-switch button[data-lang="ar"]{font-size:.95rem}
@media(max-width:900px){.lang-switch{margin-right:4px}.lang-switch button{padding:4px 7px;font-size:.7rem}}
/* RTL + Arabic */
body.rtl{direction:rtl}
body.rtl .lang-switch{margin-right:0;margin-left:6px}
body.rtl .crumb,body.rtl .hero-inner,body.rtl .phero-inner,body.rtl .about-text,body.rtl .reserve-side,body.rtl .contact-info{text-align:right}
body.rtl .hero-cta,body.rtl .nav-right{flex-direction:row-reverse}
body.rtl .wa-launcher{right:auto;left:24px}
body.rtl .wa-panel{right:auto;left:24px}
body.rtl .wa-dot{right:auto;left:-4px}
body.lang-ar{font-family:'Cairo','Jost',sans-serif}
body.lang-ar h1,body.lang-ar h2,body.lang-ar h3,body.lang-ar h4,body.lang-ar .lt,body.lang-ar .bname,body.lang-ar .eyebrow{font-family:'Cairo','Cormorant Garamond',serif;font-weight:700}
body.lang-ar .hero h1,body.lang-ar .phero h1{font-weight:700;line-height:1.25}
body.lang-ar .eyebrow{letter-spacing:0}
.nav-links a{white-space:nowrap}
.nav-phone{direction:ltr;unicode-bidi:isolate}
.room-photos{display:block;width:100%;height:100%;border:0;padding:0;margin:0;background:none;cursor:pointer;position:relative}
.room-img .kthumb,.king-preview .kthumb{width:100%;height:100%;object-fit:cover;display:block}
.photos-badge{position:absolute;left:12px;bottom:12px;display:inline-flex;align-items:center;gap:6px;background:rgba(20,28,16,.8);color:#fff;font-family:'Jost',sans-serif;font-size:.72rem;letter-spacing:.04em;padding:6px 11px;border-radius:999px;transition:background .25s}
.photos-badge svg{width:15px;height:15px}
.room-photos:hover .photos-badge,.king-preview:hover .photos-badge{background:var(--gold-d)}
.king-preview{position:relative;display:block;width:100%;border:0;padding:0;margin:20px 0 6px;background:none;cursor:pointer;border-radius:14px;overflow:hidden;aspect-ratio:16/10;box-shadow:0 10px 30px rgba(47,58,38,.16)}
.lightbox{position:fixed;inset:0;z-index:6000;display:none;align-items:center;justify-content:center;background:rgba(12,16,10,.93);padding:28px}
.lightbox.open{display:flex}
.lb-stage{margin:0;display:flex;flex-direction:column;align-items:center;gap:12px}
.lb-stage img{max-width:90vw;max-height:78vh;border-radius:8px;box-shadow:0 24px 70px rgba(0,0,0,.55);object-fit:contain;background:#0c100a}
.lb-cap{color:#f4efe6;font-family:'Jost',sans-serif;font-size:.95rem;letter-spacing:.02em}
.lb-count{position:absolute;top:24px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.78);font-family:'Jost',sans-serif;font-size:.8rem;letter-spacing:.14em}
.lb-btn{position:absolute;background:rgba(255,255,255,.13);color:#fff;border:0;width:48px;height:48px;border-radius:50%;font-size:1.7rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lb-btn:hover{background:var(--gold)}
.lb-close{top:22px;right:22px}
.lb-prev{left:22px;top:50%;transform:translateY(-50%)}
.lb-next{right:22px;top:50%;transform:translateY(-50%)}
body.rtl .photos-badge{left:auto;right:12px}
body.rtl .lb-close{right:auto;left:22px}
body.rtl .lb-prev{left:auto;right:22px;transform:translateY(-50%) scaleX(-1)}
body.rtl .lb-next{right:auto;left:22px;transform:translateY(-50%) scaleX(-1)}
@media(max-width:600px){.lb-btn{width:40px;height:40px;font-size:1.4rem}.lb-prev{left:8px}.lb-next{right:8px}.lb-stage img{max-height:70vh}}

.price-fx{display:block;margin-top:3px;font-size:.72rem;font-weight:500;line-height:1.3;color:var(--gold-d);letter-spacing:.02em;direction:ltr;unicode-bidi:isolate;font-family:var(--sans),'Cairo',sans-serif}
.price-fx:empty{display:none}

.fx-note{margin:18px auto 0;max-width:560px;text-align:center;font-size:.74rem;line-height:1.5;color:var(--ink-soft);font-style:italic}

/* Oda müsait değil rozeti (panelden ayarlanır) */
.room-avail.off{background:#9a9a90;color:#fff}
.room.is-unavailable{opacity:.92}
.room.is-unavailable .room-img::after{content:"";position:absolute;inset:0;background:rgba(47,58,38,.04)}

/* Rezervasyon: müsaitlik sorgu sonucu paneli */
#availWrap[hidden]{display:none}
.avail-result{background:#fbfaf5;border:1px solid var(--line,#e6e1d6);border-radius:14px;padding:14px 16px}
.avail-result .av-head{font-weight:600;color:var(--green-d,#2f3a26);margin-bottom:10px;font-family:'Cormorant Garamond',Georgia,serif;font-size:1.25rem}
.av-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-top:1px solid #ece7db}
.av-row:first-of-type{border-top:none}
.av-name{flex:1;font-weight:500;color:#2c2c28}
.av-price{color:var(--gold-d,#a87f3c);font-weight:600;font-size:.95rem}
.av-badge{font-size:.74rem;padding:3px 10px;border-radius:999px;font-weight:600;white-space:nowrap}
.av-badge.ok{background:#e9f0e2;color:#3c7a3c}
.av-badge.no{background:#f3eef0;color:#b3402f}
.av-row.no .av-name{color:#9a948a}
.av-warn{margin:10px 0 0;color:#b3402f;font-size:.9rem}
body.rtl .av-row{flex-direction:row-reverse}

/* ===== Mobil header + hero düzeltmeleri (tam görünürlük) ===== */
@media(max-width:600px){
  .wrap{padding:0 16px}
  .nav{gap:10px}
  .nav-right{gap:10px}
  .logo{gap:8px}
  .logo-mark{height:38px}
  .logo .lt{font-size:1.18rem}
  .logo small{display:none}            /* tagline gizle; ekran dışı taşmayı önler */
  .nav-phone{display:none}             /* WhatsApp butonu iletişimi karşılıyor */
  .lang-switch{margin-right:2px;padding:2px}
  .lang-switch button{padding:4px 7px;font-size:.7rem}
  .lang-switch button[data-lang="ar"]{font-size:.86rem}
  .hero-inner{padding:104px 16px 150px}
  .hero h1{font-size:clamp(2.3rem,8.5vw,3.3rem)}
  .hero p.lead{font-size:1.02rem}
  .phero-inner{padding:118px 16px 44px}
}
@media(max-width:380px){
  .logo .lt{font-size:1.02rem}
  .nav-right{gap:8px}
  .hero h1{font-size:2.15rem}
}

/* ===== Uluslararası telefon alanı (bayrak + ülke kodu) ===== */
.tel-field{position:relative;display:flex;align-items:stretch;border:1px solid var(--line);border-radius:10px;background:#fff;transition:border-color .2s,box-shadow .2s}
.tel-field:focus-within{border-color:var(--green);box-shadow:0 0 0 3px rgba(95,125,74,.13)}
.tel-field input#phone{border:0;border-radius:0;background:transparent;flex:1;min-width:0;padding:.85em .95em;font-family:var(--sans);font-size:.98rem;font-weight:400;color:var(--ink);letter-spacing:.02em}
.tel-field input#phone:focus{outline:0}
.tel-country{display:flex;align-items:center;gap:8px;padding:0 12px;background:linear-gradient(180deg,#fbf9f4,#f4efe6);border:0;border-right:1px solid var(--line);border-radius:10px 0 0 10px;cursor:pointer;font-family:var(--sans);color:var(--ink);white-space:nowrap;transition:filter .2s}
.tel-country:hover{filter:brightness(.975)}
.tel-flag{display:inline-flex;align-items:center}
.lf-img{width:27px;height:19px;border-radius:3px;object-fit:cover;box-shadow:0 0 0 1px rgba(40,49,31,.14);display:block;flex:none;background:#eee}
.lf-code{display:inline-flex;align-items:center;justify-content:center;width:27px;height:19px;border-radius:3px;background:var(--green);color:#fff;font-size:.62rem;font-weight:700;flex:none}
.tel-dial{font-weight:600;color:var(--green-d,#2f3a26);font-size:.97rem;font-variant-numeric:tabular-nums}
.tel-caret{font-size:.6rem;color:var(--muted,#7a7a70)}
.tel-drop{position:absolute;top:calc(100% + 8px);left:0;z-index:60;width:min(360px,88vw);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 56px -18px rgba(40,49,31,.45);overflow:hidden;animation:telpop .18s ease}
@keyframes telpop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.tel-search-wrap{position:relative;border-bottom:1px solid var(--line)}
.tel-search-wrap svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--muted,#7a7a70);pointer-events:none}
.tel-search{width:100%;border:0;padding:.85em 1em .85em 2.5em;font-size:.94rem;font-family:var(--sans);color:var(--ink);background:#fcfbf7}
.tel-search:focus{outline:0;background:#fff}
.tel-list{list-style:none;margin:0;padding:7px;max-height:262px;overflow-y:auto}
.tel-list li{display:flex;align-items:center;gap:12px;padding:9px 11px;border-radius:9px;cursor:pointer;font-size:.93rem;line-height:1.2;transition:background .15s}
.tel-list li:hover{background:#eef2e8}
.tel-list li .ln{flex:1;color:var(--ink)}
.tel-list li .ld{color:var(--gold-d,#a87f3c);font-weight:600;font-variant-numeric:tabular-nums}
.tel-empty{padding:16px;text-align:center;color:var(--muted,#7a7a70);font-size:.9rem}
body.rtl .tel-country{border-right:0;border-left:1px solid var(--line);border-radius:0 10px 10px 0}
body.rtl .tel-drop{left:auto;right:0}
body.rtl .tel-search{padding:.85em 2.5em .85em 1em}
body.rtl .tel-search-wrap svg{left:auto;right:14px}
body.rtl .tel-list li{flex-direction:row-reverse;text-align:right}

/* ===== HMS online rezervasyon butonu ===== */
.hms-cta-box{margin:2px 0 18px;display:flex;flex-direction:column;align-items:flex-start;gap:8px}
.hms-cta{font-size:1.02rem}
.hms-note{font-size:.85rem;color:var(--ink-soft,#6b6f63);line-height:1.5}
body.rtl .hms-cta-box{align-items:flex-end;text-align:right}
