*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
--bg:#FAFAF7;--text:#1B3A4B;--accent:#5B9E8F;--secondary:#EDE8E0;
--white:#ffffff;--text-light:#5A7A86;
--serif:'Cormorant Garamond',Georgia,serif;
--sans:'Inter','Helvetica Neue',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--bg);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.2}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.15s}
.reveal-delay-2{transition-delay:.3s}
.reveal-delay-3{transition-delay:.45s}
.reveal-delay-4{transition-delay:.6s}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:24px 0;transition:all .4s ease}
.nav.scrolled{background:rgba(237,232,224,.96);backdrop-filter:blur(12px);padding:14px 0;box-shadow:0 1px 20px rgba(0,0,0,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 24px}
.nav-logo img{height:44px;width:auto}
.nav.scrolled .nav-logo img{height:36px}
.nav-links{display:flex;gap:36px;align-items:center}
.nav-links a{color:rgba(255,255,255,.85);font-size:.72rem;letter-spacing:2px;text-transform:uppercase;font-weight:400;transition:color .3s}
.nav-links a:hover{color:var(--accent)}
.nav.scrolled .nav-links a{color:var(--text)}
.nav.scrolled .hamburger span{background:var(--text)}
.nav-cta{background:var(--accent)!important;color:var(--bg)!important;padding:10px 28px;border-radius:0;font-weight:500;letter-spacing:2px;font-size:.72rem!important;transition:all .3s!important}
.nav-cta:hover{background:var(--white)!important;color:var(--text)!important}
.hamburger{display:none;flex-direction:column;gap:6px;cursor:pointer;padding:8px}
.hamburger span{width:22px;height:1px;background:var(--white);transition:all .3s}
.mobile-menu{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(27,58,75,.97);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;opacity:0;pointer-events:none;transition:opacity .4s}
.mobile-menu.open{opacity:1;pointer-events:all}
.mobile-menu a{color:var(--white);font-size:1rem;letter-spacing:3px;text-transform:uppercase;font-family:var(--sans);font-weight:300}
.mobile-close{position:absolute;top:24px;right:24px;color:var(--white);font-size:2rem;cursor:pointer;background:none;border:none;font-weight:300}
@media(max-width:900px){.nav-links{display:none}.hamburger{display:flex}}

/* PAGE HERO */
.page-hero{position:relative;height:60vh;min-height:420px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(27,58,75,.25) 0%,rgba(27,58,75,.5) 100%)}
.page-hero-content{position:relative;z-index:2;color:var(--white)}
.page-hero-content h1{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;margin-bottom:16px;font-style:italic}
.page-hero-content p{font-size:1rem;font-weight:300;opacity:.8;max-width:500px;margin:0 auto;line-height:1.8}

/* SECTION HEADERS */
.section-header{text-align:center;margin-bottom:80px}
.section-header h2{font-size:clamp(1.8rem,3.5vw,2.8rem);color:var(--text);margin-bottom:16px;font-weight:300}
.section-header p{color:var(--text-light);font-weight:300;font-size:.95rem;max-width:520px;margin:0 auto;line-height:1.8}
.accent-line{width:48px;height:1px;background:var(--accent);margin:32px auto 0}

/* BUTTONS */
.btn{display:inline-block;padding:16px 44px;font-size:.72rem;letter-spacing:3px;text-transform:uppercase;font-family:var(--sans);font-weight:500;border:none;cursor:pointer;transition:all .3s}
.btn-primary{background:var(--accent);color:var(--bg)}
.btn-primary:hover{background:var(--text);color:var(--white)}
.btn-outline{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.4)}
.btn-outline:hover{background:var(--white);color:var(--text);border-color:var(--white)}

/* CONTENT SECTIONS */
.content-section{padding:120px 0}
.content-section:nth-child(even){background:var(--white)}
.content-section:nth-child(odd){background:var(--bg)}
.content-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.content-layout.reverse{direction:rtl}
.content-layout.reverse>*{direction:ltr}
.content-img{width:100%;height:480px;object-fit:cover}
.content-text h2{font-size:clamp(1.6rem,3vw,2.2rem);color:var(--text);margin-bottom:20px;font-weight:300}
.content-text h3{font-size:clamp(1.3rem,2vw,1.6rem);color:var(--text);margin-bottom:16px;font-weight:400}
.content-text p{color:var(--text-light);line-height:1.9;font-weight:300;font-size:.95rem;margin-bottom:20px}
.content-text ul{list-style:none;margin-bottom:28px}
.content-text ul li{font-size:.88rem;color:var(--text-light);font-weight:300;padding:6px 0 6px 20px;position:relative;line-height:1.6}
.content-text ul li::before{content:'';position:absolute;left:0;top:13px;width:8px;height:1px;background:var(--accent)}
@media(max-width:768px){.content-layout,.content-layout.reverse{grid-template-columns:1fr;direction:ltr}.content-img{height:320px}}

/* IMAGE BREAK */
.image-break{height:480px;background-attachment:fixed;background-size:cover;background-position:center;position:relative}
.image-break::after{content:'';position:absolute;inset:0;background:rgba(27,58,75,.35)}
.image-break-content{position:relative;z-index:1;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--white)}
.image-break-content blockquote{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2.2rem);font-style:italic;max-width:680px;padding:0 24px;line-height:1.5;font-weight:300}
@media(max-width:768px){.image-break{background-attachment:scroll}}

/* CARDS GRID */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card{background:var(--white);box-shadow:0 2px 20px rgba(27,58,75,.06);overflow:hidden;transition:all .4s}
.card:hover{box-shadow:0 8px 40px rgba(27,58,75,.1);transform:translateY(-2px)}
.card-img{height:240px;background-size:cover;background-position:center;transition:transform .6s}
.card:hover .card-img{transform:scale(1.03)}
.card-body{padding:32px 28px}
.card-body h3{font-size:1.2rem;color:var(--text);margin-bottom:8px;font-weight:400}
.card-body p{font-size:.88rem;color:var(--text-light);line-height:1.7;font-weight:300}
@media(max-width:768px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.card-grid{grid-template-columns:1fr}}

/* ROOM STYLES */
.room-section{padding:100px 0;border-bottom:1px solid var(--secondary)}
.room-section:last-of-type{border-bottom:none}
.room-section:nth-child(even){background:var(--white)}
.room-section:nth-child(odd){background:var(--bg)}
.room-hero-img{width:100%;height:480px;object-fit:cover;cursor:pointer;transition:transform .4s}
.room-hero-img:hover{transform:scale(1.01)}
.room-gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:12px}
.room-gallery img{width:100%;height:80px;object-fit:cover;cursor:pointer;opacity:.7;transition:all .3s;border:2px solid transparent}
.room-gallery img:hover,.room-gallery img.active{opacity:1;border-color:var(--accent)}
.room-content{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;margin-top:48px;align-items:start}
.room-content h2{font-size:clamp(1.6rem,3vw,2.2rem);color:var(--text);margin-bottom:16px;font-weight:300}
.room-content>div:first-child p{color:var(--text-light);line-height:1.9;font-weight:300;font-size:.95rem}
.room-amenities{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:6px 24px;margin-bottom:32px}
.room-amenities li{font-size:.85rem;color:var(--text);font-weight:300;padding:6px 0 6px 20px;position:relative;line-height:1.6}
.room-amenities li::before{content:'';position:absolute;left:0;top:13px;width:8px;height:1px;background:var(--accent)}
.room-cta{display:inline-block;padding:14px 40px;background:var(--accent);color:var(--bg);font-size:.72rem;letter-spacing:3px;text-transform:uppercase;font-weight:500;font-family:var(--sans);border:none;cursor:pointer;transition:all .3s}
.room-cta:hover{background:var(--text);color:var(--white)}
@media(max-width:900px){
.room-content{grid-template-columns:1fr}
.room-hero-img{height:320px}
.room-amenities{grid-template-columns:1fr}
.room-gallery{grid-template-columns:repeat(4,1fr)}
}

/* LIGHTBOX */
.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.lightbox-overlay.active{display:flex;opacity:1}
.lightbox-overlay img{max-width:90vw;max-height:85vh;object-fit:contain}
.lightbox-close{position:absolute;top:24px;right:32px;color:#fff;font-size:2rem;cursor:pointer;background:none;border:none;font-weight:300;z-index:10;opacity:.6;transition:opacity .3s}
.lightbox-close:hover{opacity:1}
.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:2.5rem;cursor:pointer;background:none;border:none;padding:20px;opacity:.4;transition:opacity .3s;z-index:10;font-weight:300}
.lightbox-prev:hover,.lightbox-next:hover{opacity:1}
.lightbox-prev{left:16px}
.lightbox-next{right:16px}
.lightbox-counter{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.5);font-size:.75rem;letter-spacing:2px;font-family:var(--sans)}

/* FEATURE LIST */
.feature-list{display:flex;flex-direction:column;gap:24px;margin-top:32px}
.feature-item{display:flex;gap:16px;align-items:flex-start}
.feature-icon{width:36px;height:36px;min-width:36px;display:flex;align-items:center;justify-content:center}
.feature-icon svg{width:24px;height:24px;stroke:var(--accent);fill:none;stroke-width:1.5}
.feature-item h4{font-size:.95rem;color:var(--text);margin-bottom:4px;font-weight:400}
.feature-item p{font-size:.85rem;margin:0;color:var(--text-light);font-weight:300;line-height:1.7}

/* FOOTER */
.footer{background:#1B3A4B;color:var(--white);padding:80px 0 40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:60px}
.footer h4{font-family:var(--sans);font-size:.68rem;letter-spacing:3px;text-transform:uppercase;margin-bottom:20px;color:var(--accent)}
.footer p,.footer a{font-size:.85rem;color:rgba(255,255,255,.55);line-height:1.9;font-weight:300}
.footer a:hover{color:var(--accent)}
.footer-brand p{margin-bottom:16px}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-social{display:flex;gap:12px;margin-top:16px}
.footer-social a{width:36px;height:36px;border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s}
.footer-social a:hover{background:var(--accent);border-color:var(--accent)}
.footer-social a svg{width:14px;height:14px;stroke:rgba(255,255,255,.6);fill:none;stroke-width:1.5}
.footer-social a:hover svg{stroke:var(--bg)}
.newsletter-input{display:flex;margin-top:12px}
.newsletter-input input{flex:1;padding:12px 16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:var(--white);font-family:var(--sans);font-size:.85rem;outline:none}
.newsletter-input input::placeholder{color:rgba(255,255,255,.25)}
.newsletter-input button{padding:12px 20px;background:var(--accent);color:var(--bg);border:none;font-weight:500;font-size:.68rem;letter-spacing:2px;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:background .3s}
.newsletter-input button:hover{background:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-bottom p{font-size:.72rem;color:rgba(255,255,255,.3)}
@media(max-width:768px){.footer-grid{grid-template-columns:repeat(2,1fr);gap:36px}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
