:root{
  --ink:#0e1116; --blue:#2e9be6; --blue-dk:#1c7fc4; --yellow:#ffd21f;
  --paper:#ffffff; --mute:#5b6573; --line:#e6e9ee; --soft:#f5f7fa;
  --maxw:1080px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;
}
a{color:var(--blue-dk);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* Header */
.site-head{position:sticky;top:0;z-index:50;background:var(--ink);color:#fff}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:64px;gap:16px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:800;letter-spacing:.2px}
.brand:hover{text-decoration:none}
.brand .mark{width:34px;height:34px;flex:0 0 34px}
.brand b{color:var(--yellow)}
.nav{display:flex;align-items:center;gap:20px}
.nav a{color:#dfe6ee;font-size:14px;font-weight:600}
.nav a:hover{color:#fff;text-decoration:none}
.btn{display:inline-block;background:var(--yellow);color:#1a1a1a;font-weight:800;
  padding:11px 18px;border-radius:8px;border:0;cursor:pointer;font-size:15px;line-height:1}
.btn:hover{background:#ffdc4d;text-decoration:none}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-dk)}
.nav .btn{padding:9px 14px}
@media(max-width:760px){.nav a:not(.btn){display:none}}

/* Hero */
.hero{background:linear-gradient(135deg,#0e1116 0%,#12233a 60%,#1c7fc4 140%);color:#fff;padding:64px 0 56px}
.hero h1{font-size:clamp(28px,5vw,46px);line-height:1.12;font-weight:800;letter-spacing:-.5px;max-width:780px}
.hero p.sub{font-size:clamp(16px,2.4vw,20px);color:#cfe0f0;margin-top:16px;max-width:640px}
.hero .cta{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}
.pill{display:inline-flex;gap:8px;align-items:center;background:rgba(255,255,255,.12);
  color:#eaf3fb;border:1px solid rgba(255,255,255,.18);padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600}
.hero .pills{margin-top:22px;display:flex;gap:8px;flex-wrap:wrap}

/* Breadcrumb */
.crumb{font-size:13px;color:var(--mute);padding:14px 0}
.crumb a{color:var(--mute)}
.crumb span{color:var(--ink);font-weight:600}

/* Sections */
section{padding:40px 0}
.section-sm{padding:26px 0}
h2{font-size:clamp(22px,3.4vw,30px);font-weight:800;letter-spacing:-.3px;margin-bottom:14px}
h3{font-size:18px;font-weight:700;margin-bottom:8px}
p{margin-bottom:14px}
.lead{font-size:18px;color:#2a2f37}
.muted{color:var(--mute)}
.soft{background:var(--soft)}

/* Cards / grids */
.grid{display:grid;gap:18px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
@media(max-width:820px){.g2,.g3{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px}
.card h3{color:var(--ink)}
.icon{width:40px;height:40px;border-radius:9px;background:#eaf4fd;color:var(--blue-dk);
  display:flex;align-items:center;justify-content:center;font-weight:800;margin-bottom:12px}

/* CTA band */
.band{background:var(--blue);color:#fff;border-radius:16px;padding:30px;display:flex;
  align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.band h2{margin:0;color:#fff}
.band p{margin:6px 0 0;color:#eaf3fb}

/* FAQ */
.faq details{border-bottom:1px solid var(--line);padding:16px 0}
.faq summary{font-weight:700;cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+";color:var(--blue-dk);font-weight:800;margin-right:10px}
.faq details[open] summary::before{content:"–"}
.faq p{margin:10px 0 0;color:#39414c}
.faq ul{margin:10px 0 0 20px;color:#39414c}
.faq li{margin:4px 0}

/* Legal / Terms page */
.legal{max-width:780px}
.legal h2{margin-top:30px}
.legal h3{margin-top:20px;font-size:17px}
.legal ul{margin:8px 0 8px 22px}
.legal li{margin:6px 0;color:#39414c}
.legal p{color:#39414c}

/* Booking widget */
.booking{margin-top:16px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:8px;overflow:hidden}
.booking iframe{display:block;width:100%;min-height:800px;border:0;border-radius:8px}

/* Areas list */
.areas{display:flex;flex-wrap:wrap;gap:8px}
.areas a{background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:13px;color:var(--ink)}
.areas a:hover{border-color:var(--blue);color:var(--blue-dk);text-decoration:none}

/* Info row */
.inforow{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:820px){.inforow{grid-template-columns:1fr}}

/* Footer */
.site-foot{background:var(--ink);color:#c4ccd6;padding:40px 0 26px;margin-top:30px;font-size:14px}
.site-foot a{color:#9fc6e8}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr}}
.site-foot h4{color:#fff;font-size:14px;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}
.credit{border-top:1px solid #232a33;margin-top:26px;padding-top:16px;display:flex;
  justify-content:space-between;gap:12px;flex-wrap:wrap;color:#8b95a1}
.credit a{color:var(--yellow);font-weight:600}
