:root{
  --bg:#ffffff;
  --paper:#fbfcfe;
  --ink:#0b0f19;
  --muted:#5b6476;
  --line:#e7ecf3;

  --shadow: 0 18px 55px rgba(13, 20, 35, .10);
  --shadow2: 0 10px 28px rgba(13, 20, 35, .09);

  --r12:12px; --r16:16px; --r20:20px; --r26:26px;
  --max: 1120px;

  --accent:#0b0f19;
  --danger:#b42318;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:var(--bg);
}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
.no-scroll{overflow:hidden}
.container{width:min(var(--max), calc(100% - 40px)); margin-inline:auto}

/* Topbar */
.topbar{background:#0b0f19; color:#fff; font-size:13px}
.topbar__inner{display:flex; gap:10px; align-items:center; padding:10px 0; flex-wrap:wrap}
.topbar__dot{width:8px;height:8px;border-radius:50%; background:#9aa4b2; box-shadow:0 0 0 4px rgba(154,164,178,.18)}
.topbar__link{opacity:.95}
.topbar__link:hover{opacity:1; text-decoration:underline}
.topbar__sep{opacity:.45}

/* Header */
.header{
  position:sticky; top:0; z-index:50;
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(14px);
  border-bottom:1px solid rgba(231,236,243,.75);
}
.header__inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:18px}
.brand{display:flex; align-items:center; gap:12px; min-width:240px}
.brand__mark{
  width:44px;height:44px;border-radius:14px;
  background: linear-gradient(180deg, #ffffff 0%, #f3f6fb 100%);
  border:1px solid var(--line);
  box-shadow:0 8px 20px rgba(13,20,35,.08);
  display:grid; place-items:center; overflow:hidden;
}
.brand__logo{width:30px;height:30px; object-fit:contain}
.brand__fallback{
  font-family:"Space Grotesk", Inter, sans-serif;
  font-weight:700; letter-spacing:.06em;
  color:var(--accent); font-size:14px;
}
.brand__text{display:flex; flex-direction:column; line-height:1.05}
.brand__kicker{font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted)}
.brand__name{font-family:"Space Grotesk", Inter, sans-serif; font-weight:700; letter-spacing:.08em}

/* Nav */
.nav{display:flex; align-items:center; gap:18px}
.nav a{
  font-size:14px; color:rgba(11,15,25,.86);
  padding:10px 8px; border-radius:12px;
  transition: background .18s ease, color .18s ease;
}
.nav a:hover{background:rgba(231,236,243,.7)}
.nav a.is-active{
  background: rgba(11,15,25,.06);
  color: var(--accent);
  position:relative;
}
.nav a.is-active::after{
  content:""; position:absolute;
  left:10px; right:10px; bottom:6px;
  height:2px; border-radius:2px;
  background: linear-gradient(90deg, var(--accent) 0%, rgba(11,15,25,.35) 100%);
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 16px; border-radius:14px;
  font-weight:600; font-size:14px;
  border:1px solid transparent;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
  user-select:none;
}
.btn:active{transform: translateY(1px)}
.btn--primary{background: var(--accent); color:#fff; box-shadow:0 12px 30px rgba(11,15,25,.18)}
.btn--primary:hover{box-shadow:0 16px 38px rgba(11,15,25,.22)}
.btn--ghost{background: rgba(255,255,255,.9); border-color: var(--line); color: var(--accent)}
.btn--ghost:hover{box-shadow: var(--shadow2)}
.header__actions{display:flex; align-items:center; gap:10px}

/* Burger */
.burger{
  width:44px;height:44px; border-radius:14px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.9);
  display:none; align-items:center; justify-content:center;
  gap:5px; cursor:pointer;
}
.burger span{display:block; width:18px; height:2px; background: var(--accent); border-radius:2px}

/* Mobile */
.mobile{position:fixed; inset:0; background: rgba(11,15,25,.55); opacity:0; pointer-events:none; transition: opacity .18s ease}
.mobile.is-open{opacity:1; pointer-events:auto}
.mobile__panel{
  position:absolute; top:0; right:0; height:100%;
  width:min(360px, 86%);
  background:#fff; border-left:1px solid var(--line);
  box-shadow: var(--shadow);
  padding:16px;
  display:flex; flex-direction:column; gap:8px;
  transform: translateX(10px);
  transition: transform .18s ease;
}
.mobile.is-open .mobile__panel{transform: translateX(0)}
.mobile__panel a{padding:12px 12px; border-radius:14px; border:1px solid transparent}
.mobile__panel a:hover{background: rgba(231,236,243,.8)}
.mobile__line{height:1px; background: var(--line); margin:6px 0}
.mobile__cta{width:100%}

/* Sections */
.section{padding:70px 0}
.section--soft{background: var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section__head{display:flex; align-items:flex-end; justify-content:space-between; gap:18px; margin-bottom:22px}
.section__head h2{margin:0; font-family:"Space Grotesk", Inter, sans-serif; letter-spacing:.02em; font-size:34px}
.section__head p{margin:0; color:var(--muted); max-width:520px}

/* Hero */
.hero{padding:72px 0 30px; position:relative; overflow:hidden}
.hero__inner{display:grid; grid-template-columns: 1.3fr .9fr; gap:26px; align-items:stretch}
.pill{
  display:inline-flex; gap:8px; align-items:center;
  padding:8px 12px; border-radius:999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.75);
  color: rgba(11,15,25,.78);
  font-size:13px; margin:0 0 14px;
}
.hero__title{margin:0; font-family:"Space Grotesk", Inter, sans-serif; font-size:54px; letter-spacing:.01em; line-height:1.05}
.accent{
  background: linear-gradient(90deg, #0b0f19 0%, #6b7280 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero__sub{margin:14px 0 18px; color:var(--muted); font-size:16px; line-height:1.65; max-width:620px}
.hero__cta{display:flex; gap:10px; flex-wrap:wrap}
.trust{margin-top:18px; display:flex; gap:12px; flex-wrap:wrap; color: rgba(11,15,25,.72); font-size:13px}
.trust__item{padding:10px 12px; border:1px solid var(--line); border-radius:999px; background: rgba(255,255,255,.72)}

/* Card bits */
.hero__card{
  border-radius: var(--r26);
  background: linear-gradient(180deg, #ffffff 0%, #f4f7fc 100%);
  border:1px solid var(--line);
  box-shadow: var(--shadow);
  padding:18px;
}
.glass__top{display:flex; gap:12px; align-items:center}
.avatar{
  width:54px;height:54px;border-radius:18px;
  background: radial-gradient(circle at 30% 30%, #ffffff 0%, #e9eef7 60%, #dee6f3 100%);
  border:1px solid var(--line);
  display:grid; place-items:center;
  font-family:"Space Grotesk", Inter, sans-serif;
  font-weight:700; letter-spacing:.08em;
}
.glass__name{font-weight:700}
.glass__meta{font-size:13px; color:var(--muted); margin-top:2px}
.stats{display:grid; grid-template-columns: repeat(3, 1fr); gap:10px; margin:16px 0 10px}
.stat{border:1px solid var(--line); background: rgba(255,255,255,.8); border-radius: var(--r16); padding:12px}
.stat__num{font-family:"Space Grotesk", Inter, sans-serif; font-weight:700; font-size:18px}
.stat__label{font-size:12px; color:var(--muted); margin-top:3px}
.divider{height:1px; background: var(--line); margin:12px 0}
.links{display:flex; gap:8px; flex-wrap:wrap}
.chip{
  border:1px solid var(--line);
  border-radius:999px;
  padding:10px 12px;
  background: rgba(255,255,255,.85);
  font-size:13px;
}
.chip--danger{border-color: rgba(180,35,24,.25); background: rgba(180,35,24,.06); color: var(--danger)}
.hint{margin:10px 0 0; color:var(--muted); font-size:12px}

/* Grids */
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.grid2{display:grid; grid-template-columns:repeat(2,1fr); gap:14px}

/* Cards */
.card{background:#fff; border:1px solid var(--line); border-radius: var(--r20); padding:18px; box-shadow: var(--shadow2)}
.card h3{margin:0 0 8px; font-size:18px}
.card p{margin:0; color:var(--muted); line-height:1.65}

/* Media */
.mediaCard{
  display:flex; align-items:center; gap:14px;
  background:#fff; border:1px solid var(--line);
  border-radius: var(--r20); padding:16px;
  box-shadow: var(--shadow2);
}
.mediaCard__icon{width:44px;height:44px;border-radius:16px; background: rgba(11,15,25,.06); border:1px solid var(--line); display:grid; place-items:center; font-weight:700}
.mediaCard__title{font-weight:700}
.mediaCard__desc{color:var(--muted); font-size:13px; margin-top:2px}
.mediaCard__arrow{margin-left:auto; color:rgba(11,15,25,.65)}

/* Event cards */
.event{display:flex; gap:14px; background:#fff; border:1px solid var(--line); border-radius: var(--r20); padding:16px; box-shadow: var(--shadow2)}
.event__date{
  width:58px; min-width:58px;
  border-radius:18px; border:1px solid var(--line);
  background: rgba(11,15,25,.04);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  padding:10px 0;
}
.event__day{font-family:"Space Grotesk", Inter, sans-serif; font-weight:700; font-size:18px}
.event__mon{font-size:12px; color:var(--muted); margin-top:2px}
.event__body h3{margin:0 0 6px}
.event__body p{margin:0; color:var(--muted); font-size:13px}
.tag{display:inline-flex; margin-top:10px; padding:8px 10px; border-radius:999px; border:1px solid var(--line); background: rgba(255,255,255,.85); font-size:12px}

/* Booking layout */
.booking{display:grid; grid-template-columns: 1.2fr .8fr; gap:14px; align-items:start}
.form{background:#fff; border:1px solid var(--line); border-radius: var(--r20); padding:18px; box-shadow: var(--shadow2)}
.form label{display:block; font-size:13px; color:rgba(11,15,25,.82); margin-bottom:10px}
input, select, textarea{
  width:100%;
  margin-top:8px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.92);
  outline:none;
  font-family:inherit;
  font-size:14px;
}
input:focus, select:focus, textarea:focus{
  border-color: rgba(11,15,25,.25);
  box-shadow: 0 0 0 6px rgba(11,15,25,.06);
}
.form__row{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.form__actions{display:flex; align-items:center; gap:12px; margin-top:10px; flex-wrap:wrap}
.form__hint{margin:0; color:var(--muted); font-size:12px}
.form__result{margin-top:14px}

/* Multi-select chips */
.multi{
  margin-top:8px;
  border:1px solid var(--line);
  border-radius: var(--r16);
  padding:12px;
  background: rgba(255,255,255,.92);
}
.multi__grid{display:flex; flex-wrap:wrap; gap:8px}
.chk{position:relative; display:inline-flex;}
.chk input{position:absolute; opacity:0; pointer-events:none;}
.chk span{
  display:inline-flex; align-items:center;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-size:13px;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
}
.chk span:hover{box-shadow: var(--shadow2)}
.chk input:checked + span{
  border-color: rgba(11,15,25,.22);
  background: rgba(11,15,25,.05);
}
.chk--danger input:checked + span{
  border-color: rgba(180,35,24,.22);
  background: rgba(180,35,24,.06);
  color: var(--danger);
}

/* Toast summary */
.toast{border:1px solid var(--line); background: rgba(11,15,25,.03); border-radius: var(--r16); padding:14px}
.toast__grid{display:grid; grid-template-columns: 1fr 1fr; gap:8px 12px; margin-top:10px; font-size:13px}
.toast__grid span{color:var(--muted)}
.toast__chips{margin-top:12px}
.toast__label{font-size:12px; color:var(--muted); margin-bottom:8px}
.chips{display:flex; flex-wrap:wrap; gap:8px}
.toast__msg{margin-top:12px}
.muted{color:var(--muted); font-size:13px}
.small{font-size:12px; color:var(--muted); margin-top:10px}

/* Side */
.side{display:grid; gap:14px}
.side__box{background:#fff; border:1px solid var(--line); border-radius: var(--r20); padding:18px; box-shadow: var(--shadow2)}
.side__box h3{margin:0 0 8px}
.side__box p{margin:0 0 12px; color:var(--muted); line-height:1.65}
.side__mini{margin-top:12px; color:var(--muted); font-size:13px}
.list{margin:0; padding-left:18px; color:var(--muted); line-height:1.75}

/* Contact */
.contact{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.contact__box{background:#fff; border:1px solid var(--line); border-radius: var(--r20); padding:18px; box-shadow: var(--shadow2)}
.contact__item{margin:0 0 10px}
.contact__social{display:flex; gap:12px; flex-wrap:wrap}
.contact__social a{padding:10px 12px; border:1px solid var(--line); border-radius:999px; background: rgba(255,255,255,.92)}
.contact__social a:hover{box-shadow: var(--shadow2)}

/* Footer */
.footer{border-top:1px solid var(--line); background:#fff; padding-top:34px}
.footer__inner{display:flex; justify-content:space-between; gap:24px; padding-bottom:22px}
.footer__brand{display:flex; gap:12px; align-items:center}
.footer__mark{width:44px;height:44px;border-radius:14px; border:1px solid var(--line); background: rgba(11,15,25,.04); display:grid; place-items:center; overflow:hidden}
.footer__logo{width:30px;height:30px; object-fit:contain}
.footer__fallback{font-family:"Space Grotesk", Inter, sans-serif; font-weight:700; letter-spacing:.06em}
.footer__name{font-weight:800}
.footer__desc{color:var(--muted); font-size:13px; margin-top:2px}
.footer__cols{display:grid; grid-template-columns:repeat(3, 1fr); gap:18px}
.footer__cols h4{margin:0 0 10px}
.footer__cols a, .footer__muted{display:block; color:var(--muted); font-size:13px; padding:6px 0}
.footer__cols a:hover{color:var(--accent)}
.footer__bottom{display:flex; align-items:center; justify-content:space-between; padding:16px 0 26px; color:var(--muted); font-size:13px}
.footer__bottom a{color:var(--accent)}

/* Responsive */
@media (max-width: 980px){
  .nav{display:none}
  .burger{display:inline-flex}
  .hero__inner{grid-template-columns:1fr; gap:14px}
  .grid3{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .booking{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .section__head{flex-direction:column; align-items:flex-start}
  .hero__title{font-size:44px}
  .footer__inner{flex-direction:column}
  .footer__cols{grid-template-columns:1fr}
  .toast__grid{grid-template-columns:1fr}
}

/* ===== Booking Accordion + Search PATCH ===== */
textarea{ resize:none; }

.acc{
  border:1px solid var(--line);
  border-radius: var(--r16);
  background: rgba(255,255,255,.92);
  overflow:hidden;
  margin-top:10px;
}
.acc + .acc{ margin-top:12px; }

.acc__btn{
  width:100%;
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
  padding:14px 14px;
  background:#fff;
  border:0;
  cursor:pointer;
  font-weight:700;
  font-size:14px;
}
.acc__btn:hover{ background: rgba(11,15,25,.03); }

.acc__hint{ font-weight:500; color: var(--muted); font-size:12px; }

.acc__icon{
  width:28px;height:28px;
  border-radius:10px;
  border:1px solid var(--line);
  display:grid; place-items:center;
  background: rgba(11,15,25,.03);
  flex:0 0 auto;
}
.acc__panel{
  display:none;
  padding:14px;
  border-top:1px solid var(--line);
  background: rgba(255,255,255,.85);
}
.acc.is-open .acc__panel{ display:block; }
.acc__search{ margin-bottom:10px; }
.acc__search input{ margin-top:0; }

.multi__empty{
  display:none;
  margin-top:10px;
  color: var(--muted);
  font-size:13px;
}
.multi.is-empty .multi__empty{ display:block; }