/* ============================================================
   TROPIC PAWS — Homepage + decorative sections
   ============================================================ */

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(900px 500px at 85% -10%, rgba(255,166,43,.18), transparent 60%),
    radial-gradient(1100px 700px at -10% 110%, rgba(0,165,181,.16), transparent 60%),
    linear-gradient(180deg,#F2FBFC 0%, #fff 100%);
}
.hero .container{
  position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;
  gap:48px;align-items:center;padding-top:64px;padding-bottom:96px;
}
@media (max-width:920px){
  .hero .container{grid-template-columns:1fr;padding-top:44px;padding-bottom:72px}
}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:22px}
.hero h1{
  font-size:clamp(40px,6.2vw,72px);line-height:1.04;margin-bottom:20px;color:var(--aqua-dark);
}
.hero h1 .hw{display:inline-block;white-space:nowrap}
.hero h1 .hw i{font-style:normal}
.hw--groom i{color:var(--aqua)}
.hw--wash  i{color:var(--mango-deep)}
.hw--play  i{color:var(--coral)}
.hw--stay  i{color:var(--aqua-deep)}
.hero h1 .dot{color:var(--aqua-soft)}
.hero .lead{font-size:19.5px;margin-bottom:30px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:30px}
.hero-proof{display:flex;flex-wrap:wrap;align-items:center;gap:18px;font-size:14.5px;color:var(--ink-soft)}
.hero-proof .gstars{display:flex;gap:2px;color:var(--mango)}
.hero-proof .gstars svg{width:16px;height:16px}
.hero-proof b{color:var(--aqua-dark)}

.hero-art{position:relative}
.hero-photo{
  border-radius:36px;overflow:hidden;box-shadow:var(--shadow-lg);
  aspect-ratio:4/4.6;position:relative;background:var(--aqua-mist);
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
@media (max-width:920px){.hero-photo{aspect-ratio:16/11}}
.hero-sticker{
  position:absolute;background:#fff;border-radius:18px;box-shadow:var(--shadow-md);
  padding:13px 17px;display:flex;align-items:center;gap:11px;font-size:13.5px;font-weight:800;color:var(--aqua-dark);
}
.hero-sticker svg{width:26px;height:26px;flex:none}
.hero-sticker small{display:block;font-weight:700;color:var(--ink-soft);font-size:12px}
.hs-award{top:22px;left:-26px;color:var(--mango-deep)}
.hs-rating{bottom:30px;right:-20px;color:var(--aqua)}
@media (max-width:920px){.hs-award{left:10px}.hs-rating{right:10px}}

/* floating palm leaves / paws */
.float-deco{position:absolute;z-index:1;color:var(--aqua);opacity:.13;pointer-events:none}
.fd-1{top:6%;right:4%;width:140px;height:140px;transform:rotate(18deg)}
.fd-2{bottom:8%;left:2%;width:110px;height:110px;transform:rotate(-14deg);color:var(--mango)}
.fd-3{top:40%;left:46%;width:70px;height:70px;transform:rotate(40deg);opacity:.08}

/* ---------- Service finder ---------- */
.finder-card{
  position:relative;border-radius:var(--r-lg);overflow:hidden;background:#fff;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
  border:2px solid transparent;
  transition:transform var(--speed) var(--ease-pop),box-shadow var(--speed),border-color var(--speed);
}
.finder-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--aqua-soft)}
.fc-img{aspect-ratio:4/3;background:var(--aqua-mist);position:relative;overflow:hidden}
.fc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.finder-card:hover .fc-img img{transform:scale(1.06)}
.fc-tag{
  position:absolute;top:14px;left:14px;background:#fff;border-radius:var(--r-pill);
  font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:1.1px;text-transform:uppercase;
  padding:7px 15px;color:var(--aqua-deep);box-shadow:var(--shadow-sm);
}
.fc-body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1}
.fc-body h3{font-size:23px;margin-bottom:8px}
.fc-body p{color:var(--ink-soft);font-size:15px;margin-bottom:16px}
.fc-meta{display:flex;justify-content:space-between;align-items:center;margin-top:auto}
.fc-price{font-family:var(--font-display);font-weight:600;color:var(--aqua-deep);font-size:17px}
.fc-price small{font-weight:500;color:var(--ink-soft);font-size:13px}
.fc-go{
  width:44px;height:44px;border-radius:50%;background:var(--mango);color:#5B3200;
  display:flex;align-items:center;justify-content:center;transition:transform var(--speed) var(--ease-pop);
}
.fc-go svg{width:20px;height:20px}
.finder-card:hover .fc-go{transform:translateX(4px) rotate(-8deg)}

/* ---------- Stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media (max-width:900px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{text-align:center;padding:26px 14px;background:rgba(255,255,255,.07);border-radius:var(--r-md)}
.stat b{display:block;font-family:var(--font-display);font-weight:600;font-size:clamp(34px,4vw,46px);color:#fff;line-height:1.05}
.stat b em{font-style:normal;color:var(--mango)}
.stat span{font-size:14px;color:#9FD3D9;font-weight:700;letter-spacing:.5px}

/* ---------- Split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
@media (max-width:920px){.split{grid-template-columns:1fr;gap:34px}}
.split-img{border-radius:32px;overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/3.4;background:var(--aqua-mist)}
.split-img img{width:100%;height:100%;object-fit:cover}
.split .checks{margin-top:22px}
.split .btn{margin-top:26px}

/* ---------- Gallery ---------- */
.g-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width:980px){.g-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:640px){.g-grid{grid-template-columns:repeat(2,1fr)}}
.g-item{
  border-radius:var(--r-md);overflow:hidden;aspect-ratio:1;background:var(--aqua-mist);
  position:relative;box-shadow:var(--shadow-sm);
}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.g-item:hover img{transform:scale(1.07)}
.g-item--wide{grid-column:span 2;aspect-ratio:2.05/1}
@media (max-width:640px){.g-item--wide{grid-column:span 2}}

/* ---------- Hours strip ---------- */
.hours-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:760px){.hours-grid{grid-template-columns:1fr}}
.hours-card{background:#fff;border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-sm)}
.hours-card h3{display:flex;align-items:center;gap:11px;font-size:20px;margin-bottom:16px}
.hours-card h3 svg{width:22px;height:22px;color:var(--mango-deep)}
.hours-card table{width:100%;border-collapse:collapse;font-size:15.5px}
.hours-card td{padding:9px 0;border-bottom:1px dashed var(--line)}
.hours-card tr:last-child td{border-bottom:0}
.hours-card td:last-child{text-align:right;font-weight:800;color:var(--aqua-dark);font-variant-numeric:tabular-nums}
.hours-card .hnote{font-size:13px;color:var(--ink-soft);margin-top:12px}

/* ---------- Map ---------- */
.map-wrap{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:16/8;background:var(--aqua-mist)}
.map-wrap iframe{width:100%;height:100%;border:0}
@media (max-width:760px){.map-wrap{aspect-ratio:4/3.4}}

/* ---------- Club banner ---------- */
.club{
  position:relative;overflow:hidden;border-radius:var(--r-lg);
  background:linear-gradient(115deg,#FF9E2C 0%,var(--mango) 45%,#FFC56B 100%);
  padding:50px;display:grid;grid-template-columns:1.2fr .8fr;gap:30px;align-items:center;color:#5B3200;
}
@media (max-width:860px){.club{grid-template-columns:1fr;padding:36px 26px}}
.club h2{color:#4A2900;font-size:clamp(26px,3.6vw,38px);margin-bottom:12px}
.club p{font-size:17px;max-width:520px}
.club .btn--aqua{box-shadow:0 8px 22px rgba(0,112,124,.3)}
.club-perks{display:grid;gap:10px}
.club-perks li{display:flex;gap:10px;align-items:center;font-weight:800;font-size:15.5px;background:rgba(255,255,255,.35);border-radius:var(--r-pill);padding:10px 18px}
.club-perks svg{width:18px;height:18px;flex:none}

/* ?qa mode — force-reveal everything for screenshots */
.qa-mode .reveal{opacity:1!important;transform:none!important}
