/* ===========================================================================
   Shane Ellis Guide Service — VISUAL UPGRADE LAYER
   Loaded after site.css. All color comes from seasonal --c-* vars (head.php).
   Animations reveal only when <html> has .js-anim (set by animations.js), so
   content is NEVER stuck hidden if JS/kill-switch is off. No reduced-motion
   gating (per Chad). CSP-safe: pure CSS, no @import, no external fonts.
   =========================================================================== */

:root{
  --ease: cubic-bezier(.2,.75,.2,1);
  --shadow-float: 0 24px 60px rgba(12,28,44,.22);
}

/* ---- Scroll-reveal (hidden only when JS is active) ---------------------- */
html.js-anim [data-reveal]{opacity:0;transform:translateY(34px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);will-change:opacity,transform}
html.js-anim [data-reveal="left"]{transform:translateX(-40px)}
html.js-anim [data-reveal="right"]{transform:translateX(40px)}
html.js-anim [data-reveal="zoom"]{transform:scale(.9)}
html.js-anim [data-reveal="fade"]{transform:none}
html.js-anim [data-reveal].rv-in{opacity:1;transform:none}

/* ---- Animated hero band ------------------------------------------------- */
.hero-x{position:relative;min-height:clamp(460px,72vh,720px);display:flex;align-items:center;
  color:#fff;overflow:hidden;isolation:isolate}
.hero-x__bg{position:absolute;inset:-8% 0 0 0;z-index:-2;background-size:cover;background-position:center;
  transform:translateZ(0);will-change:transform}
.hero-x::after{content:"";position:absolute;inset:0;z-index:-1;background:var(--hero-overlay)}
.hero-x .wrap{padding:4rem 20px}
.hero-x__eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:3px;font-weight:800;
  font-size:.82rem;color:#fff;background:rgba(255,255,255,.14);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.28);padding:.45rem .9rem;border-radius:999px;margin-bottom:1rem}
.hero-x h1{color:#fff;font-size:clamp(2.3rem,6vw,4.2rem);line-height:1.05;text-shadow:0 4px 30px rgba(0,0,0,.4);margin-bottom:.5rem}
.hero-x .lede{color:rgba(255,255,255,.94);font-size:clamp(1.05rem,2vw,1.3rem);max-width:42ch;text-shadow:0 2px 16px rgba(0,0,0,.45)}
.hero-x .hero-ctas{margin-top:1.8rem}
.hero-x .scroll-cue{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);color:#fff;opacity:.85;
  font-size:1.6rem;animation:bob 1.8s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,10px)}}

/* Floating glass action card on the hero */
.hero-card{margin-top:1.8rem;display:inline-flex;gap:.6rem;flex-wrap:wrap;padding:1rem;border-radius:16px;
  background:rgba(255,255,255,.12);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.25);box-shadow:var(--shadow-float)}

/* ---- Stats strip (animated counters) ------------------------------------ */
.stats-strip{background:var(--c-primary-deep);color:#fff;padding:2.4rem 0}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.5rem;text-align:center}
.stat__num{font-size:clamp(2.2rem,5vw,3.2rem);font-weight:900;line-height:1;color:#fff}
.stat__num .suffix{color:var(--c-accent)}
.stat__label{margin-top:.4rem;font-size:.9rem;letter-spacing:.5px;color:rgba(255,255,255,.8);text-transform:uppercase}

/* ---- Section headers + wave dividers ------------------------------------ */
.section{padding:3.5rem 0}
.section--tint{background:linear-gradient(180deg,var(--c-surface),var(--c-bg))}
.sec-head{text-align:center;max-width:60ch;margin:0 auto 2.2rem}
.sec-head .eyebrow{text-transform:uppercase;letter-spacing:3px;font-weight:800;font-size:.82rem;color:var(--c-section-accent)}
.sec-head h2{margin:.4rem 0 .5rem}
.sec-head p{color:var(--c-ink-soft)}
.wave{display:block;width:100%;height:60px;color:var(--c-surface)}
.wave svg{display:block;width:100%;height:100%}

/* ---- Feature/trust cards with icon + hover lift ------------------------- */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.2rem}
.feature{background:var(--c-surface);border:1px solid var(--c-line);border-radius:16px;padding:1.6rem;
  box-shadow:var(--shadow);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.feature__icon{width:54px;height:54px;display:grid;place-items:center;border-radius:14px;font-size:1.6rem;margin-bottom:.9rem;
  background:linear-gradient(135deg,var(--c-primary),var(--c-section-accent));color:#fff}
.feature h3{margin:0 0 .35rem;font-size:1.15rem}
.feature p{color:var(--c-ink-soft);margin:0}

/* ---- Image trip cards --------------------------------------------------- */
.trip-card{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);background:var(--c-surface);
  display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.trip-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.trip-card__media{position:relative;height:200px;overflow:hidden}
.trip-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.trip-card:hover .trip-card__media img{transform:scale(1.08)}
.trip-card__price{position:absolute;top:12px;right:12px;background:var(--c-accent);color:#16261d;font-weight:900;
  padding:.35rem .8rem;border-radius:999px;box-shadow:0 6px 16px rgba(0,0,0,.25)}
.trip-card__body{padding:1.3rem;display:flex;flex-direction:column;flex:1}

/* ---- Alternating image/text feature rows -------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center;padding:2.5rem 0}
.split--rev .split__media{order:2}
.split__media img{width:100%;border-radius:18px;box-shadow:var(--shadow-lg)}
.split__body h2{margin-top:0}
.split__body p{color:var(--c-ink-soft);font-size:1.05rem}
@media(max-width:820px){.split{grid-template-columns:1fr}.split--rev .split__media{order:0}}

/* ---- Lake cards with photo + overlay ------------------------------------ */
.lake-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem}
.lake-card{position:relative;border-radius:18px;overflow:hidden;min-height:260px;display:flex;align-items:flex-end;
  color:#fff;box-shadow:var(--shadow);isolation:isolate}
.lake-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .6s var(--ease)}
.lake-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,30,50,.1),rgba(10,30,50,.85))}
.lake-card:hover img{transform:scale(1.08)}
.lake-card__body{padding:1.3rem}
.lake-card__body h3{color:#fff;margin:0 0 .3rem}
.lake-card__body p{color:rgba(255,255,255,.9);font-size:.92rem;margin:0}

/* ---- Masonry gallery + lightbox ----------------------------------------- */
.masonry{columns:4 240px;column-gap:14px}
.masonry .ph{break-inside:avoid;margin:0 0 14px;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);
  cursor:zoom-in;position:relative;display:block;background:var(--c-surface)}
.masonry .ph img{width:100%;display:block;transition:transform .5s var(--ease),filter .3s}
.masonry .ph:hover img{transform:scale(1.06)}
.masonry .ph figcaption{position:absolute;left:0;right:0;bottom:0;padding:.7rem;color:#fff;font-size:.85rem;font-weight:600;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.72));opacity:0;transition:opacity .3s}
.masonry .ph:hover figcaption{opacity:1}

.lbx{position:fixed;inset:0;z-index:1000;background:rgba(8,16,26,.92);display:none;align-items:center;justify-content:center}
.lbx.open{display:flex}
.lbx img{max-width:92vw;max-height:84vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lbx__cap{position:absolute;bottom:24px;left:0;right:0;text-align:center;color:#fff;font-weight:600}
.lbx__btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);color:#fff;border:0;
  width:52px;height:52px;border-radius:50%;font-size:1.6rem;cursor:pointer;backdrop-filter:blur(6px)}
.lbx__btn:hover{background:rgba(255,255,255,.28)}
.lbx__prev{left:18px}.lbx__next{right:18px}
.lbx__close{position:absolute;top:18px;right:22px;background:none;border:0;color:#fff;font-size:2.2rem;cursor:pointer;line-height:1}
@media(max-width:600px){.masonry{columns:2 140px}.lbx__btn{width:42px;height:42px}}

/* ---- Buttons: shimmer on primary ---------------------------------------- */
.btn-primary, .btn-pay{position:relative;overflow:hidden}
.btn-primary::after, .btn-pay::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-20deg)}
.btn-primary:hover::after, .btn-pay:hover::after{left:130%;transition:left .7s var(--ease)}

/* ---- Header scroll state ------------------------------------------------- */
.site-header{transition:box-shadow .25s, background .25s}
.site-header.scrolled{box-shadow:0 6px 24px rgba(16,32,44,.12)}

/* ---- CTA band with image -------------------------------------------------*/
.cta-x{position:relative;color:#fff;text-align:center;padding:4rem 0;overflow:hidden;isolation:isolate}
.cta-x__bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center}
.cta-x::after{content:"";position:absolute;inset:0;z-index:-1;background:var(--hero-overlay)}
.cta-x h2{color:#fff;font-size:clamp(1.8rem,4vw,2.8rem)}
.cta-x p{color:rgba(255,255,255,.9)}

/* ---- FAQ two-column layout ---------------------------------------------- */
.faq-layout{display:grid;grid-template-columns:2fr 1fr;gap:2rem;align-items:start}
@media(max-width:760px){.faq-layout{grid-template-columns:1fr}}

/* ---- Review feature block ----------------------------------------------- */
.review-x{background:var(--c-surface);border:1px solid var(--c-line);border-left:5px solid var(--c-section-accent);
  border-radius:16px;padding:2rem;box-shadow:var(--shadow);max-width:760px;margin:0 auto}
.review-x blockquote{font-size:1.3rem;font-style:italic;line-height:1.5;margin:.5rem 0 1rem;color:var(--c-ink)}
.review-x .stars{color:var(--c-accent);font-size:1.3rem;letter-spacing:3px}
