
:root{--bg:#fff;--text:#0f172a;--muted:#475569;--brand:#0ea5e9;--brand-2:#a78bfa;--accent:#14b8a6;--watermark-opacity:0.12;--watermark-size:86vw}
*{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:var(--text);background:var(--bg);line-height:1.6}
.container{width:min(1150px,92vw);margin-inline:auto}
.header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(180%) blur(6px);background:rgba(255,255,255,.75);border-bottom:1px solid rgba(2,6,23,.06)}
.header .row{display:flex;align-items:center;justify-content:space-between;padding:16px 0}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}
.brand img{width:42px;height:42px;border-radius:8px}
.nav{display:flex;gap:18px;align-items:center}
.nav a{color:#0f172a;text-decoration:none;font-weight:600;padding:8px 10px;border-radius:10px}
.nav a:hover{background:#eef2ff}
.cta{display:inline-block;padding:10px 14px;border-radius:999px;font-weight:700;text-decoration:none;background:linear-gradient(90deg,var(--brand),var(--brand-2));color:#fff}
.mobile-toggle{display:none}
@media(max-width:860px){.nav{display:none}.mobile-toggle{display:block;border:1px solid rgba(2,6,23,.1);border-radius:10px;padding:8px 12px;background:#fff}
.mobile-panel{display:none;position:absolute;left:0;top:100%;width:100%;background:#fff;border-bottom:1px solid rgba(2,6,23,.06)}

}
.hero{position:relative;isolation:isolate;display:grid;align-items:center;min-height:78vh;padding:64px 0;background:none}
.watermark::after{
  content:"";
  position:fixed;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:min(96vmin, 96vw, 96vh);
  height:min(96vmin, 96vw, 96vh);
  background:url("assets/logo.png") no-repeat center/contain;
  opacity:var(--watermark-opacity);
  pointer-events:none;
  z-index:-1;
  filter:grayscale(10%);
}
.hero .eyebrow{display:inline-flex;gap:6px;align-items:center;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted)}
.hero h1{font-size:clamp(32px,5vw,56px);line-height:1.08;margin:10px 0 12px}
.hero p{font-size:clamp(16px,2.2vw,20px);color:var(--muted);max-width:60ch}
.hero .actions{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}
.btn{display:inline-block;padding:12px 18px;border-radius:999px;font-weight:700;text-decoration:none}
.btn.primary{background:linear-gradient(90deg,var(--brand),var(--brand-2));color:#fff}
.btn.secondary{border:2px solid rgba(2,6,23,.12);color:var(--text);background:#ffffffcc}
.section{padding:72px 0}.section h2{font-size:clamp(26px,4vw,40px);margin:0 0 10px}.lead{color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:24px}
.grid .card{background:none;border:1px solid rgba(2,6,23,.06);border-radius:18px;overflow:hidden}
.grid .card img{width:100%;max-height:200px;height:auto;object-fit:contain;display:block}
.grid .card .pad{padding:16px}
@media(max-width:1020px){.grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:580px){.grid{grid-template-columns:1fr}}
footer{background:#0b1220;color:#e2e8f0;padding:50px 0;margin-top:40px}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:22px}footer a{color:#cbd5e1;text-decoration:none}
footer .brandline{display:flex;align-items:center;gap:12px;margin-bottom:12px}footer .brandline img{width:42px;height:42px;border-radius:8px}
@media(max-width:760px){footer .cols{grid-template-columns:1fr}}form{display:grid;gap:12px}
input,textarea,select{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(2,6,23,.14);font:inherit;outline:none}
input:focus,textarea:focus,select:focus{box-shadow:0 0 0 4px rgba(32,156,238,.18)}label{font-weight:700;font-size:14px}
small.helper{color:var(--muted)}.success{padding:18px;border-radius:12px;background:#ecfeff;border:1px solid #a5f3fc;color:#134e4a;font-weight:600}
.center{text-align:center}.stack{display:grid;gap:8px}.pad{padding:16px}.hidden{display:none !important}
.badge{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(2,6,23,.1);padding:8px 14px;border-radius:999px;background:#fff}
.badge .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
audio{width:100%}.audio-card{background:none;border:1px solid rgba(2,6,23,.08);border-radius:16px;padding:16px}
.about-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
.about-photos img{width:100%;max-height:320px;height:auto;object-fit:contain;border-radius:14px}
.notice{background:none;border:1px solid rgba(2,6,23,.08);padding:16px;border-radius:14px}

.header .row{flex-direction:column;gap:10px}
.nav{justify-content:center}

/* Global image-fit adjustments */
.grid .card img, .about-photos img, .card img {
  object-fit: contain !important;
  width: 100%;
  height: auto;
  background: transparent; /* keep minimal aesthetic */
}

/* Hero layout with portrait */
.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center}
@media(max-width:900px){.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center}}
.hero-portrait{width:100%;max-width:560px;height:auto;object-fit:contain;border-radius:16px}

#whats-on{
  position:relative;
}
#whats-on::before{content:"";position:absolute;inset:0;background:url("assets/lifestyle-beach.jpg") no-repeat top center/cover;opacity:0.25;z-index:-1;}

.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center}
.hero-text{}
.hero-media{text-align:center}
.hero-portrait{max-width:500px;width:100%;height:auto;object-fit:contain;border-radius:16px}
