/* ============================================================
   YANARRA LUXURY BEACH HOUSE — styles.css
   Palette: Deep ocean navy + turquoise + champagne gold
   Fonts: Oranienbaum (display) + Barlow (body)
   ============================================================ */

/* 1. GOOGLE FONTS & RESET */
@import url('https://fonts.googleapis.com/css2?family=Oranienbaum&family=Barlow:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-body);color:var(--cream);background:var(--dark);line-height:1.7;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* 2. CSS VARIABLES */
:root{
  --dark:#0A1828;
  --bg-alt:#0F2238;
  --accent:#1AABB8;
  --highlight:#C8A040;
  --cream:#F5F0E8;
  --black:#060F1A;
  --white:#FFFFFF;
  --ff-display:'Oranienbaum',serif;
  --ff-body:'Barlow',sans-serif;
  --page-hero-bg:url('images/hero.jpg');
  --radius:4px;
  --radius-lg:10px;
  --transition:0.35s ease;
  --max-w:1240px;
  --shadow:0 8px 40px rgba(0,0,0,0.45);
  --shadow-sm:0 3px 15px rgba(0,0,0,0.25);
}

/* 3. TYPOGRAPHY */
h1,h2,h3,h4,h5,h6{font-family:var(--ff-display);line-height:1.2;font-weight:400}
h1{font-size:clamp(2.6rem,5.5vw,5rem);letter-spacing:0.01em}
h2{font-size:clamp(2rem,4vw,3.4rem);letter-spacing:0.01em}
h3{font-size:clamp(1.4rem,2.5vw,2rem)}
h4{font-size:clamp(1.1rem,1.8vw,1.4rem)}
h5{font-size:1rem;font-family:var(--ff-body);font-weight:600;letter-spacing:0.12em;text-transform:uppercase}
p{font-size:clamp(0.95rem,1.5vw,1.05rem);font-weight:300;line-height:1.8;color:rgba(245,240,232,0.82)}
.lead{font-size:clamp(1.05rem,1.8vw,1.2rem);font-weight:300;line-height:1.9}
.eyebrow{font-family:var(--ff-body);font-size:0.75rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent)}

/* 4. LAYOUT UTILITIES */
.container{max-width:var(--max-w);margin:0 auto;padding:0 clamp(1rem,4vw,2.5rem)}
.section{padding:clamp(4rem,8vw,7rem) 0}
.section--dark{background:var(--dark)}
.section--alt{background:var(--bg-alt)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.text-center{text-align:center}
.text-accent{color:var(--accent)}
.text-highlight{color:var(--highlight)}
.mt-1{margin-top:0.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mt-5{margin-top:3rem}
.mb-1{margin-bottom:0.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mb-5{margin-bottom:3rem}

/* 5. BUTTONS */
.btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.85rem 2rem;font-family:var(--ff-body);font-size:0.8rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;border-radius:var(--radius);transition:var(--transition);border:2px solid transparent}
.btn-primary{background:var(--accent);color:var(--dark);border-color:var(--accent)}
.btn-primary:hover{background:transparent;color:var(--accent);border-color:var(--accent)}
.btn-gold{background:var(--highlight);color:var(--dark);border-color:var(--highlight)}
.btn-gold:hover{background:transparent;color:var(--highlight);border-color:var(--highlight)}
.btn-outline{background:transparent;color:var(--cream);border-color:rgba(245,240,232,0.5)}
.btn-outline:hover{background:var(--cream);color:var(--dark);border-color:var(--cream)}
.btn-outline-accent{background:transparent;color:var(--accent);border-color:var(--accent)}
.btn-outline-accent:hover{background:var(--accent);color:var(--dark)}

/* 6. NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 0;transition:background var(--transition),padding var(--transition)}
.navbar.scrolled{background:rgba(6,15,26,0.97);backdrop-filter:blur(10px);padding:0.75rem 0;box-shadow:0 2px 20px rgba(0,0,0,0.5)}
.navbar__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.navbar__logo{display:flex;align-items:center;gap:0.75rem;flex-shrink:0}
.navbar__logo img{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid rgba(26,171,184,0.4)}
.navbar__logo-text{font-family:var(--ff-display);font-size:1.1rem;letter-spacing:0.05em;line-height:1.2}
.navbar__logo-text span{display:block;font-family:var(--ff-body);font-size:0.65rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent)}
.navbar__nav{display:flex;align-items:center;gap:2rem}
.navbar__nav a{font-size:0.78rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:rgba(245,240,232,0.85);transition:color var(--transition);position:relative}
.navbar__nav a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--accent);transition:width var(--transition)}
.navbar__nav a:hover,.navbar__nav a.active{color:var(--accent)}
.navbar__nav a:hover::after,.navbar__nav a.active::after{width:100%}
.navbar__cta{flex-shrink:0}
.navbar__burger{display:none;flex-direction:column;gap:5px;padding:0.3rem;cursor:pointer}
.navbar__burger span{display:block;width:24px;height:2px;background:var(--cream);transition:var(--transition)}

/* 7. HERO */
.hero{position:relative;height:100vh;min-height:620px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-image:var(--page-hero-bg);background-size:cover;background-position:center;transition:transform 0.1s linear}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(10,24,40,0.72) 0%,rgba(10,24,40,0.42) 50%,rgba(10,24,40,0.68) 100%)}
.hero__content{position:relative;text-align:center;padding:0 1rem}
.hero__eyebrow{margin-bottom:1.2rem}
.hero__title{color:var(--white);text-shadow:0 2px 20px rgba(0,0,0,0.4);margin-bottom:1.4rem}
.hero__subtitle{font-size:clamp(1rem,2vw,1.2rem);font-weight:300;color:rgba(255,255,255,0.85);max-width:560px;margin:0 auto 2.2rem;line-height:1.8}
.hero__actions{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0.5rem;cursor:pointer;animation:bounce 2.4s infinite}
.hero__scroll span{font-size:0.68rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.65)}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* 8. PAGE HERO */
.page-hero{position:relative;height:52vh;min-height:380px;display:flex;align-items:center;overflow:hidden}
.page-hero__bg{position:absolute;inset:0;background-image:var(--page-hero-bg);background-size:cover;background-position:center}
.page-hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,24,40,0.62) 0%,rgba(10,24,40,0.78) 100%)}
.page-hero__content{position:relative;padding:7rem 0 3rem}

/* 9. FEATURES STRIP */
.features-strip{background:var(--accent);padding:1.2rem 0}
.features-strip__inner{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap}
.feature-item{display:flex;align-items:center;gap:0.6rem;font-size:0.78rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--dark)}
.feature-item svg{flex-shrink:0;width:18px;height:18px}
.feature-sep{width:4px;height:4px;border-radius:50%;background:rgba(10,24,40,0.35)}

/* 10. OFFERINGS GRID */
.offering-card{background:var(--bg-alt);border:1px solid rgba(26,171,184,0.12);border-radius:var(--radius-lg);padding:2rem;text-align:center;transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition)}
.offering-card:hover{transform:translateY(-6px);border-color:var(--accent);box-shadow:0 16px 40px rgba(26,171,184,0.15)}
.offering-card__icon{width:56px;height:56px;margin:0 auto 1.2rem;display:flex;align-items:center;justify-content:center;background:rgba(26,171,184,0.1);border-radius:50%;color:var(--accent)}
.offering-card__icon svg{width:28px;height:28px}
.offering-card h4{font-family:var(--ff-display);font-size:1.15rem;margin-bottom:0.6rem;color:var(--cream)}
.offering-card p{font-size:0.88rem;margin:0}

/* 11. SPLIT SECTION */
.split{display:grid;grid-template-columns:1fr 1fr;min-height:520px}
.split__image{position:relative;overflow:hidden;min-height:420px}
.split__image img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease}
.split__image:hover img{transform:scale(1.04)}
.split__content{display:flex;flex-direction:column;justify-content:center;padding:clamp(2.5rem,6vw,5rem)}
.split--reverse .split__content{order:-1}

/* 12. STATS ROW */
.stats-row{background:var(--bg-alt);border-top:1px solid rgba(26,171,184,0.15);border-bottom:1px solid rgba(26,171,184,0.15)}
.stats-row__inner{display:grid;grid-template-columns:repeat(4,1fr);text-align:center}
.stat-item{padding:2.5rem 1rem;border-right:1px solid rgba(26,171,184,0.12)}
.stat-item:last-child{border-right:none}
.stat-item__number{font-family:var(--ff-display);font-size:clamp(2.2rem,4vw,3.4rem);color:var(--accent);line-height:1;margin-bottom:0.4rem}
.stat-item__label{font-size:0.72rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(245,240,232,0.55)}

/* 13. REVIEW CARDS */
.review-card{background:var(--bg-alt);border:1px solid rgba(26,171,184,0.12);border-radius:var(--radius-lg);padding:2rem;display:flex;flex-direction:column;gap:1rem;transition:border-color var(--transition)}
.review-card:hover{border-color:rgba(26,171,184,0.35)}
.review-card__stars{display:flex;gap:3px;color:var(--highlight)}
.review-card__stars svg{width:16px;height:16px}
.review-card__text{font-size:0.95rem;font-style:italic;line-height:1.8;color:rgba(245,240,232,0.82);flex:1}
.review-card__author{display:flex;align-items:center;gap:0.75rem;margin-top:auto}
.review-card__avatar{width:42px;height:42px;border-radius:50%;background:rgba(26,171,184,0.15);display:flex;align-items:center;justify-content:center;color:var(--accent);font-family:var(--ff-display);font-size:1.1rem;flex-shrink:0}
.review-card__name{font-size:0.88rem;font-weight:600;color:var(--cream)}
.review-card__source{font-size:0.75rem;color:rgba(245,240,232,0.45);margin-top:1px}
.reviews-platform{display:flex;align-items:center;gap:0.4rem;font-size:0.72rem;font-weight:600;letter-spacing:0.1em;color:rgba(245,240,232,0.45);text-transform:uppercase}
.reviews-platform svg{width:14px;height:14px;color:var(--highlight)}

/* 14. SOCIAL CTA */
.social-cta{background:linear-gradient(135deg,var(--accent) 0%,#0E8C98 100%);text-align:center;padding:5rem 0}
.social-cta h2,.social-cta p,.social-cta .eyebrow{color:var(--dark)}
.social-cta .eyebrow{color:rgba(10,24,40,0.6)}
.social-cta p{color:rgba(10,24,40,0.72)}
.social-cta .btn-outline{color:var(--dark);border-color:var(--dark)}
.social-cta .btn-outline:hover{background:var(--dark);color:var(--accent);border-color:var(--dark)}

/* 15. FEED GRID */
.feed-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.feed-item{position:relative;overflow:hidden;aspect-ratio:1/1;background:var(--bg-alt)}
.feed-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease,filter 0.5s ease}
.feed-item__overlay{position:absolute;inset:0;background:rgba(10,24,40,0.7);opacity:0;transition:opacity var(--transition);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:0.3rem}
.feed-item:hover .feed-item__overlay{opacity:1}
.feed-item:hover img{transform:scale(1.08);filter:brightness(0.7)}
.feed-item__overlay svg{width:28px;height:28px;color:var(--white)}
.feed-item__overlay span{font-size:0.72rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--white)}

/* 16. FOOTER */
.footer{background:var(--black);border-top:1px solid rgba(26,171,184,0.15);padding:4rem 0 2rem}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.footer__brand-logo{display:flex;align-items:center;gap:0.75rem;margin-bottom:1.2rem}
.footer__brand-logo img{width:52px;height:52px;border-radius:50%;object-fit:cover;border:2px solid rgba(26,171,184,0.3)}
.footer__brand-name{font-family:var(--ff-display);font-size:1.05rem;color:var(--cream)}
.footer__tagline{font-size:0.88rem;color:rgba(245,240,232,0.55);line-height:1.7;max-width:280px;margin-bottom:1.5rem}
.footer__social{display:flex;gap:0.75rem}
.footer__social a{width:38px;height:38px;border-radius:50%;background:rgba(26,171,184,0.1);border:1px solid rgba(26,171,184,0.2);display:flex;align-items:center;justify-content:center;color:var(--accent);transition:var(--transition)}
.footer__social a:hover{background:var(--accent);color:var(--dark);border-color:var(--accent)}
.footer__social svg{width:16px;height:16px}
.footer__heading{font-family:var(--ff-body);font-size:0.72rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);margin-bottom:1.2rem}
.footer__links{display:flex;flex-direction:column;gap:0.6rem}
.footer__links a{font-size:0.88rem;color:rgba(245,240,232,0.6);transition:color var(--transition)}
.footer__links a:hover{color:var(--accent)}
.footer__contact-item{display:flex;align-items:flex-start;gap:0.7rem;margin-bottom:0.8rem;font-size:0.87rem;color:rgba(245,240,232,0.65)}
.footer__contact-item svg{width:15px;height:15px;color:var(--accent);flex-shrink:0;margin-top:3px}
.footer__contact-item a:hover{color:var(--accent)}
.footer__bottom{border-top:1px solid rgba(245,240,232,0.08);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer__bottom p{font-size:0.8rem;color:rgba(245,240,232,0.35)}
.footer__bottom-links{display:flex;gap:1.5rem}
.footer__bottom-links a{font-size:0.78rem;color:rgba(245,240,232,0.35);transition:color var(--transition)}
.footer__bottom-links a:hover{color:var(--accent)}

/* 17. ABOUT PAGE */
.story-block{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.story-block__image{position:relative;border-radius:var(--radius-lg);overflow:hidden}
.story-block__image::before{content:'';position:absolute;inset:-8px;border:2px solid rgba(26,171,184,0.25);border-radius:var(--radius-lg);z-index:1;pointer-events:none}
.philosophy-card{background:var(--bg-alt);border:1px solid rgba(26,171,184,0.12);border-radius:var(--radius-lg);padding:2.2rem;text-align:center;transition:border-color var(--transition),transform var(--transition)}
.philosophy-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.philosophy-card__icon{width:60px;height:60px;margin:0 auto 1.2rem;background:rgba(26,171,184,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent)}
.philosophy-card__icon svg{width:30px;height:30px}
.values-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem}
.value-item{text-align:center;padding:2rem 1rem;border-top:2px solid rgba(26,171,184,0.2);transition:border-color var(--transition)}
.value-item:hover{border-color:var(--accent)}
.value-item__number{font-family:var(--ff-display);font-size:2.5rem;color:rgba(26,171,184,0.2);margin-bottom:0.5rem;line-height:1}
.value-item h4{font-size:1rem;color:var(--cream);margin-bottom:0.6rem}
.value-item p{font-size:0.83rem;margin:0}
.timeline{position:relative;padding-left:2rem}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--accent),transparent)}
.timeline-item{position:relative;padding-left:2rem;padding-bottom:2.5rem}
.timeline-item::before{content:'';position:absolute;left:-2.44rem;top:0.3rem;width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(26,171,184,0.15)}
.timeline-item__year{font-size:0.72rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);margin-bottom:0.4rem}
.timeline-item h4{color:var(--cream);margin-bottom:0.4rem}
.timeline-item p{font-size:0.88rem;margin:0}

/* 18. ROOMS PAGE */
.disclaimer-box{background:rgba(200,160,64,0.08);border:1px solid rgba(200,160,64,0.25);border-radius:var(--radius-lg);padding:1.5rem 2rem;margin-bottom:3rem;display:flex;align-items:flex-start;gap:1rem}
.disclaimer-box svg{width:20px;height:20px;color:var(--highlight);flex-shrink:0;margin-top:2px}
.disclaimer-box p{font-size:0.9rem;color:rgba(245,240,232,0.7);margin:0}
.category-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:4rem}
.cat-tile{background:var(--bg-alt);border:1px solid rgba(26,171,184,0.12);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;cursor:pointer;transition:var(--transition)}
.cat-tile:hover,.cat-tile.active{background:rgba(26,171,184,0.12);border-color:var(--accent)}
.cat-tile__icon{width:50px;height:50px;margin:0 auto 1rem;background:rgba(26,171,184,0.08);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent)}
.cat-tile__icon svg{width:24px;height:24px}
.cat-tile h5{font-size:0.78rem;color:var(--cream);margin-bottom:0.3rem}
.cat-tile p{font-size:0.78rem;color:rgba(245,240,232,0.5);margin:0}
.room-section{margin-bottom:5rem;scroll-margin-top:100px}
.room-section:last-child{margin-bottom:0}
.room-section__header{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem;margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(26,171,184,0.15)}
.room-section__images{display:grid;grid-template-columns:2fr 1fr;gap:1rem;margin-bottom:2rem}
.room-img-main{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3}
.room-img-main img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.room-img-main:hover img{transform:scale(1.03)}
.room-img-stack{display:grid;grid-template-rows:1fr 1fr;gap:1rem}
.room-img-thumb{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3}
.room-img-thumb img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.room-img-thumb:hover img{transform:scale(1.04)}
.room-amenities{display:flex;flex-wrap:wrap;gap:0.6rem;margin-top:1.5rem}
.room-amenity{display:flex;align-items:center;gap:0.4rem;background:rgba(26,171,184,0.08);border:1px solid rgba(26,171,184,0.18);border-radius:2rem;padding:0.35rem 0.9rem;font-size:0.78rem;color:var(--accent)}
.room-amenity svg{width:13px;height:13px;flex-shrink:0}

/* 19. GALLERY PAGE */
.filter-bar{display:flex;align-items:center;gap:0.8rem;flex-wrap:wrap;margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(26,171,184,0.15)}
.filter-btn{padding:0.55rem 1.3rem;border-radius:2rem;font-size:0.78rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;border:1px solid rgba(26,171,184,0.25);color:rgba(245,240,232,0.65);background:transparent;cursor:pointer;transition:var(--transition)}
.filter-btn:hover,.filter-btn.active{background:var(--accent);color:var(--dark);border-color:var(--accent)}
.masonry{columns:3;column-gap:1rem}
.masonry-item{break-inside:avoid;margin-bottom:1rem;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;position:relative}
.masonry-item img{width:100%;height:auto;display:block;transition:transform 0.5s ease,filter 0.5s ease}
.masonry-item::after{content:'';position:absolute;inset:0;background:rgba(10,24,40,0;transition:background var(--transition)}
.masonry-item:hover img{transform:scale(1.04);filter:brightness(0.8)}
.masonry-item::after{content:'';position:absolute;inset:0;background:transparent;transition:background var(--transition)}
.masonry-item:hover::after{background:rgba(10,24,40,0.25)}
/* Lightbox */
.lightbox{display:none;position:fixed;inset:0;z-index:2000;background:rgba(6,15,26,0.97);align-items:center;justify-content:center}
.lightbox.active{display:flex}
.lightbox__img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:var(--radius)}
.lightbox__close{position:absolute;top:1.5rem;right:1.5rem;width:44px;height:44px;border-radius:50%;background:rgba(245,240,232,0.1);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--cream);transition:var(--transition)}
.lightbox__close:hover{background:var(--accent);color:var(--dark)}
.lightbox__close svg{width:20px;height:20px}
.lightbox__prev,.lightbox__next{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(245,240,232,0.1);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--cream);transition:var(--transition)}
.lightbox__prev:hover,.lightbox__next:hover{background:var(--accent);color:var(--dark)}
.lightbox__prev{left:1.5rem}.lightbox__next{right:1.5rem}
.lightbox__prev svg,.lightbox__next svg{width:20px;height:20px}
.lightbox__counter{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);font-size:0.8rem;color:rgba(245,240,232,0.5);letter-spacing:0.1em}

/* 20. CONTACT PAGE */
.contact-blocks{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3rem}
.contact-block{background:var(--bg-alt);border:1px solid rgba(26,171,184,0.12);border-radius:var(--radius-lg);padding:2rem;text-align:center;transition:border-color var(--transition)}
.contact-block:hover{border-color:var(--accent)}
.contact-block__icon{width:56px;height:56px;margin:0 auto 1.2rem;background:rgba(26,171,184,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent)}
.contact-block__icon svg{width:26px;height:26px}
.contact-block h4{font-size:1rem;margin-bottom:0.5rem;color:var(--cream)}
.contact-block a,.contact-block p{font-size:0.9rem;color:rgba(245,240,232,0.65)}
.contact-block a:hover{color:var(--accent)}
.inquiry-form{background:var(--bg-alt);border:1px solid rgba(26,171,184,0.12);border-radius:var(--radius-lg);padding:clamp(2rem,5vw,3.5rem)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.form-group{display:flex;flex-direction:column;gap:0.4rem}
.form-group--full{grid-column:1/-1}
.form-group label{font-size:0.75rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:rgba(245,240,232,0.55)}
.form-group input,.form-group select,.form-group textarea{background:rgba(10,24,40,0.6);border:1px solid rgba(26,171,184,0.2);border-radius:var(--radius);padding:0.85rem 1rem;color:var(--cream);font-family:var(--ff-body);font-size:0.95rem;transition:border-color var(--transition);outline:none;width:100%}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}
.form-group textarea{resize:vertical;min-height:140px;line-height:1.6}
.form-group select option{background:var(--dark)}
.map-placeholder{border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-alt);border:1px solid rgba(26,171,184,0.15);height:360px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;text-align:center;padding:2rem;position:relative}
.map-placeholder::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,171,184,0.05) 0%,rgba(200,160,64,0.05) 100%)}
.map-placeholder svg{width:56px;height:56px;color:var(--accent);position:relative}
.map-placeholder p{position:relative;font-size:0.88rem;color:rgba(245,240,232,0.55)}
.faq-list{display:flex;flex-direction:column;gap:0}
.faq-item{border-bottom:1px solid rgba(26,171,184,0.12)}
.faq-item:first-child{border-top:1px solid rgba(26,171,184,0.12)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 0;cursor:pointer;gap:1rem}
.faq-question h5{font-family:var(--ff-display);font-size:1.05rem;font-weight:400;letter-spacing:0;text-transform:none;color:var(--cream);transition:color var(--transition)}
.faq-question:hover h5,.faq-item.open .faq-question h5{color:var(--accent)}
.faq-icon{width:30px;height:30px;border-radius:50%;background:rgba(26,171,184,0.1);border:1px solid rgba(26,171,184,0.25);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--transition),transform var(--transition)}
.faq-icon svg{width:14px;height:14px;color:var(--accent);transition:transform var(--transition)}
.faq-item.open .faq-icon{background:var(--accent)}
.faq-item.open .faq-icon svg{color:var(--dark);transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease,padding 0.4s ease}
.faq-answer p{font-size:0.95rem;padding-bottom:1.4rem;color:rgba(245,240,232,0.72)}
.faq-item.open .faq-answer{max-height:300px}

/* 21. SECTION DIVIDERS & DECORATORS */
.section-header{text-align:center;margin-bottom:3.5rem}
.section-header .eyebrow{margin-bottom:0.8rem}
.section-header h2{margin-bottom:1rem}
.section-header p{max-width:580px;margin:0 auto}
.divider{width:60px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);margin:1.2rem auto}
.divider--left{margin-left:0}
.accent-line{display:inline-block;width:40px;height:2px;background:var(--accent);vertical-align:middle;margin:0 0.8rem}
.highlight-text{color:var(--highlight)}
.gradient-text{background:linear-gradient(135deg,var(--accent),var(--highlight));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.book-cta-bar{background:linear-gradient(135deg,rgba(26,171,184,0.12) 0%,rgba(200,160,64,0.08) 100%);border:1px solid rgba(26,171,184,0.2);border-radius:var(--radius-lg);padding:3rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}

/* 22. RESPONSIVE */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:repeat(3,1fr)}
  .stats-row__inner{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(2){border-right:none}
  .stat-item:nth-child(3),.stat-item:nth-child(4){border-top:1px solid rgba(26,171,184,0.12)}
  .footer__grid{grid-template-columns:1fr 1fr;gap:2rem}
  .category-tiles{grid-template-columns:repeat(2,1fr)}
  .contact-blocks{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .navbar__nav,.navbar__cta{display:none}
  .navbar__burger{display:flex}
  .navbar__nav.open{display:flex;flex-direction:column;gap:0;position:fixed;inset:0;background:var(--black);padding:5rem 2rem 2rem;z-index:999}
  .navbar__nav.open a{font-size:1.1rem;padding:0.8rem 0;border-bottom:1px solid rgba(26,171,184,0.1)}
  .grid-2,.story-block,.split{grid-template-columns:1fr}
  .grid-3,.card-grid{grid-template-columns:1fr}
  .feed-grid{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:2}
  .values-grid{grid-template-columns:1fr 1fr}
  .stats-row__inner{grid-template-columns:1fr 1fr}
  .room-section__images{grid-template-columns:1fr}
  .room-img-stack{grid-template-rows:auto}
  .form-grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .split--reverse .split__content{order:0}
  .contact-blocks{grid-template-columns:1fr}
  .book-cta-bar{text-align:center;justify-content:center}
  .category-tiles{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .feed-grid{grid-template-columns:1fr}
  .masonry{columns:1}
  .hero__actions{flex-direction:column;align-items:center}
  .category-tiles{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
}
