:root{
  --bg:#061319;
  --bg2:#0b1e27;
  --bg3:#13313e;
  --paper:#f3efe6;
  --ink:#0a1d27;
  --line:rgba(243,239,230,.12);
  --line-dark:rgba(10,29,39,.14);
  --muted:#9aaab2;
  --muted-dark:#5a6970;
  --teal:#29abe2;
  --teal-2:#5dc2ec;
  --sun:#29abe2;
  --sun-2:#5dc2ec;
  --coral:#e07555;
  --container:1280px;
  --pad:32px;
  --f-disp:"Barlow Condensed",Impact,sans-serif;
  --f-body:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--f-body);background:var(--bg);color:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;border:0;background:0;color:inherit;cursor:pointer}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad)}

/* ---------- TYPE ---------- */
.eyebrow{font-family:var(--f-body);font-size:11px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--sun);display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--sun)}
h1,h2,h3,h4{font-family:var(--f-disp);font-weight:800;text-transform:uppercase;line-height:.92;letter-spacing:.005em}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 26px;font-family:var(--f-body);font-weight:700;font-size:13px;letter-spacing:.18em;text-transform:uppercase;border:1px solid transparent;transition:transform .2s,background .2s,color .2s,border-color .2s;cursor:pointer;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--sun);color:var(--ink)}
.btn-primary:hover{background:var(--sun-2)}
.btn-teal{background:var(--teal);color:#fff}
.btn-teal:hover{background:var(--teal-2)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:#fff}
.btn-paper{background:var(--paper);color:var(--ink)}
.btn-paper:hover{background:#fff}
.btn-arrow::after{content:"→";font-size:16px;letter-spacing:0;transition:transform .2s}
.btn-arrow:hover::after{transform:translateX(4px)}

/* ---------- HEADER ---------- */
.hdr{position:fixed;inset:0 0 auto 0;z-index:50;padding:18px 0;transition:background .3s,padding .3s,border-color .3s;border-bottom:1px solid transparent}
.hdr.scrolled{background:rgba(6,19,25,.94);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:12px 0;border-bottom-color:var(--line)}
.hdr-row{display:flex;align-items:center;justify-content:space-between;gap:32px}
.brand{display:flex;align-items:center;gap:14px;color:#fff}
.brand-logo{height:54px;width:auto;display:block;transition:height .3s}
.hdr.scrolled .brand-logo{height:44px}
.brand-mark{width:48px;height:48px;display:grid;place-items:center;background:var(--teal);position:relative;flex-shrink:0;transition:height .3s,width .3s}
.hdr.scrolled .brand-mark{width:42px;height:42px}
.brand-mark::before,.brand-mark::after{content:"";position:absolute;left:6px;right:6px;height:1.5px;background:#fff;opacity:.85}
.brand-mark::before{top:14px;border-radius:50%;height:4px;background:none;border-top:1.5px solid #fff;border-radius:50% 50% 0 0/100% 100% 0 0}
.brand-mark::after{bottom:14px;border-radius:50%;height:4px;background:none;border-top:1.5px solid #fff;border-radius:50% 50% 0 0/100% 100% 0 0}
.brand-mark svg{width:26px;height:26px;color:#fff;position:relative;z-index:1}
.brand-words{display:flex;flex-direction:column;line-height:1}
.brand-words .a{font-family:var(--f-disp);font-weight:800;font-size:20px;letter-spacing:.04em;color:#fff}
.brand-words .b{font-size:9px;font-weight:600;letter-spacing:.32em;color:var(--sun);margin-top:5px;text-transform:uppercase}
nav.nav{display:flex;align-items:center;gap:30px}
.nav a{font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.85);position:relative;padding:6px 0;transition:color .15s}
.nav a:hover{color:#fff}
.nav a:not(.btn)::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--sun);transform:scaleX(0);transform-origin:left;transition:transform .25s}
.nav a:not(.btn):hover::after{transform:scaleX(1)}
.nav .btn{margin-left:6px;padding:11px 18px;font-size:11px}
.burger{display:none;width:44px;height:44px;border:1px solid rgba(255,255,255,.4);background:rgba(0,0,0,.4);place-items:center}
.burger span{display:block;width:22px;height:1.5px;background:#fff;margin:4px auto}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;padding:140px 0 70px}
.hero-img{position:absolute;inset:0;background-image:url('../images/photos/home-header-min.webp');background-size:cover;background-position:center;z-index:0;animation:slowzoom 18s ease-in-out infinite alternate}
@keyframes slowzoom{0%{transform:scale(1)}100%{transform:scale(1.06)}}
.hero .ovl{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(6,19,25,.55) 0%,rgba(6,19,25,.05) 28%,rgba(6,19,25,.18) 55%,rgba(6,19,25,.92) 100%),linear-gradient(90deg,rgba(6,19,25,.5),rgba(6,19,25,0) 60%)}
.hero-content{position:relative;z-index:2;width:100%}
.hero h1{font-family:var(--f-disp);font-weight:900;font-size:clamp(64px,11vw,200px);line-height:.86;color:#fff;text-transform:uppercase;letter-spacing:-.005em;max-width:1200px;margin:24px 0 24px;text-shadow:0 4px 30px rgba(0,0,0,.45)}
.hero h1 .accent{color:var(--sun);display:block;font-style:italic}
.hero h1 .small{display:block;font-size:.42em;font-weight:600;letter-spacing:.32em;color:var(--paper);text-shadow:none;margin-top:18px;text-transform:uppercase}
.hero p.sub{font-size:19px;color:rgba(255,255,255,.92);max-width:640px;margin-bottom:36px;line-height:1.55}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:56px}
.hero .tagline{display:inline-flex;align-items:center;gap:12px;padding:8px 16px;background:rgba(6,19,25,.5);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.25);font-family:var(--f-body);font-size:11px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#fff}
.hero .tagline .dot{width:7px;height:7px;border-radius:50%;background:var(--sun);box-shadow:0 0 0 4px rgba(41,171,226,.25)}
.trustbar{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid rgba(255,255,255,.2);padding-top:22px;max-width:1080px}
.trustbar > div{padding:0 28px 0 0;display:flex;align-items:flex-start;gap:14px}
.trustbar svg{width:22px;height:22px;color:var(--sun);flex-shrink:0;margin-top:2px}
.trustbar .l{font-size:9px;font-weight:600;letter-spacing:.22em;color:var(--teal-2);text-transform:uppercase;margin-bottom:5px}
.trustbar .v{font-size:13px;color:#fff;font-weight:500;line-height:1.4}

/* ---------- TICKER ---------- */
.ticker{padding:18px 0;background:var(--bg3);color:var(--sun);overflow:hidden;position:relative;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ticker-track{display:flex;gap:60px;animation:scroll 38s linear infinite;white-space:nowrap;will-change:transform}
.ticker-track > span{font-family:var(--f-disp);font-weight:800;font-size:22px;letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;gap:60px;flex-shrink:0;color:#fff}
.ticker-track > span::after{content:"◆";color:var(--sun);font-size:14px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- ABOUT ---------- */
.about{display:grid;grid-template-columns:1fr 1fr;min-height:640px}
.about .imgcol{background-size:cover;background-position:center;position:relative}
.about .imgcol::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(0,0,0,.15),rgba(0,0,0,0) 60%)}
.about .txtcol{padding:96px 72px;display:flex;flex-direction:column;justify-content:center;background:var(--bg)}
.about h2{font-size:clamp(44px,6vw,88px);margin:24px 0 24px}
.about h2 em{color:var(--sun);font-style:normal;display:block}
.about p{font-size:18px;color:var(--muted);line-height:1.65;margin-bottom:28px;max-width:540px}
.about p strong{color:#fff;font-weight:600}
.about ul{list-style:none;display:flex;flex-direction:column;margin-bottom:36px;max-width:520px}
.about ul li{display:flex;align-items:flex-start;gap:14px;font-size:15px;padding:14px 0;border-bottom:1px solid var(--line);color:var(--paper)}
.about ul li svg{width:20px;height:20px;color:var(--sun);flex-shrink:0;margin-top:1px}

/* ---------- SECTION shells ---------- */
.sec{padding:120px 0}
.sec-paper{background:var(--paper);color:var(--ink)}
.sec-bg2{background:var(--bg2)}
.sec-head{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:end;margin-bottom:64px}
.sec-head h2{font-size:clamp(48px,7vw,108px);line-height:.9}
.sec-head .eyebrow{margin-bottom:22px}
.sec-sub{font-size:18px;line-height:1.6;max-width:560px;color:var(--muted)}
.sec-paper .sec-sub{color:#3a4d57}

/* ---------- CHARTERS ---------- */
.charters{padding:130px 0;background:var(--bg);position:relative}
.charters::before{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:var(--line)}
.charter-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.charter{background:var(--bg2);border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;position:relative;transition:transform .25s,border-color .25s}
.charter:hover{transform:translateY(-4px);border-color:var(--sun)}
.charter .img{aspect-ratio:16/10;background-size:cover;background-position:center;position:relative}
.charter .img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 50%,rgba(0,0,0,.55))}
.charter .img-tag{position:absolute;top:18px;left:18px;z-index:2;display:inline-flex;align-items:center;gap:8px;padding:7px 12px;background:rgba(6,19,25,.85);backdrop-filter:blur(6px);font-size:10px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#fff;border:1px solid rgba(255,255,255,.25)}
.charter .img-tag.popular{background:var(--sun);color:var(--ink);border-color:var(--sun)}
.charter .img-tag .pip{width:6px;height:6px;border-radius:50%;background:currentColor}
.charter .price{position:absolute;bottom:18px;right:18px;z-index:2;background:rgba(6,19,25,.9);backdrop-filter:blur(6px);padding:10px 16px;border:1px solid rgba(255,255,255,.18);text-align:right}
.charter .price .num{font-family:var(--f-disp);font-weight:800;font-size:34px;color:var(--sun);line-height:.9}
.charter .price .lbl{font-size:9px;font-weight:600;letter-spacing:.24em;color:var(--paper);text-transform:uppercase;margin-top:4px}
.charter .body{padding:36px 32px 32px;display:flex;flex-direction:column;flex:1}
.charter .num{font-size:11px;font-weight:600;letter-spacing:.3em;color:var(--sun);text-transform:uppercase;margin-bottom:10px}
.charter h3{font-family:var(--f-disp);font-weight:800;font-size:clamp(36px,3.6vw,52px);color:#fff;text-transform:uppercase;margin-bottom:8px;line-height:.95}
.charter h3 em{color:var(--teal-2);font-style:normal}
.charter .descriptor{font-size:14px;color:var(--sun);font-weight:500;margin-bottom:20px;letter-spacing:.04em}
.charter p.blurb{font-size:15px;color:var(--muted);line-height:1.6;margin-bottom:24px;flex:1}
.spec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line);margin-bottom:24px}
.spec{padding:14px 0;border-bottom:1px solid var(--line)}
.spec:nth-child(odd){padding-right:18px;border-right:1px solid var(--line);padding-left:0}
.spec:nth-child(even){padding-left:18px}
.spec .l{font-size:9px;font-weight:600;letter-spacing:.24em;color:var(--teal-2);text-transform:uppercase;margin-bottom:5px}
.spec .v{font-size:14px;color:#fff;font-weight:500}

/* ---------- DETAIL TRIO ---------- */
.detail-trio{margin-top:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;border-top:1px solid var(--line);padding-top:48px}
.dt{display:flex;flex-direction:column;gap:14px;padding-right:24px}
.dt .ic{width:48px;height:48px;display:grid;place-items:center;background:var(--teal);color:#fff}
.dt .ic svg{width:24px;height:24px}
.dt h4{font-family:var(--f-disp);font-weight:700;font-size:22px;color:#fff;letter-spacing:.04em}
.dt p, .dt ul{font-size:14px;color:var(--muted);line-height:1.65}
.dt ul{list-style:none}
.dt ul li{padding:5px 0;border-bottom:1px dashed var(--line)}
.dt ul li:last-child{border-bottom:0}
.dt .price-line{font-family:var(--f-disp);font-weight:800;font-size:32px;color:var(--sun);line-height:1}
.dt .price-line small{font-size:12px;font-family:var(--f-body);font-weight:500;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;margin-left:6px}

/* ---------- SEA-DOO BLOCK ---------- */
.seadoo{display:grid;grid-template-columns:1fr 1fr;min-height:600px;background:var(--bg)}
.seadoo .imgcol{background-size:cover;background-position:center;position:relative}
.seadoo .imgcol::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(0,0,0,0) 0%,rgba(0,0,0,.4) 100%)}
.seadoo .imgcol .price-stamp{position:absolute;top:32px;right:32px;background:var(--sun);color:var(--ink);padding:18px 22px;text-align:right;z-index:2}
.seadoo .imgcol .price-stamp .num{font-family:var(--f-disp);font-weight:900;font-size:48px;line-height:.9}
.seadoo .imgcol .price-stamp .lbl{font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;margin-top:4px}
.seadoo .txtcol{padding:96px 72px;display:flex;flex-direction:column;justify-content:center}
.seadoo h2{font-size:clamp(44px,6vw,88px);margin:24px 0 24px}
.seadoo h2 em{color:var(--sun);font-style:normal;display:block}
.seadoo p{font-size:17px;color:var(--muted);line-height:1.65;margin-bottom:28px;max-width:540px}
.seadoo p strong{color:#fff;font-weight:600}

/* ---------- BIG CTA ---------- */
.bigcta{position:relative;min-height:560px;display:flex;align-items:center;overflow:hidden}
.bigcta .bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;filter:contrast(1.05) saturate(.92)}
.bigcta .ovl{position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(42,141,163,.35) 0%,transparent 60%),linear-gradient(180deg,rgba(0,0,0,.4) 0%,rgba(0,0,0,.85) 100%);z-index:1}
.bigcta-c{position:relative;z-index:2;width:100%;padding:96px 0;text-align:center}
.bigcta h2{font-size:clamp(56px,9vw,160px);color:#fff;line-height:.86;margin-bottom:24px}
.bigcta h2 em{color:var(--sun);font-style:italic}
.bigcta p{font-size:18px;color:rgba(255,255,255,.85);max-width:640px;margin:0 auto 36px;line-height:1.6}
.bigcta .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- FIND US ---------- */
.find{display:grid;grid-template-columns:1fr 1fr;min-height:600px}
.find .info{padding:96px 72px;display:flex;flex-direction:column;justify-content:center;background:var(--bg)}
.find .info h2{font-size:clamp(44px,6vw,88px);margin-bottom:32px}
.find-blocks{display:flex;flex-direction:column;margin-bottom:28px}
.find-blocks div{border-top:1px solid var(--line);padding:18px 0}
.find-blocks div:last-child{border-bottom:1px solid var(--line)}
.find-blocks .lbl{font-size:10px;font-weight:600;letter-spacing:.28em;color:var(--sun);text-transform:uppercase;margin-bottom:6px}
.find-blocks .val{font-size:17px;color:#fff;line-height:1.45}
.find-blocks .val a:hover{color:var(--sun)}
.find-fact{padding:16px 18px;font-size:13px;font-weight:500;color:var(--paper);border-left:3px solid var(--teal);background:rgba(42,141,163,.12);margin:8px 0 28px;line-height:1.5}
.find .cta-row{display:flex;gap:12px;flex-wrap:wrap}
.find .imgcol{background-size:cover;background-position:center;position:relative}
.find .imgcol::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(0,0,0,0) 0%,rgba(0,0,0,.4) 100%)}

/* ---------- REVIEWS ---------- */
.reviews{padding:130px 0;background:var(--bg)}
.rv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rv{background:var(--bg2);padding:36px 32px;border:1px solid var(--line);display:flex;flex-direction:column}
.rv .stars{display:flex;gap:4px;margin-bottom:18px}
.rv .stars svg{width:16px;height:16px;color:var(--sun);fill:currentColor}
.rv .qm{font-family:var(--f-disp);font-size:80px;line-height:.5;color:var(--teal);opacity:.7;margin-bottom:8px}
.rv .q{font-family:var(--f-disp);font-weight:600;font-size:22px;line-height:1.3;color:#fff;margin-bottom:24px;flex:1;text-transform:none;letter-spacing:0}
.rv .auth{display:flex;align-items:center;gap:12px;padding-top:18px;border-top:1px solid var(--line)}
.rv .av{width:40px;height:40px;border-radius:50%;background:var(--teal);display:grid;place-items:center;font-family:var(--f-disp);font-weight:800;font-size:18px;color:#fff}
.rv .nm{font-size:14px;font-weight:600;color:#fff}
.rv .tg{font-size:9px;font-weight:600;letter-spacing:.24em;color:var(--sun);text-transform:uppercase;margin-top:3px}

/* ---------- SPONSORS ---------- */
.sponsors{padding:90px 0;background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sponsors h3{font-family:var(--f-disp);font-weight:700;text-align:center;font-size:26px;color:#fff;letter-spacing:.04em;margin-bottom:8px}
.sponsors .sub{text-align:center;font-size:11px;font-weight:600;letter-spacing:.28em;color:var(--sun);text-transform:uppercase;margin-bottom:48px}
.sp-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0;align-items:center;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.sp{display:grid;place-items:center;padding:24px 16px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-height:130px;transition:background .2s}
.sp .sp-card{width:100%;height:100%;min-height:84px;background:#fff;display:grid;place-items:center;padding:18px 16px;transition:transform .2s,box-shadow .2s}
.sp:hover .sp-card{transform:scale(1.03);box-shadow:0 12px 32px rgba(0,0,0,.4)}
.sp img{max-height:54px;max-width:160px;width:auto;object-fit:contain}

/* ---------- FOOTER ---------- */
footer.ft{padding:64px 0 28px;background:#040d12;border-top:1px solid var(--line)}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.ft h5{font-size:10px;font-weight:600;letter-spacing:.28em;color:var(--sun);text-transform:uppercase;margin-bottom:18px}
.ft ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.ft ul a{font-size:14px;color:var(--muted);transition:color .15s}
.ft ul a:hover{color:#fff}
.ft .ft-brand{display:flex;align-items:center;gap:14px;color:#fff;margin-bottom:20px}
.ft p.about-blurb{color:var(--muted);font-size:14px;max-width:380px;line-height:1.65}
.ft p.about-blurb strong{color:#fff;font-weight:600}
.ft-tag{font-family:var(--f-disp);font-weight:800;font-size:24px;color:#fff;letter-spacing:.04em;margin-top:24px;text-transform:uppercase}
.ft-tag em{color:var(--sun);font-style:normal}
.ft-social{display:flex;gap:12px;margin-top:22px}
.ft-social a{width:38px;height:38px;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:color .15s,border-color .15s}
.ft-social a:hover{color:#fff;border-color:var(--sun)}
.ft-social svg{width:16px;height:16px}
.ft-bot{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--line);font-size:11px;font-weight:500;letter-spacing:.18em;color:var(--muted-dark);text-transform:uppercase}

/* ---------- MOBILE ---------- */
.mob{position:fixed;inset:0;z-index:60;background:#040d12;display:flex;flex-direction:column;padding:100px 32px 40px;opacity:0;pointer-events:none;transition:opacity .25s}
.mob.open{opacity:1;pointer-events:auto}
.mob a{font-family:var(--f-disp);font-weight:800;font-size:42px;line-height:1;text-transform:uppercase;color:#fff;padding:18px 0;border-bottom:1px solid var(--line);letter-spacing:.02em}
.mob .btn{margin-top:32px;align-self:stretch;justify-content:center}
.mob-close{position:absolute;top:24px;right:24px;width:44px;height:44px;display:grid;place-items:center;color:#fff}

/* ---------- RESPONSIVE ---------- */
@media (max-width:1024px){
  .nav{gap:22px}
  .nav a:not(.btn){font-size:11px}
  .sec-head{grid-template-columns:1fr;gap:24px}
  .about,.find,.seadoo{grid-template-columns:1fr}
  .about .imgcol,.find .imgcol,.seadoo .imgcol{min-height:420px}
  .about .txtcol,.find .info,.seadoo .txtcol{padding:72px 40px}
  .charter-grid{grid-template-columns:1fr}
  .rv-grid{grid-template-columns:1fr 1fr}
  .rv-grid > :last-child{grid-column:span 2}
  .detail-trio{grid-template-columns:1fr;gap:32px}
  .sp-grid{grid-template-columns:repeat(3,1fr)}
  .ft-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  :root{--pad:20px}
  .sec,.charters,.reviews,.sponsors{padding:70px 0}
  nav.nav{display:none}
  .burger{display:grid}
  .hero{padding:130px 0 80px}
  .trustbar{grid-template-columns:1fr 1fr;gap:16px;padding-top:18px}
  .trustbar > div{padding:12px 0}
  .rv-grid{grid-template-columns:1fr}
  .rv-grid > :last-child{grid-column:auto}
  .sp-grid{grid-template-columns:repeat(2,1fr)}
  .ft-grid{grid-template-columns:1fr}
  .ft-bot{flex-direction:column;gap:12px;text-align:center}
  .about .txtcol,.find .info,.seadoo .txtcol{padding:56px 24px}
  .ticker-track > span{font-size:18px;gap:36px}
  .ticker-track{gap:36px}
}

/* ============== WAKESPORTS FLAIR . water + splash ============== */
@keyframes wk-rise{0%{opacity:0;transform:translateY(60px)}60%{transform:translateY(-6px)}100%{opacity:1;transform:translateY(0)}}
@keyframes wk-fade-up{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}
@keyframes wk-wave-shift{from{transform:translateX(0)}to{transform:translateX(-1440px)}}
@keyframes wk-wave-shift-rev{from{transform:translateX(-1440px)}to{transform:translateX(0)}}
@keyframes wk-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes wk-glint{0%,100%{opacity:.4;transform:scale(.9)}50%{opacity:1;transform:scale(1.2)}}
@keyframes wk-ripple{from{transform:scale(0);opacity:.6}to{transform:scale(2.5);opacity:0}}
@keyframes wk-pulse-sun{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}

/* Continuous flowing wave SVG that lives at the bottom of HERO and on section dividers */
.wk-waves{display:none}
.wk-waves.bottom{bottom:-1px}
.wk-waves svg{position:absolute;left:0;width:2880px;height:100%;animation:wk-wave-shift 24s linear infinite}
.wk-waves svg.s2{animation:wk-wave-shift-rev 36s linear infinite;opacity:.55}
.wk-waves svg.s3{animation:wk-wave-shift 48s linear infinite;opacity:.3}

/* Hero coords / weather . top right */
.wk-hud{position:absolute;top:120px;right:32px;z-index:2;font-family:"Inter",monospace;font-size:10.5px;letter-spacing:.2em;color:rgba(255,255,255,.6);text-align:right;line-height:1.8;text-transform:uppercase}
.wk-hud .live{color:var(--sun);font-weight:600;display:inline-flex;align-items:center;gap:8px}
.wk-hud .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--sun);animation:wk-pulse-sun 1.6s infinite;box-shadow:0 0 12px var(--sun)}
.wk-hud .b{color:#fff;font-weight:600}
@media (max-width:720px){.wk-hud{display:none}}

/* Sun glint orb top-right of hero */
.wk-sun{position:absolute;top:140px;left:8%;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--sun) 0%,rgba(232,176,38,.6) 30%,rgba(232,176,38,0) 70%);filter:blur(2px);z-index:1;animation:wk-bob 6s ease-in-out infinite;mix-blend-mode:screen;pointer-events:none;opacity:.7}
@media (max-width:720px){.wk-sun{display:none}}

/* Hero h1 . splash-up word reveal */
.hero h1 > span:first-child,.hero h1 .accent,.hero h1 .small{display:inline-block;opacity:0;animation:wk-rise 1s cubic-bezier(.2,.8,.2,1) forwards}
.hero h1 > span:first-child{animation-delay:.15s}
.hero h1 .accent{animation-delay:.4s}
.hero h1 .small{animation-delay:.65s}
.hero h1 .accent{position:relative}
.hero h1 .accent::after{content:"";position:absolute;left:0;right:0;bottom:.05em;height:.2em;background:var(--sun);opacity:.4;transform:scaleX(0);transform-origin:left;animation:wk-fade-up .8s cubic-bezier(.2,.8,.2,1) forwards;animation-delay:1.3s;z-index:-1}
.hero p.sub,.hero .cta-row,.hero .trustbar,.hero .tagline{opacity:0;animation:wk-fade-up .8s cubic-bezier(.2,.8,.2,1) forwards}
.hero .tagline{animation-delay:0s}
.hero p.sub{animation-delay:.95s}
.hero .cta-row{animation-delay:1.1s}
.hero .trustbar{animation-delay:1.25s}

/* Hero img slow zoom-out on load */
.hero-img{animation:wk-fade-up 1.2s ease forwards;transform:scale(1.08);transition:transform 10s linear}
.hero.in-view .hero-img{transform:scale(1)}

/* Generic scroll-reveal */
.r{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1)}
.r.in{opacity:1;transform:none}
.r-stagger > *{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.r-stagger.in > *{opacity:1;transform:none}
.r-stagger.in > *:nth-child(1){transition-delay:0s}
.r-stagger.in > *:nth-child(2){transition-delay:.12s}
.r-stagger.in > *:nth-child(3){transition-delay:.24s}
.r-stagger.in > *:nth-child(4){transition-delay:.36s}
.r-stagger.in > *:nth-child(5){transition-delay:.48s}

/* Charter cards . wave-rise reveal + ripple on click */
.charter{transform:translateY(60px) rotate(-.5deg);opacity:0;transition:opacity 1s cubic-bezier(.2,.8,.2,1),transform 1s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}
.charter-grid.in .charter{opacity:1;transform:none}
.charter-grid.in .charter:nth-child(1){transition-delay:.1s}
.charter-grid.in .charter:nth-child(2){transition-delay:.28s;transform:translateY(60px) rotate(.4deg)}
.charter-grid.in .charter:nth-child(2).in-view{transform:none}
.charter .img{transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.charter:hover .img{transform:scale(1.06)}
.charter::after{content:"";position:absolute;width:30px;height:30px;border-radius:50%;background:rgba(232,176,38,.4);left:var(--rx,50%);top:var(--ry,50%);transform:translate(-50%,-50%) scale(0);opacity:0;pointer-events:none}
.charter.rippling::after{animation:wk-ripple .8s ease-out}

/* Reviews . water-card hover */
.rv{position:relative;overflow:hidden;transition:transform .3s cubic-bezier(.2,.8,.2,1)}
.rv:hover{transform:translateY(-4px)}
.rv::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--sun));transform:scaleX(0);transform-origin:left;transition:transform .55s cubic-bezier(.2,.8,.2,1)}
.rv:hover::before{transform:scaleX(1)}
.rv .qm{transition:transform .35s ease,color .35s}
.rv:hover .qm{transform:translateY(-3px) rotate(-4deg);color:var(--sun)}

/* Sea-Doo price stamp pulse */
.seadoo .price-stamp{animation:wk-bob 4s ease-in-out infinite}

/* Sponsor strip . mono → color on hover */
.sponsors-strip img{transition:filter .35s,transform .25s;filter:grayscale(1) brightness(1.4) contrast(.8);opacity:.7}
.sponsors-strip img:hover{filter:none;opacity:1;transform:scale(1.08)}

/* Tagline pulse */
.hero .tagline .dot{animation:wk-pulse-sun 1.6s infinite}

/* Floating sun-glints across hero */
.wk-glints{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.wk-glints span{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--sun);box-shadow:0 0 8px var(--sun);animation:wk-glint 3s ease-in-out infinite}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .r,.charter{opacity:1!important;transform:none!important}
}