/* ─────────────────────────────────────────────
   South Hams Coast — Modern Shared Stylesheet
   ───────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Playfair+Display:wght@700;900&display=swap');

*{margin:0;padding:0;box-sizing:border-box;}

:root{
  --ocean:#0c3d5e;
  --ocean-mid:#0369a1;
  --ocean-light:#38bdf8;
  --foam:#e0f2fe;
  --sand:#fef3c7;
  --sand-dark:#f59e0b;
  --sunset:#f97316;
  --green:#16a34a;
  --green-bg:#dcfce7;
  --red:#dc2626;
  --red-bg:#fee2e2;
  --amber-bg:#fef9c3;
  --amber:#92400e;
  --slate:#1e293b;
  --muted:#64748b;
  --light:#94a3b8;
  --bg:#f8fafc;
  --white:#ffffff;
  --glass:rgba(255,255,255,0.12);
  --glass-border:rgba(255,255,255,0.2);
  --shadow-sm:0 2px 8px rgba(0,0,0,0.06);
  --shadow:0 4px 20px rgba(0,0,0,0.1);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.18);
  --radius:16px;
  --radius-sm:10px;
}

html{scroll-behavior:smooth;}
body{
  font-family:'Inter',-apple-system,sans-serif;
  background:var(--bg);
  color:var(--slate);
  line-height:1.6;
  overflow-x:hidden;
}

/* ── SCROLLBAR ─────────────────────────────── */
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:#f1f5f9;}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:#94a3b8;}

/* ── NAV ───────────────────────────────────── */
.site-nav{
  background:rgba(12,61,94,0.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  position:sticky;top:0;z-index:100;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.nav-inner{
  max-width:1000px;margin:0 auto;
  display:flex;align-items:center;
  padding:0 1.5rem;
}
.nav-brand{
  color:white;font-weight:800;font-size:0.95rem;
  text-decoration:none;padding:1rem 1.2rem 1rem 0;
  white-space:nowrap;letter-spacing:-0.3px;
  border-right:1px solid rgba(255,255,255,0.12);
  margin-right:0.5rem;display:flex;align-items:center;gap:0.4rem;
}
.nav-brand .brand-sub{opacity:0.5;font-weight:400;font-size:0.8rem;}
.nav-links{display:flex;flex:1;}
.nav-link{
  color:rgba(255,255,255,0.65);text-decoration:none;
  padding:0.9rem 0.9rem;font-size:0.82rem;font-weight:500;
  display:flex;align-items:center;gap:0.35rem;
  border-bottom:2px solid transparent;
  transition:all 0.2s;letter-spacing:0.1px;
}
.nav-link:hover{color:white;background:rgba(255,255,255,0.06);}
.nav-link.active{color:white;border-bottom-color:var(--ocean-light);}
.nav-icon{font-size:0.95rem;}

/* ── HERO ──────────────────────────────────── */
.hero{
  position:relative;
  min-height:520px;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  overflow:hidden;
  background:var(--ocean);
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transform:scale(1.05);
  transition:transform 8s ease-out;
}
.hero-bg.loaded{transform:scale(1);}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    to bottom,
    rgba(12,61,94,0.5) 0%,
    rgba(12,61,94,0.4) 40%,
    rgba(12,61,94,0.75) 100%
  );
}
.hero-content{
  position:relative;z-index:2;
  color:white;padding:4rem 1.5rem 3rem;
  max-width:700px;
}
.hero-eyebrow{
  font-size:0.72rem;text-transform:uppercase;letter-spacing:3px;
  font-weight:700;opacity:0.75;margin-bottom:0.8rem;
}
.hero-content h1{
  font-family:'Playfair Display',serif;
  font-size:3.2rem;font-weight:900;
  letter-spacing:-1px;line-height:1.1;
  text-shadow:0 2px 20px rgba(0,0,0,0.3);
}
.hero-content .tagline{
  font-size:0.95rem;opacity:0.8;margin-top:0.6rem;
  font-weight:400;letter-spacing:0.5px;
}
.hero-content .date-stamp{
  font-size:0.75rem;opacity:0.55;margin-top:0.5rem;
}
.hero-wave{
  position:absolute;bottom:-2px;left:0;right:0;
  height:80px;z-index:3;
}

/* ── CONTAINER ─────────────────────────────── */
.container{max-width:1000px;margin:0 auto;padding:0 1.5rem;}

/* ── CARDS ─────────────────────────────────── */
.card{
  background:var(--white);
  border-radius:var(--radius);
  padding:1.8rem;
  margin-bottom:1.2rem;
  box-shadow:var(--shadow-sm);
  border:1px solid rgba(0,0,0,0.04);
  transition:box-shadow 0.2s;
}
.card:hover{box-shadow:var(--shadow);}

/* ── SECTION HEADER ────────────────────────── */
.section-header{
  display:flex;align-items:center;gap:0.75rem;
  margin-bottom:1.2rem;padding-bottom:1rem;
  border-bottom:1px solid #f1f5f9;flex-wrap:wrap;
}
.sec-icon{font-size:1.6rem;line-height:1;}
.section-header h2{font-size:1.15rem;font-weight:700;color:var(--slate);letter-spacing:-0.3px;}
.section-header .loc{font-size:0.72rem;color:var(--light);font-weight:500;margin-top:0.1rem;}
.section-header .badge-area{margin-left:auto;display:flex;gap:0.4rem;align-items:center;flex-wrap:wrap;}

/* ── DATA GRID ─────────────────────────────── */
.data-grid{display:grid;grid-template-columns:1fr 1fr;gap:0.4rem;}
.data-row{
  background:#f8fafc;
  border:1px solid #f1f5f9;
  border-radius:8px;
  padding:0.6rem 0.8rem;
  display:flex;justify-content:space-between;align-items:center;gap:0.5rem;
  transition:background 0.15s;
}
.data-row:hover{background:#f1f5f9;}
.dr-label{font-size:0.78rem;color:var(--muted);display:flex;align-items:center;gap:0.3rem;}
.dr-value{font-size:0.82rem;font-weight:600;color:var(--slate);text-align:right;}
.full{grid-column:1/-1;}

/* ── BADGES ────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:0.25rem;
  padding:0.2rem 0.6rem;border-radius:20px;
  font-size:0.72rem;font-weight:600;white-space:nowrap;
}
.badge.good{background:#dcfce7;color:#166534;}
.badge.fair{background:#fef9c3;color:#854d0e;}
.badge.poor{background:#fee2e2;color:#991b1b;}
.badge.info{background:#dbeafe;color:#1e40af;}

/* ── NOTES ─────────────────────────────────── */
.note{
  border-radius:0 8px 8px 0;
  padding:0.75rem 1rem;font-size:0.81rem;margin-top:0.8rem;
  line-height:1.5;
}
.note.amber{background:#fffbeb;border-left:3px solid var(--sand-dark);color:#78350f;}
.note.blue{background:#eff6ff;border-left:3px solid #60a5fa;color:#1e3a8a;}
.note.green{background:#f0fdf4;border-left:3px solid #4ade80;color:#14532d;}
.note.red{background:#fff1f2;border-left:3px solid #f87171;color:#7f1d1d;}

/* ── TIDES ─────────────────────────────────── */
.tide-row{display:flex;gap:0.5rem;justify-content:space-around;padding:1rem 0;flex-wrap:wrap;}
.tide-pt{text-align:center;}
.tide-label{font-size:0.62rem;text-transform:uppercase;font-weight:700;letter-spacing:0.5px;}
.tide-label.high{color:var(--ocean-light);}
.tide-label.low{color:var(--sand-dark);}
.tide-bar{width:4px;border-radius:2px;margin:0.25rem auto;}
.tide-bar.high{height:52px;background:linear-gradient(to top,#38bdf8,#0c4a6e);}
.tide-bar.low{height:22px;background:linear-gradient(to top,var(--sand-dark),#fef3c7);}
.tide-time{font-size:1rem;font-weight:700;color:var(--slate);}
.tide-ht{font-size:0.7rem;color:var(--light);margin-top:0.1rem;}

/* ── STATS STRIP ────────────────────────────── */
.stats-strip{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(100px,1fr));
  gap:0.6rem;margin-bottom:1.2rem;
}
.stat{
  background:white;border-radius:var(--radius-sm);
  padding:1rem 0.6rem;text-align:center;
  box-shadow:var(--shadow-sm);
  border:1px solid rgba(0,0,0,0.04);
  transition:transform 0.15s,box-shadow 0.15s;
}
.stat:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.stat .s-icon{font-size:1.3rem;}
.stat .s-val{font-size:1.25rem;font-weight:800;color:var(--ocean);margin:0.2rem 0;letter-spacing:-0.5px;}
.stat .s-label{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.8px;color:var(--light);font-weight:700;}

/* ── VERDICT BANNER ────────────────────────── */
.verdict{
  background:white;border-radius:var(--radius);
  padding:1.2rem 1.5rem;margin-bottom:1.2rem;
  box-shadow:var(--shadow-sm);
  border:1px solid rgba(0,0,0,0.04);
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
}
.verdict .v-icon{font-size:2.2rem;}
.verdict h2{font-size:1.05rem;font-weight:700;color:var(--slate);letter-spacing:-0.3px;}
.verdict p{font-size:0.81rem;color:var(--muted);margin-top:0.2rem;line-height:1.5;}

/* ── PHOTO CARDS (activity nav) ────────────── */
.page-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.2rem;}
.page-card{
  display:block;text-decoration:none;
  border-radius:var(--radius);overflow:hidden;
  position:relative;min-height:200px;
  transition:transform 0.3s,box-shadow 0.3s;
}
.page-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.page-card .pc-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform 0.4s;
}
.page-card:hover .pc-bg{transform:scale(1.07);}
.page-card .pc-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,0.8) 0%,rgba(0,0,0,0.2) 60%,transparent 100%);
}
.page-card .pc-content{
  position:relative;z-index:2;
  color:white;
  height:100%;display:flex;flex-direction:column;
  justify-content:flex-end;padding:1.3rem;
}
.page-card .pc-icon{font-size:2rem;margin-bottom:0.4rem;}
.page-card h3{font-size:1rem;font-weight:700;letter-spacing:-0.2px;}
.page-card p{font-size:0.72rem;opacity:0.8;margin-top:0.3rem;line-height:1.4;}
.page-card .pc-arrow{
  display:inline-flex;align-items:center;gap:0.3rem;
  margin-top:0.7rem;font-size:0.72rem;font-weight:600;
  background:rgba(255,255,255,0.2);
  padding:0.25rem 0.7rem;border-radius:20px;
  backdrop-filter:blur(4px);width:fit-content;
}

/* ── ACTIVITY VERDICT ROWS ─────────────────── */
.quick-verdict{
  border-radius:10px;padding:0.9rem 1rem;margin-bottom:0.5rem;
  display:flex;align-items:center;gap:0.8rem;
  text-decoration:none;color:inherit;
  transition:all 0.2s;border:1px solid transparent;
}
.quick-verdict:last-child{margin-bottom:0;}
.quick-verdict:hover{transform:translateX(4px);}
.quick-verdict.sail{background:linear-gradient(to right,#eff6ff,#f8faff);border-color:#bfdbfe;}
.quick-verdict.surf{background:linear-gradient(to right,#f0fdf4,#f8fff9);border-color:#bbf7d0;}
.quick-verdict.fish{background:linear-gradient(to right,#fffbeb,#fffdf5);border-color:#fde68a;}
.quick-verdict:hover.sail{background:linear-gradient(to right,#dbeafe,#eff6ff);box-shadow:0 4px 16px rgba(59,130,246,0.15);}
.quick-verdict:hover.surf{background:linear-gradient(to right,#dcfce7,#f0fdf4);box-shadow:0 4px 16px rgba(34,197,94,0.15);}
.quick-verdict:hover.fish{background:linear-gradient(to right,#fef3c7,#fffbeb);box-shadow:0 4px 16px rgba(245,158,11,0.15);}
.qv-icon{font-size:1.5rem;flex-shrink:0;}
.qv-body{flex:1;min-width:0;}
.qv-body .qv-title{font-size:0.85rem;font-weight:700;color:var(--slate);}
.qv-body .qv-sum{font-size:0.75rem;color:var(--muted);margin-top:0.15rem;line-height:1.4;}
.qv-badge{margin-left:auto;flex-shrink:0;}
.qv-arrow{font-size:0.9rem;color:var(--light);flex-shrink:0;}

/* ── GALLERY STRIP ─────────────────────────── */
.gallery-strip{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:0.6rem;
  margin-bottom:1.2rem;
}
.gallery-item{
  border-radius:var(--radius-sm);overflow:hidden;
  position:relative;height:130px;
  transition:transform 0.3s,box-shadow 0.3s;
  cursor:pointer;
}
.gallery-item:hover{transform:scale(1.03);box-shadow:var(--shadow-lg);}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.4s;
  display:block;
}
.gallery-item:hover img{transform:scale(1.08);}
.gallery-item .gal-label{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(0,0,0,0.75),transparent);
  color:white;font-size:0.68rem;font-weight:700;
  padding:0.5rem 0.6rem 0.4rem;
  text-transform:uppercase;letter-spacing:0.5px;
}

/* ── LIVE LINKS ─────────────────────────────── */
.live-links{display:grid;grid-template-columns:1fr 1fr;gap:0.8rem;}
.live-link{
  display:block;text-decoration:none;
  border-radius:12px;overflow:hidden;
  position:relative;
  transition:transform 0.2s,box-shadow 0.2s;
}
.live-link:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.live-link-inner{
  padding:1.3rem;text-align:center;color:white;
  background:linear-gradient(135deg,var(--ocean),var(--ocean-mid));
}
.live-link .ll-icon{font-size:2rem;margin-bottom:0.4rem;}
.live-link .ll-title{font-size:0.88rem;font-weight:700;}
.live-link .ll-sub{font-size:0.7rem;opacity:0.8;margin-top:0.2rem;}
.live-link .ll-btn{
  display:inline-block;margin-top:0.7rem;
  background:rgba(255,255,255,0.2);
  padding:0.25rem 0.7rem;border-radius:20px;
  font-size:0.7rem;font-weight:600;
  backdrop-filter:blur(4px);
}

/* ── TABLES ─────────────────────────────────── */
.info-table{width:100%;border-collapse:collapse;font-size:0.8rem;}
.info-table th{
  background:#f8fafc;color:var(--muted);
  font-weight:700;padding:0.6rem 0.8rem;
  text-align:left;font-size:0.7rem;
  text-transform:uppercase;letter-spacing:0.5px;
  border-bottom:2px solid #f1f5f9;
}
.info-table td{padding:0.55rem 0.8rem;border-bottom:1px solid #f8fafc;color:var(--slate);}
.info-table tr:last-child td{border-bottom:none;}
.info-table tbody tr:hover td{background:#f8fafc;}

/* ── TAGS ──────────────────────────────────── */
.tags{display:flex;gap:0.4rem;flex-wrap:wrap;margin-top:0.6rem;}
.tag{
  background:#f1f5f9;color:var(--muted);
  padding:0.2rem 0.65rem;border-radius:20px;
  font-size:0.72rem;font-weight:600;
}
.tag.blue{background:#dbeafe;color:#1e40af;}
.tag.green{background:#dcfce7;color:#166534;}
.tag.amber{background:#fef3c7;color:#78350f;}

/* ── SECTION DIVIDER ───────────────────────── */
.divider{
  display:flex;align-items:center;gap:1rem;
  margin:0.5rem 0 1.2rem;
}
.divider-line{flex:1;height:1px;background:linear-gradient(to right,#e2e8f0,transparent);}
.divider-line.right{background:linear-gradient(to left,#e2e8f0,transparent);}
.divider-label{
  font-size:0.65rem;text-transform:uppercase;
  letter-spacing:2px;font-weight:700;color:var(--light);
  white-space:nowrap;
}

/* ── SOURCES ────────────────────────────────── */
.sources{
  background:white;border-radius:var(--radius-sm);
  padding:1rem 1.2rem;margin-bottom:1.2rem;
  border:1px solid #f1f5f9;
}
.sources h4{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--light);margin-bottom:0.5rem;}
.src-list{display:flex;flex-wrap:wrap;gap:0.3rem 1rem;}
.src-list a{color:var(--ocean-light);text-decoration:none;font-size:0.75rem;}
.src-list a:hover{text-decoration:underline;}

/* ── FOOTER ─────────────────────────────────── */
footer{
  background:var(--ocean);
  color:rgba(255,255,255,0.6);
  text-align:center;padding:2rem 1.5rem;
  font-size:0.75rem;
}
footer a{color:var(--ocean-light);text-decoration:none;}
footer a:hover{text-decoration:underline;}
footer .footer-links{display:flex;justify-content:center;gap:1rem;margin-bottom:0.8rem;flex-wrap:wrap;}
footer .footer-links a{color:rgba(255,255,255,0.7);font-weight:500;}

/* ── MULTI-DAY FORECAST ─────────────────────── */
.multi-day{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:0.6rem;}
.day-card{
  background:#f8fafc;border-radius:var(--radius-sm);
  padding:0.9rem 0.6rem;text-align:center;
  border:1px solid #f1f5f9;
  transition:all 0.2s;
}
.day-card:hover{background:white;box-shadow:var(--shadow-sm);}
.day-card .dc-day{font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--light);}
.day-card .dc-icon{font-size:1.6rem;margin:0.3rem 0;}
.day-card .dc-temp,.day-card .dc-surf,.day-card .dc-text{font-size:0.95rem;font-weight:700;color:var(--slate);}
.day-card .dc-wind,.day-card .dc-detail{font-size:0.68rem;color:var(--muted);margin-top:0.2rem;line-height:1.3;}
.day-card .dc-badge{margin-top:0.5rem;}

/* ── SPOT CARDS ─────────────────────────────── */
.spot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:0.7rem;margin-top:0.5rem;}
.spot-card{
  border-radius:var(--radius-sm);
  border:1px solid #f1f5f9;background:#f8fafc;
  padding:1rem;transition:all 0.2s;
}
.spot-card:hover{background:white;box-shadow:var(--shadow);border-color:#e2e8f0;}
.spot-card h4{font-size:0.85rem;font-weight:700;color:var(--slate);}
.spot-card .sc-type{font-size:0.68rem;color:var(--light);font-weight:500;margin-top:0.1rem;}
.spot-card ul{list-style:none;margin-top:0.6rem;font-size:0.75rem;color:var(--muted);}
.spot-card ul li{padding:0.12rem 0;display:flex;gap:0.3rem;}
.spot-card .sc-badge{margin-top:0.5rem;}

/* ── RESPONSIVE ─────────────────────────────── */
@media(max-width:700px){
  .hero-content h1{font-size:2.2rem;}
  .page-cards{grid-template-columns:1fr;}
  .page-card{min-height:150px;}
  .data-grid{grid-template-columns:1fr;}
  .live-links{grid-template-columns:1fr;}
  .gallery-strip{grid-template-columns:repeat(2,1fr);}
  .nav-brand .brand-sub{display:none;}
  .nav-link{padding:0.85rem 0.55rem;font-size:0.75rem;}
  .card{padding:1.2rem;}
  .stats-strip{grid-template-columns:repeat(4,1fr);}
}
@media(max-width:400px){
  .stats-strip{grid-template-columns:repeat(2,1fr);}
  .gallery-strip{grid-template-columns:repeat(2,1fr);}
}

/* ── ANIMATIONS ─────────────────────────────── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px);}
  to{opacity:1;transform:translateY(0);}
}
.fade-up{animation:fadeUp 0.5s ease forwards;}
.fade-up-1{animation-delay:0.1s;opacity:0;}
.fade-up-2{animation-delay:0.2s;opacity:0;}
.fade-up-3{animation-delay:0.3s;opacity:0;}

/* ── BAIT / SPECIES CARDS ────────────────────── */
.bait-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:0.5rem;margin-top:0.5rem;}
.bait-card{
  background:#f8fafc;border-radius:var(--radius-sm);
  padding:0.7rem;text-align:center;
  border:1px solid #f1f5f9;
  transition:all 0.2s;
}
.bait-card:hover{background:white;box-shadow:var(--shadow-sm);}
.bait-card .bc-icon{font-size:1.4rem;}
.bait-card .bc-name{font-size:0.75rem;font-weight:700;margin-top:0.3rem;color:var(--slate);}
.bait-card .bc-target{font-size:0.65rem;color:var(--muted);margin-top:0.1rem;}

/* ── MARKS GRID ─────────────────────────────── */
.marks-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(195px,1fr));gap:0.7rem;margin-top:0.5rem;}
.mark-card{
  border-radius:var(--radius-sm);border:1px solid #f1f5f9;
  padding:1rem;background:#f8fafc;transition:all 0.2s;
}
.mark-card:hover{background:white;box-shadow:var(--shadow);border-color:#e2e8f0;}
.mark-card h4{font-size:0.85rem;font-weight:700;color:var(--slate);}
.mark-card .mc-type{font-size:0.68rem;color:var(--light);font-weight:500;}
.mark-card ul{list-style:none;margin-top:0.5rem;font-size:0.75rem;color:var(--muted);}
.mark-card ul li{padding:0.12rem 0;display:flex;gap:0.3rem;}

/* ── WETSUIT GUIDE ───────────────────────────── */
.wetsuit-guide{display:grid;grid-template-columns:repeat(auto-fit,minmax(78px,1fr));gap:0.4rem;margin-top:0.5rem;}
.wt-month{border-radius:8px;padding:0.5rem 0.3rem;text-align:center;font-size:0.68rem;border:1px solid transparent;}
.wt-month .wm-name{font-weight:700;margin-bottom:0.2rem;font-size:0.7rem;}
.wt-month.cold{background:#dbeafe;color:#1e3a8a;border-color:#bfdbfe;}
.wt-month.cool{background:#dcfce7;color:#166534;border-color:#bbf7d0;}
.wt-month.warm{background:#fef3c7;color:#78350f;border-color:#fde68a;}

/* ── CAL LEGEND ─────────────────────────────── */
.cal-legend{display:flex;gap:1rem;margin-top:0.5rem;flex-wrap:wrap;}
.cal-legend span{font-size:0.7rem;display:flex;align-items:center;gap:0.3rem;}
