*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--sand:#d4bc8a;--sand-light:#e8d9ba;--sand-pale:#f7f2e8;--cream:#faf7f2;--ivory:#fffdf8;--charcoal:#1c1916;--warm-gray:#6b6458;--warm-gray-light:#9c9186;--green:#4a6741;--green-light:#7a9b6f;--terracotta:#c4704a}.img-wrap{background:var(--sand-light);isolation:isolate;border-radius:4px;position:relative;overflow:hidden}@keyframes shimmer{0%{background-position:-800px 0}to{background-position:800px 0}}.img-wrap.img-loading:after{content:"";pointer-events:none;z-index:2;background:linear-gradient(90deg,#0000 0%,#ffffff59 40%,#fff9 50%,#ffffff59 60%,#0000 100%) 0 0/800px 100%;animation:1.4s ease-in-out infinite shimmer;position:absolute;inset:0}.img-wrap picture,.img-wrap img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.img-wrap.img-loaded:after{display:none}.img-wrap.img-missing{background:var(--sand-pale)}.img-wrap.img-missing:after{display:none}body{background:var(--ivory);color:var(--charcoal);font-family:Outfit,sans-serif;overflow-x:hidden}nav{z-index:100;justify-content:space-between;align-items:center;padding:1.5rem 3rem;transition:background .4s,padding .4s;display:flex;position:fixed;top:0;left:0;right:0}nav.scrolled{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#faf7f2f5;border-bottom:1px solid #d4bc8a4d;padding:1rem 3rem}.nav-logo img{filter:brightness(0)invert();height:48px;transition:filter .4s}nav.scrolled .nav-logo img{filter:none}.nav-links{gap:2.5rem;list-style:none;display:flex}.nav-links a{letter-spacing:.18em;text-transform:uppercase;color:#ffffffd9;font-family:Outfit,sans-serif;font-size:.78rem;font-weight:400;text-decoration:none;transition:color .3s}nav.scrolled .nav-links a{color:var(--warm-gray)}.nav-links a:hover{color:var(--sand)!important}.nav-book-btn{letter-spacing:.15em;text-transform:uppercase;color:var(--sand);border:1px solid var(--sand);border-radius:2px;padding:.55rem 1.4rem;font-family:Outfit,sans-serif;font-size:.72rem;font-weight:500;text-decoration:none;transition:background .3s,color .3s}.nav-book-btn:hover{background:var(--sand);color:var(--charcoal)}nav.scrolled .nav-book-btn{color:var(--charcoal);border-color:var(--charcoal)}nav.scrolled .nav-book-btn:hover{background:var(--charcoal);color:var(--ivory)}#hero{grid-template-columns:1fr 1fr;align-items:center;height:100vh;min-height:620px;display:grid;position:relative;overflow:hidden}.hero-bg{background:linear-gradient(145deg,#1a0905 0%,#6b2515 28%,#b8532a 58%,#c4704a 80%,#8b4028 100%);position:absolute;inset:0}.hero-texture{background-image:radial-gradient(at 15% 60%,#d4bc8a21 0%,#0000 55%),radial-gradient(at 75% 25%,#c4704a2e 0%,#0000 50%),radial-gradient(at 90% 80%,#6b251540 0%,#0000 40%),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");position:absolute;inset:0}.hero-overlay{background:linear-gradient(90deg,#1a0905bf 0%,#1a090559 50%,#1a09050d 100%),linear-gradient(#0000 60%,#1a090580 100%);position:absolute;inset:0}.palm-left,.palm-right{opacity:.15;fill:#3d1508;position:absolute;bottom:0}.palm-left{left:-20px}.palm-right{right:-20px}.hero-content{z-index:2;text-align:right;grid-column:2;justify-self:end;max-width:680px;padding:0 5rem 0 3rem;animation:1.2s both heroFadeUp;position:relative}.hero-left-accent{z-index:10;flex-direction:column;align-items:center;gap:3.5rem;animation:1.5s .4s both heroFadeUp;display:flex;position:absolute;top:50%;left:2.5rem;transform:translateY(-50%)}.rotating-seal{opacity:.65;width:130px;height:130px;transition:opacity .3s;animation:25s linear infinite rotateSeal}.rotating-seal:hover{opacity:.95}@keyframes rotateSeal{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.vertical-text{writing-mode:vertical-rl;letter-spacing:.35em;color:#fff6;align-items:center;gap:1.5rem;font-family:Outfit,sans-serif;font-size:.72rem;font-weight:300;display:flex;transform:rotate(180deg)}.vertical-text:after,.vertical-text:before{content:"";background:#fff3;width:1px;height:35px;display:block}.hero-oversized-logo{z-index:1;pointer-events:none;-webkit-user-select:none;user-select:none;mix-blend-mode:soft-light;opacity:.8;width:65vw;animation:2.5s cubic-bezier(.2,.8,.2,1) both heroFadeUp;position:absolute;top:50%;right:-5vw;transform:translateY(-50%)}.hero-oversized-logo img{filter:brightness(0)invert();transform-origin:100%;width:100%;transform:scale(2.2)}.hero-eyebrow{letter-spacing:.3em;text-transform:uppercase;color:var(--sand-light);justify-content:flex-end;align-items:center;gap:1rem;margin-bottom:1.5rem;font-family:Outfit,sans-serif;font-size:.7rem;font-weight:400;display:flex}.hero-eyebrow:after{content:"";background:var(--sand-light);opacity:.6;width:40px;height:1px;display:block}.hero-title{color:var(--ivory);letter-spacing:-.01em;margin-bottom:1.5rem;font-family:Playfair Display,serif;font-size:clamp(3.5rem,7vw,6rem);font-weight:300;line-height:1}.hero-title em{color:var(--sand-light);font-style:italic}.hero-tagline{color:#fff9;letter-spacing:.08em;max-width:420px;margin-bottom:2.5rem;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:300;line-height:1.8}.hero-ctas{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:1rem;display:flex}.btn-primary{letter-spacing:.15em;text-transform:uppercase;background:var(--sand);color:var(--charcoal);border-radius:2px;padding:1rem 2.5rem;font-family:Outfit,sans-serif;font-size:.75rem;font-weight:500;text-decoration:none;transition:background .3s,transform .2s}.btn-primary:hover{background:var(--sand-light);transform:translateY(-1px)}.btn-ghost{letter-spacing:.15em;text-transform:uppercase;color:#ffffffbf;border-bottom:1px solid #ffffff4d;padding:1rem 0;font-family:Outfit,sans-serif;font-size:.75rem;font-weight:400;text-decoration:none;transition:color .3s,border-color .3s}.btn-ghost:hover{color:var(--sand-light);border-color:var(--sand-light)}.hero-scroll{z-index:2;letter-spacing:.25em;text-transform:uppercase;color:#fff6;align-items:center;gap:.8rem;font-family:Outfit,sans-serif;font-size:.65rem;animation:1.5s .3s both heroFadeUp;display:flex;position:absolute;bottom:2.5rem;right:5rem}.scroll-line{background:#ffffff40;width:1px;height:50px;position:relative;overflow:hidden}.scroll-line:after{content:"";background:var(--sand);width:1px;height:50px;animation:2s ease-in-out infinite scrollDrop;position:absolute;top:-50px;left:0}@keyframes heroFadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scrollDrop{0%{top:-50px}to{top:50px}}section{padding:7rem 5rem}.section-label{letter-spacing:.3em;text-transform:uppercase;color:var(--sand);align-items:center;gap:.8rem;margin-bottom:1.2rem;font-family:Outfit,sans-serif;font-size:.65rem;font-weight:500;display:flex}.section-label:after{content:"";background:var(--sand);opacity:.6;width:30px;height:1px;display:block}.section-title{color:var(--charcoal);margin-bottom:1.5rem;font-family:Playfair Display,serif;font-size:clamp(2.2rem,4vw,3.2rem);font-weight:300;line-height:1.15}.section-title em{color:var(--green);font-style:italic}.section-body{color:var(--warm-gray);max-width:520px;font-family:Outfit,sans-serif;font-size:.92rem;font-weight:300;line-height:1.9}#about{background:var(--cream);grid-template-columns:1fr 1fr;align-items:center;gap:6rem;display:grid}.about-image-grid{grid-template-rows:220px 220px;grid-template-columns:1fr 1fr;gap:12px;display:grid}.img-wrap.tall{grid-row:span 2}.about-stats{border-top:1px solid #d4bc8a4d;gap:2rem;margin-top:2.5rem;padding-top:2.5rem;display:flex}.stat{flex-direction:column;gap:.3rem;display:flex}.stat-num{color:var(--charcoal);font-family:Playfair Display,serif;font-size:2.2rem;font-weight:300;line-height:1}.stat-label{letter-spacing:.15em;text-transform:uppercase;color:var(--warm-gray-light);font-family:Outfit,sans-serif;font-size:.65rem;font-weight:400}#rooms{background:var(--ivory)}.rooms-intro{grid-template-columns:1fr 1fr;align-items:end;gap:4rem;margin-bottom:4rem;display:grid}.rooms-gallery{grid-template-rows:320px 260px;grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.rooms-gallery .img-wrap:first-child{grid-column:span 2}.rooms-cta{text-align:center;margin-top:3rem}#pool{background:var(--charcoal);color:var(--ivory);grid-template-columns:1fr 1.2fr;align-items:center;gap:6rem;display:grid}#pool .section-title{color:var(--ivory)}#pool .section-title em{color:var(--sand-light)}#pool .section-body{color:#ffffff8c;max-width:440px}.pool-features{grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:2.5rem;display:grid}.pool-feature{color:#ffffffa6;align-items:flex-start;gap:.8rem;font-family:Outfit,sans-serif;font-size:.82rem;font-weight:300;line-height:1.5;display:flex}.pool-feature-dot{background:var(--sand);border-radius:50%;flex-shrink:0;width:5px;height:5px;margin-top:6px}.pool-image-stack{height:540px;position:relative}.pool-img-main{z-index:2;background:linear-gradient(135deg,#1a3a3a 0%,#2a5555 50%,#1e4040 100%);border-radius:6px;width:80%;height:440px;position:absolute;top:0;right:0;box-shadow:-15px 15px 50px #00000080}.pool-img-accent{z-index:1;width:60%;height:260px;color:var(--sand);text-align:left;background:linear-gradient(135deg,#4a261a 0%,#2a140d 100%);border:1px solid #d4bc8a26;border-radius:6px;justify-content:flex-start;align-items:flex-end;padding:2rem 40% 2.5rem 2.5rem;font-family:Playfair Display,serif;font-size:1.1rem;font-style:italic;line-height:1.6;display:flex;position:absolute;bottom:-20px;left:0}.pool-img-main .img-label{color:#ffffff4d;letter-spacing:.15em;text-transform:uppercase;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;height:100%;font-family:Outfit,sans-serif;font-size:.65rem;display:flex}#gallery{background:var(--sand-pale);padding-bottom:0}.gallery-header{justify-content:space-between;align-items:flex-end;margin-bottom:3rem;display:flex}.gallery-grid{column-count:3;column-gap:12px;display:block}.gallery-grid .img-wrap{break-inside:avoid;page-break-inside:avoid;height:auto;min-height:200px;margin-bottom:12px;display:block}.gallery-grid .img-wrap img,.gallery-grid .img-wrap picture{object-fit:fill;width:100%;display:block;inset:auto;height:auto!important;position:relative!important}.amenities-strip{background:var(--charcoal);flex-wrap:wrap;justify-content:center;align-items:center;gap:4rem;margin-top:4rem;padding:3rem 5rem;display:flex}.amenity-item{letter-spacing:.2em;text-transform:uppercase;color:#ffffff73;flex-direction:column;align-items:center;gap:.8rem;font-family:Outfit,sans-serif;font-size:.65rem;font-weight:400;display:flex}.amenity-icon{opacity:.5;width:36px;height:36px}#location{background:var(--cream);grid-template-columns:1fr 1fr;align-items:start;gap:6rem;display:grid}.location-map-placeholder{height:420px;color:var(--green);letter-spacing:.15em;text-transform:uppercase;background:linear-gradient(135deg,#f0dfd1 0%,#e2c4b1 50%,#ebcebb 100%);border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;font-family:Outfit,sans-serif;font-size:.75rem;font-weight:400;display:flex;position:relative;overflow:hidden}.location-map-placeholder:before{content:"";background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 0h60v60H0z' fill='none'/%3E%3Cpath d='M0 30h60M30 0v60' stroke='%23C4704A' stroke-width='0.3' opacity='0.3'/%3E%3C/svg%3E");position:absolute;inset:0}.map-pin{z-index:1;width:40px;height:40px;position:relative}.location-details{flex-direction:column;gap:2rem;padding-top:1rem;display:flex}.location-item h4{letter-spacing:.2em;text-transform:uppercase;color:var(--sand);margin-bottom:.6rem;font-family:Outfit,sans-serif;font-size:.65rem;font-weight:500}.location-item p{color:var(--warm-gray);font-family:Outfit,sans-serif;font-size:.88rem;font-weight:300;line-height:1.8}.distances{flex-direction:column;gap:.6rem;display:flex}.distance-row{color:var(--warm-gray);border-bottom:1px solid #d4bc8a33;justify-content:space-between;align-items:center;padding:.6rem 0;font-family:Outfit,sans-serif;font-size:.82rem;font-weight:300;display:flex}.distance-km{color:var(--charcoal);font-weight:400}#contact{text-align:center;background:linear-gradient(135deg,#4a261a 0%,#21110b 100%);padding:8rem 5rem;position:relative;overflow:hidden}#contact:before{content:"";background:radial-gradient(#d4bc8a12 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-50%;left:50%;transform:translate(-50%)}.contact-eyebrow{letter-spacing:.3em;text-transform:uppercase;color:var(--sand);margin-bottom:1.5rem;font-family:Outfit,sans-serif;font-size:.65rem;font-weight:400}.contact-title{color:var(--ivory);margin-bottom:1.2rem;font-family:Playfair Display,serif;font-size:clamp(2.5rem,5vw,4rem);font-weight:300;line-height:1.1}.contact-title em{color:var(--sand-light);font-style:italic}.contact-subtitle{color:#ffffff73;max-width:460px;margin:0 auto 3rem;font-family:Outfit,sans-serif;font-size:.88rem;font-weight:300;line-height:1.8}.contact-channels{flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem;margin-bottom:4rem;display:flex}.channel-btn{letter-spacing:.1em;text-transform:uppercase;border-radius:3px;align-items:center;gap:.8rem;padding:1rem 2rem;font-family:Outfit,sans-serif;font-size:.78rem;font-weight:400;text-decoration:none;transition:transform .2s,opacity .2s;display:flex}.channel-btn:hover{opacity:.9;transform:translateY(-2px)}.channel-btn.whatsapp{color:#fff;background:#25d366}.channel-btn.instagram{color:#fff;background:linear-gradient(135deg,#405de6,#5851db,#833ab4,#c13584,#e1306c,#fd1d1d)}.channel-btn.email{color:var(--sand-light);border:1px solid #d4bc8a66}.channel-btn.email:hover{background:#d4bc8a1a}.contact-divider{background:#ffffff1a;width:1px;height:40px}.contact-info{border-top:1px solid #ffffff14;flex-wrap:wrap;justify-content:center;gap:4rem;padding-top:3rem;display:flex}.contact-info-item{color:#fff6;text-align:center;font-family:Outfit,sans-serif;font-size:.78rem;font-weight:300;line-height:1.8}.contact-info-item strong{color:#ffffffb3;letter-spacing:.2em;text-transform:uppercase;margin-bottom:.4rem;font-size:.65rem;font-weight:400;display:block}#contact a[href^=tel],#contact a[href^=tel]:visited{color:#fff;text-decoration:none}footer{background:#170b08;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:2.5rem 5rem;display:flex}.footer-logo img{filter:brightness(0)invert(.5);height:32px}.footer-copy{color:#fff3;letter-spacing:.05em;font-family:Outfit,sans-serif;font-size:.7rem;font-weight:300}.footer-links{gap:1.5rem;list-style:none;display:flex}.footer-links a{letter-spacing:.12em;text-transform:uppercase;color:#ffffff40;font-family:Outfit,sans-serif;font-size:.68rem;font-weight:300;text-decoration:none;transition:color .3s}.footer-links a:hover{color:var(--sand)}.wa-float{z-index:200;background:#25d366;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;text-decoration:none;transition:transform .3s,box-shadow .3s;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 4px 20px #25d36659}.wa-float:hover{transform:scale(1.08);box-shadow:0 6px 28px #25d36680}.wa-float svg{fill:#fff;width:28px;height:28px}.reveal{opacity:0;transition:opacity .8s,transform .8s;transform:translateY(24px)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.35s}@media (width<=900px){nav{padding:1.2rem 1.5rem}nav.scrolled{padding:.8rem 1.5rem}.nav-links{display:none}section{padding:5rem 1.5rem}#about,#pool,#location{grid-template-columns:1fr;gap:3rem}.about-image-grid{grid-template-rows:180px 180px}#hero{grid-template-columns:1fr}.hero-left-accent{display:none}.hero-oversized-logo{opacity:.12;pointer-events:none;mix-blend-mode:soft-light;width:140vw;top:50%;left:50%;transform:translate(-50%,-50%)}.hero-oversized-logo img{transform:scale(1)}.hero-content{text-align:left;grid-column:1;justify-self:start;margin-top:-8vh;padding:0}.hero-eyebrow{justify-content:flex-start}.hero-eyebrow:after{display:none}.hero-ctas{justify-content:flex-start}.rooms-intro{grid-template-columns:1fr;gap:2rem}.rooms-gallery{grid-template-rows:220px 220px 220px;grid-template-columns:1fr 1fr}.rooms-gallery .img-wrap:first-child{grid-column:span 2}.pool-image-stack{height:380px;margin-top:2rem}.pool-img-main{width:92%;height:320px}.pool-img-accent{text-align:center;justify-content:center;align-items:flex-end;width:90%;height:auto;min-height:120px;padding:2.5rem 1.5rem 1rem;bottom:-20px}.gallery-header{flex-direction:column;align-items:flex-start;gap:1rem}.gallery-grid{column-count:2;column-gap:8px}.gallery-grid .img-wrap{min-height:0;margin-bottom:8px}.amenities-strip{text-align:center;grid-template-columns:1fr 1fr;justify-items:center;gap:2rem;padding:2.5rem 1.5rem;display:grid}footer{flex-direction:column;align-items:flex-start;padding:2rem 1.5rem}#contact{padding:5rem 1.5rem}.contact-info{text-align:center;flex-direction:column;align-items:center;gap:2rem;width:100%}.hero-scroll{display:none}}@media (width<=768px){.hero-oversized-logo{width:120vw!important;position:absolute!important;inset:auto auto -6rem 50%!important;transform:translate(-50%)!important}.hero-oversized-logo img{transform-origin:50%!important;filter:brightness(0)invert()!important;width:100%!important;transform:none!important}}
