/* =====================================================================
   our904 — spot-pages.css
   ---------------------------------------------------------------------
   Styles for build-generated per-listing pages (/fishing/{slug}/ and
   /eats/{slug}/). Loaded by pageShell() in build.js on top of base.css.

   Palette tokens (--navy-*, --gold, --teal*, --ink, --soft, --muted)
   come from base.css :root. Do not redefine them here.

   Previously inlined into all 111+ generated pages (~55 lines × each).
   Extracting to this file lets browsers cache once and reuse.
   =====================================================================
*/

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

body {
  background: var(--navy-900);
  color: var(--ink);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.6;
  /* The shared site-nav (rendered by /js/nav.js) is position:fixed
     and 64px tall — push body content below it so headings aren't
     hidden under the nav. */
  padding-top: 64px;
}
body.in-iframe { padding-top: 0; }

a { color: var(--teal-lt); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- Top bar / site nav (per-spot flavour) ---- */
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 20px;
  background: rgba(6, 13, 26, 0.95);
  border-bottom: 1px solid var(--navy-600);
  backdrop-filter: blur(8px);
}
.logo { font-size: 22px; font-weight: 900; color: var(--ink); letter-spacing: -0.8px; }
.logo .accent { color: var(--gold); }
.topbar-nav { display: flex; gap: 6px; flex-wrap: wrap; }
.topbar-nav a {
  color: var(--soft); font-size: 12px; font-weight: 600;
  padding: 6px 10px; border-radius: 6px; border: 1px solid transparent;
}
.topbar-nav a:hover { border-color: var(--navy-600); color: var(--ink); text-decoration: none; }
.topbar-nav a.cta { background: var(--gold); color: var(--navy-900); border-color: var(--gold); }
.topbar-nav a.cta:hover { background: #f0b848; }
/* CTA link sits on a gold background — flip its icon to navy so it stays readable. */
.topbar-nav a.cta .icon { color: var(--navy-900); }

/* ---- Page layout ---- */
main { max-width: 860px; margin: 0 auto; padding: 36px 20px 64px; }

.breadcrumb { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 1.3px; margin-bottom: 10px; }
.breadcrumb a { color: var(--muted); }

h1 { font-size: 34px; font-weight: 900; color: var(--gold); letter-spacing: -1px; margin-bottom: 6px; line-height: 1.15; }

.area { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 18px; font-weight: 700; }

.content { font-size: 15px; color: var(--soft); margin-bottom: 22px; }

/* ---- Panels (Target Species, Access, Rig, Related) ---- */
.panel {
  background: var(--navy-800);
  border: 1px solid var(--navy-600);
  border-radius: 12px;
  padding: 18px;
  margin-bottom: 16px;
}
.panel h3 {
  font-size: 11px; color: var(--gold);
  text-transform: uppercase; letter-spacing: 1.3px;
  margin-bottom: 8px; font-weight: 800;
}

/* ---- Species / tag pills ---- */
.tags { display: flex; gap: 6px; flex-wrap: wrap; margin: 10px 0; }
.tag {
  font-size: 11px;
  background: rgba(232, 168, 50, 0.12);
  color: var(--gold);
  padding: 4px 10px;
  border-radius: 12px;
  letter-spacing: 0.3px;
}

/* ---- Access meta grid ---- */
.meta-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 10px; }
.meta-cell { background: rgba(6, 13, 26, 0.5); padding: 10px; border-radius: 8px; }
.meta-cell .l { font-size: 9px; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; font-weight: 700; }
.meta-cell .v { font-size: 14px; color: var(--ink); font-weight: 700; margin-top: 2px; }

/* ---- CTA buttons ---- */
.cta-row { display: flex; gap: 10px; flex-wrap: wrap; margin: 14px 0; }
.btn {
  display: inline-block;
  background: var(--gold); color: var(--navy-900);
  padding: 10px 18px; border-radius: 20px;
  font-size: 12px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.5px;
  text-decoration: none;
}
.btn:hover { background: #f0b848; text-decoration: none; }
.btn.secondary { background: var(--navy-800); color: var(--soft); border: 1px solid var(--navy-600); }
.btn.secondary:hover { background: var(--navy-600); color: var(--ink); }

/* ---- Rig detail block ---- */
.rig-env {
  display: inline-block;
  font-size: 10px; font-weight: 800;
  color: #7de0ae;
  background: rgba(80, 200, 140, 0.12);
  padding: 3px 9px; border-radius: 10px;
  text-transform: uppercase; letter-spacing: 0.9px;
  margin-bottom: 8px;
}
.rig-name { font-size: 17px; font-weight: 800; color: var(--ink); margin-bottom: 10px; }
.rig-name a { color: var(--ink); text-decoration: none; border-bottom: 1px dotted var(--navy-600); }
.rig-name a:hover { color: var(--gold); border-bottom-color: var(--gold); }
.rig-name-arrow { color: var(--gold); font-weight: 600; margin-left: 3px; }

.rig-spec { width: 100%; border-collapse: collapse; margin-bottom: 10px; font-size: 13px; }
.rig-spec td { padding: 7px 10px; border-bottom: 1px solid var(--navy-600); vertical-align: top; }
.rig-spec tr:last-child td { border-bottom: none; }
.rig-spec td.l { width: 110px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.8px; font-size: 10px; font-weight: 700; padding-top: 9px; }
.rig-spec td.v { color: var(--ink); font-weight: 600; }

.rig-bait {
  background: rgba(80, 200, 140, 0.10);
  border-left: 3px solid #50c88c;
  padding: 9px 12px;
  border-radius: 4px;
  font-size: 13px; color: var(--soft);
  margin-top: 4px;
}
.rig-bait strong {
  color: #7de0ae;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  font-weight: 800;
  display: block;
  margin-bottom: 2px;
}

/* ---- Related spots grid ---- */
.related { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; }
.related-card {
  background: var(--navy-800);
  border: 1px solid var(--navy-600);
  border-radius: 10px;
  padding: 12px;
  transition: border-color 0.15s;
}
.related-card:hover { border-color: var(--teal-lt); }
.related-card a { color: var(--ink); font-weight: 700; font-size: 13px; text-decoration: none; }
.related-card .area { font-size: 10px; margin-bottom: 0; margin-top: 2px; letter-spacing: 1px; }
.related-card .dist { font-size: 11px; color: var(--teal-lt); margin-top: 4px; font-weight: 700; }

/* ---- Footer ---- */
footer {
  max-width: 860px;
  margin: 40px auto 0;
  padding: 16px 20px;
  border-top: 1px solid var(--navy-600);
  font-size: 11px; color: var(--muted);
  text-align: center;
}
footer a { color: var(--muted); }
