/* =====================================================================
   Cooks Bay Marina — homepage + signature sections
   ===================================================================== */

/* ---- HERO ---- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--harbour-2)}
.hero__canvas{position:absolute;inset:0;z-index:0}
.hero__poster{position:absolute;inset:0;z-index:0}
.hero__poster img{width:100%;height:100%;object-fit:cover}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:
   linear-gradient(180deg,rgba(11,34,48,.42) 0%,rgba(11,34,48,.12) 32%,rgba(11,34,48,.20) 55%,rgba(11,34,48,.82) 100%),
   radial-gradient(120% 80% at 80% 10%,rgba(226,145,47,.16),transparent 55%);
}
.hero__inner{position:relative;z-index:3;width:100%;padding-bottom:clamp(2.5rem,6vw,5rem);padding-top:calc(var(--nav-h) + 2rem)}
.hero .eyebrow{color:#F2C078}
.hero .eyebrow::before{background:#F2C078}
.hero h1{color:var(--foam);max-width:16ch;text-shadow:0 2px 30px rgba(8,24,34,.4)}
.hero h1 em{font-style:italic;color:#FAD9A6}
.hero__lede{color:#E4ECEF;font-size:clamp(1.1rem,1.7vw,1.4rem);max-width:46ch;margin-top:1.3rem;text-shadow:0 1px 18px rgba(8,24,34,.45)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.6rem;margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.16)}
.hero__meta div{display:flex;flex-direction:column}
.hero__meta b{font-family:var(--font-mono);color:var(--foam);font-weight:600;font-size:1.05rem;font-variant-numeric:tabular-nums}
.hero__meta span{font-size:.78rem;color:#A9C0C8;letter-spacing:.04em}
.scroll-cue{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);z-index:3;color:#cfe0e5;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.8}
.scroll-cue::after{content:"";width:1px;height:34px;background:linear-gradient(#cfe0e5,transparent);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(.3);transform-origin:top;opacity:.3}50%{transform:scaleY(1);opacity:1}100%{transform:scaleY(.3);transform-origin:bottom;opacity:.3}}

/* sticky NAP under hero */
.nap-strip{position:relative;z-index:5;margin-top:-58px;margin-bottom:1rem}

/* ---- intro split ---- */
.intro-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.intro-media{position:relative}
.intro-media .media-frame{aspect-ratio:5/4}
.intro-media .float-stat{position:absolute;bottom:-26px;left:-26px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.3rem;box-shadow:var(--shadow);max-width:230px}
.intro-media .float-stat b{font-family:var(--font-display);font-size:1.7rem;color:var(--harbour);display:block;line-height:1}
.intro-media .float-stat span{font-size:.84rem;color:var(--ink-soft)}

/* ---- FOUR SEASONS band (signature scroll-scrub) ---- */
.seasons{background:var(--harbour);color:#D7E2E6;position:relative;overflow:hidden}
.seasons__head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem}
.seasons__track{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.season{position:relative;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);overflow:hidden;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;isolation:isolate}
.season__img{position:absolute;inset:0;z-index:-2}
.season__img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.season::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(11,34,48,.15),rgba(11,34,48,.88))}
.season:hover .season__img img{transform:scale(1.06)}
.season__body{padding:1.3rem}
.season__n{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;color:#F0B96A;text-transform:uppercase}
.season h3{color:#fff;margin-top:.4rem;font-size:1.3rem}
.season p{color:#C4D2D8;font-size:.9rem;margin-top:.4rem}
.season a{display:inline-flex;align-items:center;gap:.4em;margin-top:.9rem;color:#fff;font-weight:600;font-size:.9rem}
.season a:hover{color:var(--sun)}

/* ---- fleet teaser ---- */
.fleet-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.fleet-card{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--paper);border:1px solid var(--line);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.fleet-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.fleet-card img{aspect-ratio:1/1;width:100%;object-fit:cover}
.fleet-card .fc-body{padding:1rem 1.1rem 1.2rem}
.fleet-card h4{color:var(--harbour);font-size:1.05rem}
.fleet-card .fc-price{font-family:var(--font-mono);font-size:.84rem;color:var(--water);margin-top:.3rem;font-weight:600}

/* ---- services grid ---- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.svc{padding:1.7rem 1.6rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(16,46,64,.2)}
.svc__ic{width:52px;height:52px;border-radius:13px;background:rgba(21,94,102,.1);display:grid;place-items:center;color:var(--water);margin-bottom:1.1rem}
.svc__ic svg{width:1.6em;height:1.6em}
.svc h3{font-size:1.25rem}
.svc p{margin-top:.5rem;font-size:.95rem}
.svc a.more{display:inline-flex;align-items:center;gap:.4em;margin-top:1rem;font-weight:600;font-size:.92rem;color:var(--cedar)}
.svc a.more:hover{gap:.65em}

/* ---- testimonial ---- */
.quote-band{background:var(--sand-2)}
.bigquote{max-width:24ch;font-family:var(--font-display);font-weight:600;font-size:clamp(1.7rem,3.6vw,2.9rem);line-height:1.15;color:var(--harbour);letter-spacing:-.015em}
.bigquote em{color:var(--cedar);font-style:italic}
.quote-cite{margin-top:1.6rem;font-family:var(--font-mono);font-size:.84rem;letter-spacing:.04em;color:var(--ink-soft)}
.mini-quotes{display:grid;gap:1.2rem}
.mini-quote{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem 1.4rem;box-shadow:var(--shadow-sm)}
.mini-quote p{color:var(--ink);font-size:1rem}
.mini-quote cite{display:block;margin-top:.7rem;font-family:var(--font-mono);font-size:.78rem;color:var(--ink-soft);font-style:normal}

/* ---- events teaser ---- */
.event-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.event-card{position:relative;border-radius:var(--radius);overflow:hidden;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;isolation:isolate}
.event-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .9s var(--ease)}
.event-card::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(11,34,48,.1),rgba(11,34,48,.85))}
.event-card:hover img{transform:scale(1.06)}
.event-card .ec-body{padding:1.4rem}
.event-card h3{color:#fff;font-size:1.3rem}
.event-card p{color:#CFDBE0;font-size:.9rem;margin-top:.35rem}

/* ---- CTA band ---- */
.cta-band{position:relative;overflow:hidden;background:var(--harbour);color:var(--foam);border-radius:var(--radius-lg)}
.cta-band::after{content:"";position:absolute;inset:0;background:radial-gradient(90% 120% at 100% 0,rgba(226,145,47,.22),transparent 55%);pointer-events:none}
.cta-band .wrap{position:relative;z-index:2;text-align:center;padding-block:clamp(3rem,6vw,5rem)}
.cta-band h2{color:#fff;max-width:20ch;margin-inline:auto}
.cta-band p{color:#C4D2D8;margin-top:1rem;max-width:50ch;margin-inline:auto}
.cta-band .hero__cta{justify-content:center;margin-top:2rem}

/* depth-contour decoration */
.contour-deco{position:absolute;inset:0;pointer-events:none;opacity:.5;z-index:0}

@media (max-width:980px){
  .intro-grid{grid-template-columns:1fr}
  .seasons__track{grid-template-columns:1fr 1fr}
  .fleet-strip{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr}
  .event-row{grid-template-columns:1fr}
}
@media (max-width:560px){
  .seasons__track,.fleet-strip{grid-template-columns:1fr}
  .intro-media .float-stat{left:0;bottom:-18px}
  .hero{min-height:92svh}
}
