:root {
  --primary: #1E6091;
  --primary-dark: #0F3D5C;
  --primary-light: #14A3C8;
  --accent: #E8A87C;
  --accent-dark: #D4956A;
  --accent-light: #F0C4A8;
  --bg: #F0F4F8;
  --bg-card: #FFFFFF;
  --text: #1A1A2E;
  --text-light: #6B7280;
  --text-white: #FFFFFF;
  --border: #D1E4EC;
  --shadow-sm: 0 2px 8px rgba(30,96,145,0.08);
  --shadow: 0 8px 24px rgba(30,96,145,0.12);
  --shadow-lg: 0 16px 48px rgba(30,96,145,0.18);
  --radius: 12px;
  --radius-lg: 20px;
  --radius-full: 999px;
  --transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  --max-width: 1200px;
  --nav-height: 72px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--nav-height)}
body{
  font-family:'Inter','Noto Sans Georgian','Noto Sans Hebrew','Noto Sans Armenian',-apple-system,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section-header{text-align:center;margin-bottom:3rem}
.section-header h2{
  font-family:'Playfair Display','Noto Sans Georgian',serif;
  font-size:2.75rem;font-weight:700;color:var(--text);
  margin-bottom:0.75rem;letter-spacing:-0.02em;
  position:relative;display:inline-block
}
.section-header h2::after{
  content:'';display:block;width:60px;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  margin:0.75rem auto 0;border-radius:2px
}
.section-header p{color:var(--text-light);font-size:1.1rem;max-width:600px;margin:0 auto}

.icon{display:inline-block;vertical-align:middle;width:1.25em;height:1.25em}

/* Wave divider */
.wave-divider{line-height:0;margin:-1px 0;width:100%;overflow:hidden}
.wave-divider svg{display:block;width:100%;height:auto}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;
  padding:0.875rem 2rem;border-radius:var(--radius-full);
  font-weight:600;font-size:1rem;border:none;cursor:pointer;
  transition:var(--transition);text-decoration:none;white-space:nowrap
}
.btn-primary{background:var(--primary);color:var(--text-white)}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(30,96,145,0.35)}
.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-outline:hover{background:var(--primary);color:var(--text-white);transform:translateY(-2px)}
.btn-cta{background:var(--accent);color:var(--text-white);padding:1.25rem 2.5rem;font-size:1.1rem;box-shadow:0 4px 20px rgba(232,168,124,0.45)}
.btn-cta:hover{background:var(--accent-dark);transform:translateY(-2px)}
.btn-block{width:100%;justify-content:center}

/* Nav */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(240,244,248,0.92);backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);height:var(--nav-height);
  transition:var(--transition);border-bottom:1px solid transparent
}
.nav-scrolled{border-bottom-color:var(--border);box-shadow:var(--shadow-sm)}
.nav-inner{
  max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;
  height:100%;display:flex;align-items:center;justify-content:space-between
}
.logo{font-family:'Noto Sans Georgian','Playfair Display',serif;font-size:1.5rem;font-weight:700;color:var(--primary);display:flex;align-items:center;gap:0.5rem}
.logo svg{width:28px;height:28px;fill:var(--primary)}
.nav-right{display:flex;align-items:center;gap:0.75rem}
.nav-links{display:flex;gap:0.25rem;align-items:center}
.nav-links a{padding:0.5rem 1rem;border-radius:8px;color:var(--text);font-weight:500;font-size:0.95rem;transition:var(--transition);letter-spacing:0.02em}
.nav-links a:hover{background:var(--bg);color:var(--primary)}
.lang-selector{display:flex;gap:2px;padding:0 0.5rem;border-left:1px solid var(--border);margin-left:0.5rem}
.lang-btn{
  width:32px;height:32px;border:none;background:transparent;
  border-radius:6px;font-size:0.7rem;font-weight:700;
  cursor:pointer;transition:var(--transition);
  color:var(--text-light);display:flex;align-items:center;justify-content:center;padding:0
}
.lang-btn:hover{background:var(--bg);color:var(--text)}
.lang-btn.active{background:var(--primary);color:var(--text-white)}
.nav-cta{
  background:linear-gradient(135deg,var(--primary),var(--primary-light))!important;
  color:var(--text-white)!important;
  padding:0.5rem 1.25rem!important;border-radius:var(--radius-full)!important
}
.nav-cta:hover{opacity:0.9!important}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{width:24px;height:2.5px;background:var(--text);border-radius:2px;transition:var(--transition)}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Hero: Full-screen with ocean gradient overlay */
.hero{
  min-height:100vh;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  padding-top:var(--nav-height)
}
.hero-bg{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1571896349842-33c89424de2d?w=1200&q=80') center center/cover no-repeat
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    160deg,
    rgba(15,61,92,0.85) 0%,
    rgba(30,96,145,0.7) 40%,
    rgba(20,163,200,0.5) 80%,
    rgba(232,168,124,0.3) 100%
  )
}
.hero-waves{
  position:absolute;bottom:-2px;left:0;right:0;z-index:2;
  line-height:0
}
.hero-waves svg{width:100%;height:auto;display:block}
.hero-content{
  position:relative;z-index:3;text-align:center;
  color:var(--text-white);max-width:700px;padding:0 2rem
}
.hero-badge{
  display:inline-block;
  background:rgba(255,255,255,0.15);backdrop-filter:blur(8px);
  color:var(--text-white);border:1px solid rgba(255,255,255,0.25);
  padding:0.5rem 1.5rem;border-radius:var(--radius-full);
  font-weight:600;font-size:0.9rem;margin-bottom:1.75rem;
  letter-spacing:0.05em;text-transform:uppercase
}
.hero h1{
  font-family:'Playfair Display','Noto Sans Georgian',serif;
  font-size:4.5rem;font-weight:700;
  margin-bottom:1rem;line-height:1.08;
  text-shadow:0 4px 20px rgba(0,0,0,0.3)
}
.hero-sub{font-size:1.2rem;color:rgba(255,255,255,0.9);margin-bottom:2.5rem;line-height:1.7;max-width:560px;margin-left:auto;margin-right:auto}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* Stats */
.stats{background:var(--bg-card);padding:2.5rem 0;position:relative}
.stats::before,.stats::after{
  content:'';position:absolute;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--primary),var(--primary-light),var(--accent))
}
.stats::before{top:0}
.stats::after{bottom:0}
.stats-track{
  max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center
}
.stat-cell{display:flex;flex-direction:column;align-items:center;gap:0.5rem}
.stat-icon{
  width:56px;height:56px;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 12px rgba(30,96,145,0.25)
}
.stat-icon svg{width:24px;height:24px;stroke:white;fill:none;stroke-width:2}
.stat-cell h3{font-size:2.5rem;font-weight:700;color:var(--primary);line-height:1.2;font-family:'Playfair Display',serif}
.stat-unit{font-size:1.2rem}
.stat-cell p{color:var(--text-light);font-weight:500;font-size:0.925rem}

/* About */
.about-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-frame{
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);
  height:450px;position:relative;
  background:url('https://images.unsplash.com/photo-1566073771259-6a8506099945?w=800&q=80') center center/cover no-repeat
}
.about-frame::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(30,96,145,0.15),transparent);
  border-radius:inherit
}
.about-text h2{font-family:'Playfair Display','Noto Sans Georgian',serif;font-size:2.25rem;font-weight:700;margin-bottom:1.5rem}
.about-text p{color:var(--text-light);font-size:1.05rem;line-height:1.8}

/* Features Bento */
.features{background:var(--bg-card)}
.features-bento{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem
}
.bento-card{
  background:var(--bg);padding:2rem;border-radius:var(--radius);
  transition:var(--transition);border:1px solid var(--border);
  position:relative;overflow:hidden
}
.bento-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--primary-light));
  opacity:0;transition:var(--transition)
}
.bento-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.bento-card:hover::before{opacity:1}
.bento-icon{font-size:2rem;margin-bottom:1rem}
.bento-card h3{font-size:1.15rem;margin-bottom:0.5rem;color:var(--primary-dark)}
.bento-card p{color:var(--text-light);font-size:0.925rem;line-height:1.6}

/* Services Chips */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.service-chip{
  display:flex;align-items:center;gap:1rem;
  background:var(--bg-card);padding:1.25rem;border-radius:var(--radius);
  border:1px solid var(--border);transition:var(--transition);cursor:default
}
.service-chip:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--primary)}
.chip-icon{
  width:52px;height:52px;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  border-radius:14px;display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;flex-shrink:0
}
.service-chip h4{font-size:1rem;margin-bottom:0.15rem;color:var(--text)}
.service-chip p{color:var(--text-light);font-size:0.85rem}

/* Rooms Cards */
.rooms{background:var(--bg)}
.rooms-timeline{display:flex;flex-direction:column;gap:2rem}
.room-block{
  display:grid;grid-template-columns:320px 1fr;
  background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--border);transition:var(--transition);
  box-shadow:var(--shadow-sm)
}
.room-block:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.room-visual{
  position:relative;display:flex;align-items:center;justify-content:center;
  font-size:4rem;min-height:220px;
  background:linear-gradient(135deg,var(--primary-dark),var(--primary),var(--primary-light));
  color:var(--text-white)
}
.room-visual::after{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'%3E%3Cpath fill='rgba(255,255,255,0.05)' d='M0,160L48,170.7C96,181,192,203,288,197.3C384,192,480,160,576,165.3C672,171,768,213,864,208C960,203,1056,149,1152,138.7C1248,128,1344,160,1392,176L1440,192L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'/%3E%3C/svg%3E") center bottom/cover no-repeat
}
.room-detail{padding:1.75rem 1.75rem 1.75rem 0}
.room-detail h3{font-family:'Playfair Display','Noto Sans Georgian',serif;font-size:1.35rem;margin-bottom:0.35rem;color:var(--primary-dark)}
.room-detail>p{color:var(--text-light);font-size:0.925rem;margin-bottom:0.75rem}
.room-tags{display:flex;flex-wrap:wrap;gap:0.4rem;margin-bottom:0.75rem}
.room-tags span{
  background:var(--bg);padding:0.35rem 0.85rem;border-radius:var(--radius-full);
  font-size:0.8rem;border:1px solid var(--border);color:var(--text-light)
}
.room-pricing{margin-bottom:1.25rem}
.room-pricing .price{
  font-family:'Noto Sans Georgian','Inter',sans-serif;
  font-size:1.75rem;font-weight:700;color:var(--accent);
  letter-spacing:-0.02em
}
.room-pricing .period{color:var(--text-light);font-size:0.9rem}
.room-detail .btn{padding:0.75rem 2rem}

/* Gallery Masonry */
.gallery-masonry{
  display:grid;grid-template-columns:repeat(4,1fr);
  grid-auto-rows:220px;gap:1rem
}
.gallery-cell{
  border-radius:var(--radius);overflow:hidden;cursor:pointer;
  position:relative
}
.gallery-cell img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease}
.gallery-cell:hover img{transform:scale(1.1)}
.gallery-cell::after{
  content:'';position:absolute;inset:0;
  background:rgba(30,96,145,0.3)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E")
    center/2rem no-repeat;
  display:block;opacity:0;transition:var(--transition)
}
.gallery-cell:hover::after{opacity:1}
.gallery-cell--tall{grid-row:span 2}

/* Location Split */
.location{background:var(--bg-card)}
.location-split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.loc-card{padding:2rem;background:var(--bg);border-radius:var(--radius-lg);border:1px solid var(--border)}
.loc-card h3{font-size:1.15rem;margin-bottom:0.5rem;color:var(--primary-dark)}
.loc-card a{color:var(--primary);font-weight:600}
.loc-card p{color:var(--text-light);margin-bottom:1.5rem}
.dist-list{display:grid;gap:0.75rem;margin-top:1.5rem}
.dist-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:0.75rem 1rem;background:var(--bg-card);border-radius:var(--radius);
  border:1px solid var(--border);transition:var(--transition)
}
.dist-row:hover{background:var(--primary);color:var(--text-white)}
.dist-row:hover strong{color:var(--text-white)}
.loc-map{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.loc-map iframe{width:100%;height:420px;border:none;display:block}

/* Testimonials */
.testimonial-scroll{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.testi-card{
  background:var(--bg-card);padding:2rem;border-radius:var(--radius);
  border:1px solid var(--border);transition:var(--transition);
  position:relative
}
.testi-card::before{
  content:'\201C';position:absolute;top:0.75rem;left:1.25rem;
  font-size:3rem;line-height:1;color:var(--primary-light);opacity:0.3;
  font-family:'Playfair Display',serif
}
.testi-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.testi-stars{color:#F59E0B;font-size:1.1rem;margin-bottom:1rem}
.testi-card p{color:var(--text-light);margin-bottom:1rem;font-style:italic;line-height:1.7}
.testi-author{font-weight:600;color:var(--primary-dark);font-size:0.925rem}

/* CTA Band */
.cta-band{
  background:linear-gradient(135deg,var(--primary-dark),var(--primary),var(--primary-light));
  text-align:center;padding:5rem 1.5rem;color:var(--text-white);
  position:relative;overflow:hidden
}
.cta-band::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'%3E%3Cpath fill='rgba(255,255,255,0.05)' d='M0,224L48,213.3C96,203,192,181,288,181.3C384,181,480,203,576,218.7C672,235,768,245,864,234.7C960,224,1056,192,1152,181.3C1248,171,1344,181,1392,186.7L1440,192L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'/%3E%3C/svg%3E") center bottom/cover no-repeat;
  opacity:0.5
}
.cta-band h2{font-family:'Playfair Display','Noto Sans Georgian',serif;font-size:2.75rem;margin-bottom:1rem;position:relative}
.cta-band p{font-size:1.15rem;opacity:0.9;margin-bottom:2rem;position:relative}
.cta-group{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative}

/* Booking Panel */
.booking-panel{max-width:720px;margin:0 auto;background:var(--bg-card);padding:3rem;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.form-group{display:flex;flex-direction:column;gap:0.4rem}
.form-group.full{grid-column:1/-1}
.form-group label{font-size:0.875rem;font-weight:600;color:var(--text)}
.form-group input,.form-group select,.form-group textarea{
  padding:0.75rem 1rem;border:1.5px solid var(--border);border-radius:12px;
  font-size:0.95rem;font-family:inherit;transition:var(--transition);
  background:var(--bg);color:var(--text)
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,96,145,0.12)
}
.form-group textarea{resize:vertical;min-height:80px}
.booking-panel .btn-block{margin-top:0.5rem;font-size:1.05rem;padding:1rem}
.booking-success{display:none;text-align:center;padding:2rem;font-size:1.1rem;color:#059669;font-weight:600}
.booking-success.show{display:block}

/* Contact Stack */
.contact{background:var(--bg)}
.contact-stack{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.contact-item{
  background:var(--bg-card);padding:2rem;border-radius:var(--radius);
  text-align:center;border:1px solid var(--border);transition:var(--transition)
}
.contact-item:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.contact-symbol{
  width:72px;height:72px;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.25rem;font-size:1.75rem
}
.contact-item h3{margin-bottom:0.5rem;font-size:1.1rem;color:var(--primary-dark)}
.contact-item a{color:var(--primary);font-weight:600;transition:var(--transition)}
.contact-item a:hover{color:var(--primary-light)}
.contact-item p{color:var(--text-light)}

/* Share */
.share-band{background:var(--bg-card);padding:2.5rem 0;text-align:center}
.share-inner h3{font-family:'Playfair Display','Noto Sans Georgian',serif;font-size:1.25rem;margin-bottom:1.25rem;color:var(--text)}
.share-buttons{display:flex;justify-content:center;align-items:center;gap:0.75rem;flex-wrap:wrap}
.share-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:0.4rem;
  padding:0.6rem 1.2rem;border-radius:var(--radius-full);
  font-size:0.9rem;font-weight:600;border:none;cursor:pointer;
  transition:var(--transition);text-decoration:none;color:white;white-space:nowrap
}
.share-btn:hover{transform:translateY(-2px);opacity:0.9}
.share-native{background:var(--primary)}
.share-fb{background:#1877F2;width:40px;height:40px;padding:0;border-radius:50%}
.share-tw{background:#1DA1F2;width:40px;height:40px;padding:0;border-radius:50%}
.share-wa{background:#25D366;width:40px;height:40px;padding:0;border-radius:50%}
.share-tg{background:#0088CC;width:40px;height:40px;padding:0;border-radius:50%}
.share-li{background:#0A66C2;width:40px;height:40px;padding:0;border-radius:50%}
.share-vk{background:#4C75A3;width:40px;height:40px;padding:0;border-radius:50%}
.share-pi{background:#E60023;width:40px;height:40px;padding:0;border-radius:50%}

@media(max-width:768px){
  .share-band{padding:1.5rem 0}
  .share-buttons{gap:0.5rem}
}

/* Footer */
footer{background:var(--primary-dark);color:var(--text-white);padding:4rem 1.5rem 2rem;position:relative}
footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary-light),var(--accent),var(--primary))
}
.footer-content{max-width:var(--max-width);margin:0 auto;text-align:center}
.footer-brand{font-family:'Noto Sans Georgian','Playfair Display',serif;font-size:1.75rem;font-weight:700;margin-bottom:0.75rem}
.footer-content>p{opacity:0.7;margin-bottom:1.5rem;font-size:0.95rem}
.footer-info{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:2rem;font-size:0.9rem;opacity:0.8}
.footer-divider{height:1px;background:rgba(255,255,255,0.15);margin-bottom:2rem}
.footer-copy{opacity:0.5;font-size:0.85rem}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,0.92);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity 0.3s,visibility 0.3s
}
.lightbox.active{opacity:1;visibility:visible}
.lightbox img{
  max-width:90vw;max-height:85vh;border-radius:12px;
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
  transform:scale(0.9);transition:transform 0.3s
}
.lightbox.active img{transform:scale(1)}
.lightbox-close,.lightbox-nav{
  position:absolute;width:48px;height:48px;border:none;
  background:rgba(255,255,255,0.1);border-radius:50%;
  color:white;font-size:1.5rem;cursor:pointer;
  transition:var(--transition);display:flex;align-items:center;justify-content:center
}
.lightbox-close{top:1.5rem;right:1.5rem}
.lightbox-close:hover,.lightbox-nav:hover{background:rgba(255,255,255,0.25)}
.lightbox-nav.prev{left:1.5rem;top:50%;transform:translateY(-50%)}
.lightbox-nav.next{right:1.5rem;top:50%;transform:translateY(-50%)}
.lightbox-counter{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.6);font-size:0.9rem}

/* Floating WhatsApp */
.whatsapp-float{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:999;
  width:56px;height:56px;background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.75rem;color:white;
  box-shadow:0 4px 16px rgba(37,211,102,0.4);
  transition:var(--transition);text-decoration:none
}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 24px rgba(37,211,102,0.5)}

/* Back to Top */
.back-to-top{
  position:fixed;bottom:1.5rem;left:1.5rem;z-index:999;
  width:44px;height:44px;background:var(--accent);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:white;font-size:1.25rem;box-shadow:var(--shadow);
  transition:var(--transition);border:none;cursor:pointer;
  opacity:0;visibility:hidden;transform:translateY(10px)
}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--accent-dark);transform:translateY(-3px)}

/* Animations */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease,transform 0.6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.pulse{animation:pulse 2s infinite}

@media(max-width:1024px){
  .hero h1{font-size:3.5rem}
  .gallery-masonry{grid-template-columns:repeat(3,1fr)}
  .testimonial-scroll{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .hamburger{display:flex}
  .nav-links{
    position:fixed;top:var(--nav-height);left:0;right:0;
    background:rgba(240,244,248,0.98);backdrop-filter:blur(12px);
    flex-direction:column;padding:1rem;gap:0.25rem;
    border-bottom:1px solid var(--border);display:none
  }
  .nav-links.open{display:flex}
  .nav-links a{width:100%;text-align:center;padding:0.75rem 1rem}
  .lang-selector{border-left:none;margin-left:0;padding:0.5rem 0 0 0;justify-content:center;width:100%;border-top:1px solid var(--border);margin-top:0.25rem;padding-top:0.75rem}

  .hero{min-height:auto;padding-top:calc(var(--nav-height) + 2rem);padding-bottom:4rem}
  .hero h1{font-size:2.5rem}
  .hero-sub{font-size:1rem}
  .hero-badge{font-size:0.8rem}

  .stats-track{grid-template-columns:repeat(2,1fr);gap:1.5rem}
  .stat-cell h3{font-size:2rem}

  .about-wrap{grid-template-columns:1fr;gap:2rem}
  .about-frame{height:280px}

  .features-bento{grid-template-columns:1fr}

  .services-grid{grid-template-columns:1fr}

  .room-block{grid-template-columns:1fr}
  .room-visual{min-height:140px}
  .room-detail{padding:1.25rem}

  .gallery-masonry{grid-template-columns:repeat(2,1fr)}
  .gallery-cell--tall{grid-row:span 1}

  .location-split{grid-template-columns:1fr}
  .testimonial-scroll{grid-template-columns:1fr}
  .contact-stack{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .booking-panel{padding:1.5rem}
  .footer-info{flex-direction:column;align-items:center;gap:0.75rem}
  .section{padding:3rem 0}
  .section-header h2{font-size:2rem}
  .cta-band h2{font-size:2rem}
  .lightbox-nav{display:none}
}
@media(max-width:480px){
  .hero h1{font-size:2rem}
  .gallery-masonry{grid-template-columns:1fr 1fr;gap:0.5rem}
  .stat-cell h3{font-size:1.75rem}
  .room-pricing .price{font-size:1.5rem}
}