
:root{
  --bg:#07111f;
  --bg2:#050a13;
  --card:rgba(255,255,255,.05);
  --card-2:rgba(255,255,255,.04);
  --border:rgba(255,255,255,.1);
  --text:rgba(255,255,255,.95);
  --muted:rgba(255,255,255,.72);
  --muted-2:rgba(255,255,255,.55);
  --requested:#facc15;
  --booked:#f87171;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,Helvetica,sans-serif;
  background:var(--bg);
  color:var(--text);
}
.hidden{display:none}
a{text-decoration:none;color:inherit}
button,input,textarea{font:inherit}

.lockscreen{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
  background:var(--bg);
}
.lockbox{
  width:100%;
  max-width:430px;
  border:1px solid var(--border);
  background:var(--card);
  border-radius:32px;
  padding:32px;
  box-shadow:0 20px 80px rgba(0,0,0,.45);
  backdrop-filter:blur(14px);
}
.brandline{display:flex;gap:12px;align-items:center}
.brandicon{
  width:44px;height:44px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border);background:var(--card);
  box-shadow:0 20px 50px rgba(0,0,0,.2)
}
.brandname{font-size:12px;font-weight:700;letter-spacing:.2em;color:rgba(255,255,255,.6)}
.brandsub{font-size:16px;color:rgba(255,255,255,.8)}
.brandsub.white{color:#fff}
.locktitle{font-size:34px;margin:18px 0 10px}
.locktext{line-height:1.7;color:var(--muted)}
.input,.textarea{
  width:100%;
  border-radius:16px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.05);
  color:#fff;
  padding:14px 16px;
}
.input::placeholder,.textarea::placeholder{color:rgba(255,255,255,.35)}
.textarea{min-height:140px;resize:vertical}
.error{color:#fca5a5;margin-top:10px}
.primary-btn,.secondary-btn{
  border:none;
  border-radius:18px;
  padding:14px 18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:.2s ease;
}
.primary-btn{background:#fff;color:#0f172a;font-weight:700}
.primary-btn:hover{background:rgba(255,255,255,.92)}
.secondary-btn{
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.05);
  color:#fff;
}
.secondary-btn:hover{background:rgba(255,255,255,.1)}
.full{width:100%}
.small{width:48px;height:48px;padding:0}

.page{min-height:100vh;background:var(--bg)}
.hero-shell{position:relative;overflow:hidden}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at top right, rgba(87,143,255,.28), transparent 35%),
    radial-gradient(circle at top left, rgba(255,255,255,.08), transparent 20%),
    linear-gradient(180deg,#08111d 0%,#07111f 45%,#050a13 100%);
}
.site-header,.hero,.main,.site-footer{
  position:relative;z-index:1;
  width:min(1280px, calc(100% - 32px));
  margin:0 auto;
}
.site-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;
}
.nav{display:flex;align-items:center;gap:24px;font-size:14px;color:rgba(255,255,255,.72)}
.nav a:hover{color:#fff}
.legal-badge{
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.1);
  color:rgba(255,255,255,.82);
  padding:6px 12px;border-radius:999px;font-size:10px;letter-spacing:.15em
}

.hero{
  display:grid;grid-template-columns:1.1fr .9fr;gap:64px;
  align-items:center;padding:20px 0 96px;
}
.eyebrow-badge{
  display:inline-flex;padding:8px 14px;border-radius:999px;
  border:1px solid var(--border);background:rgba(255,255,255,.1);
  font-size:12px;letter-spacing:.18em;color:rgba(255,255,255,.82);
  margin-bottom:20px;text-transform:none
}
.hero-title{
  margin:0;
  font-size:clamp(42px, 7vw, 78px);
  line-height:1.02;
  letter-spacing:-.04em;
}
.hero-title span{display:block;color:rgba(255,255,255,.72)}
.hero-text{max-width:780px;line-height:1.75;color:var(--muted);font-size:18px}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}
.stat-card,.offer-card,.mini-card,.detail-card,.legal-card,.form-card{
  border:1px solid var(--border);
  background:var(--card);
  border-radius:28px;
  box-shadow:0 20px 80px rgba(0,0,0,.22);
}
.stat-card{padding:20px}
.stat-label{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.stat-value{margin-top:12px;line-height:1.5;color:rgba(255,255,255,.92)}

.video-card{border-radius:32px;overflow:hidden;border:1px solid var(--border);background:var(--card)}
.video-wrap{position:relative;height:540px}
.video-wrap video,.video-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.video-overlay{position:absolute;inset:0;background:linear-gradient(to top,#04101d 0%, rgba(4,16,29,.2) 45%, transparent 100%)}
.video-chip{
  position:absolute;left:20px;top:20px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(0,0,0,.3);backdrop-filter:blur(12px);
  padding:8px 14px;border-radius:999px;font-size:14px;color:rgba(255,255,255,.85)
}
.video-caption{position:absolute;left:0;right:0;bottom:0;padding:28px}
.video-kicker{font-size:14px;color:rgba(255,255,255,.7)}
.video-caption h3{margin:12px 0 0;font-size:34px}
.video-caption p{max-width:580px;line-height:1.7;color:rgba(255,255,255,.75)}
.thumb-grid{margin-top:16px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.thumb{
  border:1px solid var(--border);border-radius:18px;padding:0;background:none;overflow:hidden;cursor:pointer
}
.thumb.active{border-color:rgba(255,255,255,.4);box-shadow:0 0 0 2px rgba(255,255,255,.18)}
.thumb img{width:100%;height:88px;object-fit:cover;display:block}
.arrow-row{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}

.main{padding:96px 0}
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start;margin-bottom:112px}
.stack{margin-bottom:112px}
.section-copy.narrow{max-width:820px}
.section-eyebrow{
  font-size:12px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.6);
  margin-bottom:12px
}
.section-copy h2{font-size:clamp(34px,4vw,54px);margin:0 0 16px;letter-spacing:-.03em}
.section-copy p{font-size:18px;line-height:1.75;color:var(--muted)}
.offer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.offer-card{padding:24px;display:flex;flex-direction:column;min-height:100%}
.offer-badge{
  align-self:flex-start;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.1);
  color:rgba(255,255,255,.8);font-size:13px
}
.offer-card h3{font-size:26px;margin:18px 0}
.offer-line{color:var(--muted);line-height:1.65;margin-top:10px}
.mt-auto{margin-top:auto}

.mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:24px}
.one-col{grid-template-columns:1fr}
.mini-card{padding:20px}
.mini-card h4{margin:0 0 12px;font-size:18px}
.mini-card p{margin:0;line-height:1.7;color:var(--muted)}
.image-panel{
  border-radius:32px;overflow:hidden;border:1px solid var(--border);background:var(--card-2)
}
.image-panel img{width:100%;height:100%;min-height:320px;object-fit:cover;display:block}

.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:24px}
.gallery-card{
  position:relative;overflow:hidden;border-radius:32px;border:1px solid var(--border)
}
.gallery-card img{width:100%;height:360px;object-fit:cover;display:block;transition:transform .5s ease}
.gallery-card:hover img{transform:scale(1.03)}
.gallery-overlay{
  position:absolute;inset:0;padding:24px;
  display:flex;flex-direction:column;justify-content:flex-end;
  background:linear-gradient(to top, rgba(0,0,0,.7), rgba(0,0,0,.08) 55%, transparent)
}
.gallery-overlay h3{margin:0;font-size:24px}
.gallery-overlay p{margin:10px 0 0;line-height:1.6;color:rgba(255,255,255,.78)}

.stats-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}
.detail-card{padding:18px;text-align:center}
.detail-label{font-size:13px;color:rgba(255,255,255,.5)}
.detail-value{font-size:28px;font-weight:700;color:#fff;margin-top:8px}

.booking-panel{
  margin-top:24px;padding:24px;border:1px solid var(--border);border-radius:32px;background:var(--card-2)
}
.booking-header{display:flex;align-items:center;gap:10px;font-weight:700;margin-bottom:16px}
.booking-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.small-label{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:12px}
.helper{font-size:12px;color:rgba(255,255,255,.5);margin-top:12px;line-height:1.5}
.slot-row{display:flex;flex-wrap:wrap;gap:10px}
.slot-btn{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);color:rgba(255,255,255,.8);
  padding:8px 12px;border-radius:999px;cursor:pointer
}
.slot-btn.active{background:#fff;color:#0f172a;border-color:#fff}
.slot-btn.requested{border-color:rgba(250,204,21,.3);background:rgba(234,179,8,.12);color:#fef08a}
.slot-btn.booked{border-color:rgba(248,113,113,.3);background:rgba(239,68,68,.12);color:#fecaca}
.slot-btn.disabled{opacity:.3;cursor:not-allowed}
.legend-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.legend-chip{
  border:1px solid var(--border);background:rgba(255,255,255,.05);
  padding:6px 12px;border-radius:999px;font-size:12px;color:rgba(255,255,255,.68)
}
.legend-chip.requested{border-color:rgba(250,204,21,.3);background:rgba(234,179,8,.12);color:#fef08a}
.legend-chip.booked{border-color:rgba(248,113,113,.3);background:rgba(239,68,68,.12);color:#fecaca}

.form-card{padding:24px}
.form-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.form-head h3{font-size:32px;margin:8px 0 0}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.notice,.status-message{font-size:14px;line-height:1.7;margin-top:16px}
.notice{color:var(--muted-2)}
.status-message{color:#fef08a}

.legal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.legal-card{padding:24px}
.legal-card h3{font-size:32px;margin:0 0 16px}
.legal-card p{line-height:1.75;color:var(--muted)}
.site-footer{
  border-top:1px solid var(--border);
  background:var(--bg2);
  display:grid;grid-template-columns:1.2fr .8fr;gap:32px;
  padding:40px 0 48px
}
.footer-eyebrow{font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.site-footer h3{font-size:32px;margin:14px 0}
.site-footer p{max-width:760px;line-height:1.7;color:var(--muted-2)}
.footer-list{display:grid;gap:12px;color:rgba(255,255,255,.75)}

@media (max-width: 1100px){
  .hero,.split,.site-footer{grid-template-columns:1fr}
  .offer-grid,.gallery-grid,.legal-grid,.stats-detail-grid,.booking-grid,.stats-grid{grid-template-columns:1fr 1fr}
  .nav{display:none}
}
@media (max-width: 700px){
  .site-header,.hero,.main,.site-footer{width:min(1280px, calc(100% - 24px))}
  .hero{padding-bottom:64px}
  .hero-title{font-size:44px}
  .offer-grid,.gallery-grid,.stats-detail-grid,.booking-grid,.stats-grid,.mini-grid,.legal-grid{grid-template-columns:1fr}
  .video-wrap{height:360px}
  .video-caption h3,.section-copy h2,.legal-card h3,.form-head h3,.site-footer h3{font-size:28px}
  .thumb img{height:72px}
}
