*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;color:#0f172a;background:#ffffff}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.site-header{position:sticky;top:0;background:#ffffffcc;backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid #e2e8f0;z-index:10}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{font-weight:700;color:#0f172a;text-decoration:none;font-size:18px;display:flex;align-items:center;gap:8px}
.brand-logo{height:40px;width:40px;display:block;border-radius:50%;object-fit:cover;border:1px solid #0f172a20}
.nav-links{display:flex;gap:18px}
.nav-links a{color:#0f172a;text-decoration:none;padding:8px 10px;border-radius:8px}
.nav-links a.active,.nav-links a:hover{background:#f1f5f9}
.nav-toggle{display:none;border:1px solid #e2e8f0;background:#fff;padding:8px 10px;border-radius:8px}
@media (max-width:768px){.nav-links{display:none;position:absolute;right:20px;top:72px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:10px;flex-direction:column;min-width:180px}.nav-links.open{display:flex}.nav-toggle{display:block}}
.hero{background:linear-gradient(120deg,#0ea5e9 0%,#22c55e 100%);color:#fff}
.hero-inner{padding:80px 0;text-align:center}
.hero h1{font-size:40px;line-height:1.1;margin:0 0 10px}
.hero-title{display:inline-flex;align-items:center;gap:10px}
.hero-title img{width:200px;height:200px;object-fit:cover;border-radius:50%;border:2px solid #ffffff50;box-shadow:0 6px 20px rgba(0,0,0,.25)}
@media (max-width:640px){.hero-title img{width:140px;height:140px}}
.hero p{font-size:18px;margin:0 0 20px}
.actions{display:flex;gap:12px;justify-content:center}
.btn{display:inline-block;padding:12px 18px;border-radius:10px;border:1px solid #0f172a20;background:#fff;color:#0f172a;text-decoration:none;font-weight:600}
.btn.primary{background:#0f172a;color:#fff;border-color:#0f172a}
.btn:hover{opacity:.9}
.page-title{margin:28px 0 10px;font-size:28px}
.features{padding:40px 0}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{border:1px solid #e2e8f0;border-radius:12px;padding:18px;background:#fff}
@media (max-width:900px){.feature-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.feature-grid{grid-template-columns:1fr}}
.cta{background:#0f172a;color:#fff}
.cta-inner{padding:36px 0;text-align:center}
.site-footer{border-top:1px solid #e2e8f0;margin-top:40px;background:#fff}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:18px 0}
.footer-links{display:flex;gap:16px}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery-grid img{width:100%;height:260px;object-fit:cover;border-radius:12px;border:1px solid #e2e8f0}
@media (max-width:900px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.gallery-grid{grid-template-columns:1fr}}
.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media (max-width:800px){.contact-grid{grid-template-columns:1fr}}
.booking-widget{border:1px dashed #0f172a40;border-radius:12px;padding:24px;background:#f8fafc}
.note{color:#334155}

/* Contact form */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:12px 0 14px}
.form-grid label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:14px}
.form-grid label span{color:#0f172a}
.form-grid .full{grid-column:1/-1}
input[type="text"],input[type="email"],textarea{border:1px solid #e2e8f0;border-radius:10px;padding:12px;font:inherit;color:#0f172a;background:#fff}
input[type="text"]:focus,input[type="email"]:focus,textarea:focus{outline:2px solid #93c5fd;outline-offset:1px}
.hp{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}
.form-status{margin-top:10px;font-weight:600}
.form-status.sending{color:#0ea5e9}
.form-status.success{color:#16a34a}
.form-status.error{color:#b91c1c}
@media (max-width:720px){.form-grid{grid-template-columns:1fr}}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(15,23,42,.9);display:none;align-items:center;justify-content:center;z-index:50}
.lightbox.open{display:flex}
.lightbox-inner{position:relative;max-width:95vw;max-height:90vh;display:flex;align-items:center;justify-content:center}
.lightbox img{max-width:95vw;max-height:90vh;border-radius:8px;box-shadow:0 10px 30px rgba(0,0,0,.5)}
.lightbox .close-btn{position:absolute;top:-44px;right:0;background:#ffffff;border:0;border-radius:999px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.lightbox .arrow{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff;border:0;border-radius:999px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.9}
.lightbox .arrow:hover{opacity:1}
.lightbox .prev{left:-54px}
.lightbox .next{right:-54px}
@media (max-width:640px){
  .lightbox .prev{left:8px}
  .lightbox .next{right:8px}
  .lightbox .close-btn{top:8px;right:8px}
}

/* Banner */
.banner{width:100%;overflow:hidden;background:#000}
.banner .container{max-width:100%;padding:0}
.banner-image{display:block;width:100%;height:auto;max-width:100%;object-fit:cover}
