:root{
  --ink:#0a1f2e;--muted:#5f7789;--line:#e6eff5;--bg:#f3fafc;
  --brand:#0b8ec9;--brand2:#25cbdc;--deep:#052235;--night:#03151f;--sun:#ffbf47;--coral:#ff7d5c;
  --grad:linear-gradient(120deg,#0b8ec9,#25cbdc);--ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,sans-serif;color:var(--ink);line-height:1.55;background:#fff;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.serif{font-family:'Fraunces',Georgia,serif;font-weight:600}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
a{color:inherit;text-decoration:none}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15px;border-radius:999px;padding:14px 26px;cursor:pointer;border:none;transition:transform .18s var(--ease),box-shadow .18s,filter .18s}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 14px 30px -10px rgba(11,142,201,.6)}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.06);box-shadow:0 20px 40px -12px rgba(11,142,201,.7)}
.btn-glass{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.3);backdrop-filter:blur(6px)}
.btn-glass:hover{background:rgba(255,255,255,.24)}
.btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:#bcdcec;transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--brand)}.btn-white:hover{transform:translateY(-2px)}
.btn-lg{padding:16px 32px;font-size:16.5px}
nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,box-shadow .3s}
nav.solid{background:rgba(255,255,255,.9);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo{display:flex;align-items:center;gap:11px;font-weight:800;font-size:22px;color:#fff;transition:color .3s}
nav.solid .logo{color:var(--ink)}
.logo .mark{width:40px;height:40px;border-radius:13px;background:var(--grad);display:grid;place-items:center;font-size:21px;box-shadow:0 8px 18px -6px rgba(11,142,201,.6)}
.navlinks{display:flex;gap:28px;font-size:14.5px;font-weight:600;color:rgba(255,255,255,.85)}
nav.solid .navlinks{color:var(--muted)}
.navlinks a{position:relative}.navlinks a.on{color:#fff}nav.solid .navlinks a.on{color:var(--brand)}
.navlinks a:hover{color:#fff}nav.solid .navlinks a:hover{color:var(--brand)}
.navlinks a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:currentColor;transform:scaleX(0);transition:transform .2s var(--ease);transform-origin:left}
.navlinks a:hover::after,.navlinks a.on::after{transform:scaleX(1)}
h1{font-size:clamp(44px,6vw,78px);line-height:1;letter-spacing:-.03em;font-weight:700}
h2{font-size:clamp(32px,4vw,52px);line-height:1.04;letter-spacing:-.025em;font-weight:700}
.lede{font-size:19px;color:var(--muted)}
.pill{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:700;color:#fff;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.28);padding:8px 16px;border-radius:999px;margin-bottom:26px;backdrop-filter:blur(6px)}
.stars{color:#ffbf47;letter-spacing:2px}
section{padding:104px 0}
.sh{max-width:660px;margin:0 auto 56px;text-align:center}
.sh .k{font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);margin-bottom:16px}
.sh p{font-size:18px;color:var(--muted);margin-top:16px}
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);animation:kb 18s var(--ease) forwards}
@keyframes kb{to{transform:scale(1)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(3,21,31,.9) 0%,rgba(5,34,53,.7) 42%,rgba(11,142,201,.32) 100%)}
.hero-bg::before{content:"";position:absolute;inset:0;z-index:1;background:radial-gradient(120% 80% at 100% 100%,rgba(37,203,220,.35),transparent 55%)}
.hero .wrap{position:relative;z-index:2;padding-top:90px;padding-bottom:60px;width:100%}
.hgrid{display:grid;grid-template-columns:1.15fr .85fr;gap:50px;align-items:center}
h1.hero-h{font-size:clamp(44px,6.4vw,82px);line-height:.98;margin-bottom:22px;text-shadow:0 4px 30px rgba(0,0,0,.25)}
h1.hero-h em{font-style:normal;background:linear-gradient(120deg,#ffe1a8,#ffbf47);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hlede{font-size:clamp(17px,1.5vw,20px);color:rgba(255,255,255,.9);max-width:520px;margin-bottom:34px}
.hcta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.hstat{display:flex;gap:30px}.hstat .s b{font-size:30px;font-weight:800;display:block;line-height:1}.hstat .s span{font-size:12.5px;color:rgba(255,255,255,.75)}
.bookw{background:#fff;border:1px solid var(--line);border-radius:24px;padding:26px;box-shadow:0 34px 74px -26px rgba(5,20,40,.55);color:var(--ink)}
.bookw h3{font-size:20px;margin-bottom:4px;color:var(--ink)}
.bookw .sub{font-size:13px;color:var(--muted);margin-bottom:18px}
.bookw .opt{display:flex;align-items:center;gap:12px;background:var(--bg);border:1px solid var(--line);border-radius:15px;padding:14px 16px;margin-bottom:10px;transition:background .15s,transform .15s,border-color .15s}
.bookw .opt:hover{background:#fff;border-color:var(--brand);transform:translateX(3px)}
.bookw .opt b{font-size:15px;display:block;color:var(--ink)}.bookw .opt span{font-size:11.5px;color:var(--muted)}
.bookw .opt .pr{margin-left:auto;font-weight:800;color:var(--brand);font-size:16px}
.bookw .btn{width:100%;justify-content:center;margin-top:8px}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.7);font-size:12px;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px;animation:bob 2s ease-in-out infinite}
@keyframes bob{50%{transform:translate(-50%,6px)}}
.phero{position:relative;background:linear-gradient(120deg,#052235 10%,#0b8ec9 100%);color:#fff;padding:160px 0 90px;text-align:center;overflow:hidden}
.phero::before{content:"";position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(37,203,220,.3),transparent 65%);top:-260px;right:-180px}
.phero .wrap{position:relative;z-index:2}
.phero h1{font-size:clamp(38px,5vw,64px)}
.phero p{font-size:19px;color:rgba(255,255,255,.9);max-width:580px;margin:16px auto 0}
.marq{background:var(--night);color:#bfe3f0;overflow:hidden;padding:16px 0;white-space:nowrap}
.marq .track{display:inline-flex;gap:52px;animation:scrollx 26s linear infinite;font-size:14px;font-weight:600}
.marq b{color:#fff}.marq span{opacity:.5}
@keyframes scrollx{to{transform:translateX(-50%)}}
.rv{opacity:0;transform:translateY(34px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}
.stats{background:linear-gradient(180deg,#fff,var(--bg))}
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{text-align:center;padding:20px}
.stat b{font-size:clamp(40px,4.5vw,58px);font-weight:800;letter-spacing:-.03em;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1;display:block}
.stat span{font-size:14px;color:var(--muted);font-weight:600;margin-top:8px;display:block}
.pg{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pc{border-radius:24px;overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:0 4px 20px -14px rgba(5,34,53,.4);transition:transform .3s var(--ease),box-shadow .3s;display:flex;flex-direction:column}
.pc:hover{transform:translateY(-8px);box-shadow:0 40px 60px -30px rgba(5,34,53,.4)}
.pc .ph{aspect-ratio:4/3;overflow:hidden;position:relative}
.pc .ph img{width:100%;height:100%;object-fit:cover;object-position:center 34%;transition:transform .6s var(--ease)}
.pc:hover .ph img{transform:scale(1.08)}
.pc .age{position:absolute;top:14px;left:14px;z-index:2;background:rgba(255,255,255,.92);color:var(--brand);font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:6px 12px;border-radius:999px;backdrop-filter:blur(4px)}
.pc .body{padding:26px;flex:1;display:flex;flex-direction:column}
.pc h3{font-size:24px;margin-bottom:9px}.pc p{font-size:15px;color:var(--muted);flex:1}
.pc .foot{display:flex;align-items:center;justify-content:space-between;margin-top:20px}
.pc .price{font-weight:800;font-size:24px}.pc .price small{font-size:13px;color:var(--muted);font-weight:600}
.pc .go{width:44px;height:44px;border-radius:50%;background:var(--bg);display:grid;place-items:center;color:var(--brand);font-size:18px;transition:background .2s,transform .2s}
.pc:hover .go{background:var(--grad);color:#fff}
.dot{width:34px;height:34px;border-radius:11px;background:var(--grad);flex:0 0 auto;box-shadow:0 6px 14px -7px rgba(11,142,201,.6)}
.bookw .dot{width:30px;height:30px;border-radius:9px;box-shadow:none}
.marq .mi{display:inline-flex;align-items:center;gap:10px}
.marq .mi svg{color:var(--brand2)}
.pill svg{flex:0 0 auto}
.loc .row svg{flex:0 0 auto;margin-top:2px}
.why{background:var(--deep);color:#fff;position:relative;overflow:hidden}
.why::before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(37,203,220,.22),transparent 70%);top:-200px;right:-150px}
.wgrid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative}
.wleft h2{color:#fff;margin-bottom:20px}.wleft p{color:#a9c9db;font-size:17px}
.wlist{display:grid;gap:18px}
.wi{display:flex;gap:16px;align-items:flex-start;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:20px;transition:transform .2s,background .2s}
.wi:hover{transform:translateX(5px);background:rgba(255,255,255,.09)}
.wi .ic{width:48px;height:48px;flex:0 0 auto;border-radius:13px;background:var(--grad);display:grid;place-items:center;font-size:22px}
.wi h4{font-size:18px;margin-bottom:4px}.wi p{font-size:14px;color:#a9c9db}
.ig{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.icard{border-radius:24px;overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:0 4px 20px -14px rgba(5,34,53,.4);transition:transform .3s var(--ease),box-shadow .3s}
.icard:hover{transform:translateY(-8px);box-shadow:0 40px 60px -30px rgba(5,34,53,.4)}
.icard .av{aspect-ratio:1/1;overflow:hidden}.icard .av img{width:100%;height:100%;object-fit:cover;object-position:center 30%;transition:transform .6s var(--ease)}
.icard:hover .av img{transform:scale(1.06)}
.icard .b{padding:24px}
.icard h4{font-size:22px}.icard .role{font-size:13px;color:var(--brand);font-weight:700;margin:4px 0 10px}.icard p{font-size:14px;color:var(--muted)}
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gal .gi{position:relative;border-radius:18px;overflow:hidden;cursor:pointer;aspect-ratio:1/1}
.gal .gi img{width:100%;height:100%;object-fit:cover;object-position:center 36%;transition:transform .6s var(--ease)}
.gal .gi:hover img{transform:scale(1.07)}
.gal .gi::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(3,21,31,.4));opacity:0;transition:opacity .3s}
.gal .gi:hover::after{opacity:1}
.rev{background:linear-gradient(140deg,var(--brand),#0a6fa0);color:#fff;position:relative;overflow:hidden}
.rev::before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);bottom:-200px;left:-100px}
.rev h2{color:#fff}.rev .sh .k{color:#c9f2f8}.rev .sh p{color:#dbf5f9}
.rg{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
.rc{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:30px;backdrop-filter:blur(10px)}
.rc .stars{margin-bottom:14px;display:block}.rc p{font-size:16px;margin-bottom:18px;line-height:1.5}.rc .who{font-size:13.5px;color:rgba(255,255,255,.8);font-weight:600}
.ratebig{text-align:center;margin-bottom:44px;position:relative}
.ratebig .n{font-size:72px;font-weight:800;line-height:1;color:#fff}.ratebig .s{color:#ffbf47;font-size:28px;letter-spacing:4px}
.loc{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border:1px solid var(--line);border-radius:24px;overflow:hidden;background:#fff;box-shadow:0 30px 60px -34px rgba(5,34,53,.3)}
.loc .lp{overflow:hidden}.loc .lp img{width:100%;height:100%;object-fit:cover;min-height:340px}
.loc .lb{padding:44px}
.loc h3{font-size:30px;margin-bottom:14px}
.loc .row{display:flex;gap:10px;font-size:16px;color:var(--muted);margin-bottom:12px}.loc .row b{color:var(--ink)}
.final{position:relative;color:#fff;text-align:center;overflow:hidden}
.final-bg{position:absolute;inset:0;z-index:0}.final-bg img{width:100%;height:100%;object-fit:cover}
.final-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,34,53,.86),rgba(3,21,31,.9))}
.final .wrap{position:relative;z-index:2}.final h2{color:#fff;margin-bottom:16px}.final p{color:#c9e3ef;font-size:19px;max-width:560px;margin:0 auto 30px}
.bookwrap{max-width:720px;margin:0 auto}
.steps{display:flex;gap:8px;margin-bottom:26px}
.steps .st{flex:1;text-align:center;font-size:12.5px;font-weight:700;color:var(--muted);padding-bottom:12px;border-bottom:3px solid var(--line);transition:color .2s,border-color .2s}
.steps .st.on{color:var(--brand);border-color:var(--brand)}
.bcard{border:1px solid var(--line);border-radius:24px;padding:34px;background:#fff;box-shadow:0 30px 60px -34px rgba(5,34,53,.3)}
.opt{display:flex;align-items:center;gap:14px;border:1.5px solid var(--line);border-radius:16px;padding:18px;margin-bottom:12px;cursor:pointer;transition:border-color .12s,background .12s,transform .12s}
.opt:hover{border-color:#b6dced;transform:translateX(3px)}.opt.sel{border-color:var(--brand);background:#f0fafd}
.opt .em{font-size:28px}.opt b{font-size:17px;display:block;margin-bottom:3px}.opt span{font-size:13px;color:var(--muted)}.opt .pr{margin-left:auto;font-weight:800;color:var(--brand);font-size:18px}
.slots{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.slot{text-align:center;border:1.5px solid var(--line);border-radius:12px;padding:14px 4px;font-size:14px;font-weight:600;cursor:pointer;transition:.12s}
.slot:hover{border-color:#b6dced}.slot.sel{background:var(--brand);color:#fff;border-color:var(--brand)}
.fld{margin-bottom:16px}.fld label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.fld input{width:100%;font:inherit;font-size:15px;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;outline:none}.fld input:focus{border-color:var(--brand)}
.bnav{display:flex;justify-content:space-between;margin-top:24px}
.summary{background:var(--bg);border-radius:16px;padding:22px;margin-bottom:20px}
.summary .r{display:flex;justify-content:space-between;font-size:15px;padding:7px 0}.summary .r.tot{border-top:1px solid var(--line);margin-top:6px;padding-top:13px;font-weight:800;font-size:19px}
.booked{display:none;text-align:center;padding:20px}.booked .big{font-size:56px}
footer{background:var(--night);color:#7fa8bf;padding:56px 0 40px}
.foot{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:30px;margin-bottom:34px}
.foot .logo{color:#fff;font-size:20px;margin-bottom:14px}.foot h5{color:#fff;font-size:14px;margin-bottom:14px}
.foot a{display:block;color:#7fa8bf;font-size:14px;padding:4px 0;transition:color .15s}.foot a:hover{color:#fff}.foot p{font-size:14px;line-height:1.7}
.footbot{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.demo-tag{position:fixed;bottom:16px;left:16px;z-index:99;background:#0a1f2e;color:#fff;font-size:11px;font-weight:700;padding:7px 13px;border-radius:9px;opacity:.9;box-shadow:0 6px 16px -6px rgba(0,0,0,.5)}
@media(max-width:920px){
  .hgrid,.wgrid,.pg,.sgrid,.rg,.ig,.loc{grid-template-columns:1fr}
  .sgrid{grid-template-columns:1fr 1fr}.gal{grid-template-columns:repeat(2,1fr)}
  .navlinks{display:none}.hero{min-height:auto;padding:40px 0}
  .foot{grid-template-columns:1fr 1fr}.slots{grid-template-columns:repeat(2,1fr)}
}
