/* Knepper's Alaska Fishcamp — Morning Brief
   Fishcamp25 palette, inverted · dark instrument-cluster theme.
   Modeled on premium-EV night dashboards. Private tool — not public-brand voice.
*/

:root {
  /* Cook Inlet ocean palette — sampled from a dark sea-surface photograph.
     Restrained, monochromatic, no electric cyan. The "lit instrument" feel
     comes from depth and blur, not bright glow accents. (Redesign 2026-06-02) */
  --ink:    #0A1620;   /* page background — deepest water shadow */
  --navy:   #122332;   /* card surfaces — lifted slightly from background */
  --steel:  #5A7585;   /* secondary text, ticks — wave-trough slate */
  --powder: #D2DCE3;   /* primary text — wave crest, slate-grey not powder-blue */
  --teal:   #3D6D85;   /* base teal stroke — muted, mid-water */
  --snow:   #F0F5F8;   /* brightest highlight — spray */

  --glow:        #5E96AD;   /* accent glow — slate-blue reflection, not cyan */
  --glow-strong: #88B8CB;   /* lit accent — soft sea-spray */

  --warn:        #B07050;   /* advisories — muted ochre */
  --warn-glow:   #D49770;   /* lit warn — soft amber */

  --ink-90:    rgba(10, 22, 32, 0.90);
  --navy-60:   rgba(18, 35, 50, 0.60);
  --steel-08:  rgba(90, 117, 133, 0.08);
  --steel-15:  rgba(90, 117, 133, 0.15);
  --steel-25:  rgba(90, 117, 133, 0.25);
  --steel-40:  rgba(90, 117, 133, 0.40);
  --powder-90: rgba(210, 220, 227, 0.90);
  --powder-60: rgba(210, 220, 227, 0.60);
  --powder-30: rgba(210, 220, 227, 0.30);

  --font-display: 'Inter Tight', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-body:    'Inter Tight', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--ink);
  color: var(--powder);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  min-height: 100vh;
}

/* Ambient glow behind everything — the "lit panel" feeling */
.amb {
  position: fixed;
  inset: -10vmax;
  z-index: -1;
  background:
    radial-gradient(ellipse 80% 50% at 30% 15%, rgba(61, 109, 133, 0.10), transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 90%, rgba(18, 35, 50, 0.40), transparent 60%),
    var(--ink);
  pointer-events: none;
}

/* ----- MASTHEAD ----- */

.masthead {
  max-width: 1280px;
  margin: 0 auto;
  padding: 28px 24px 8px;
}

.masthead__line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--steel);
}

.masthead__eyebrow { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; }

.dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--glow-strong);
  box-shadow: 0 0 8px var(--glow), 0 0 14px var(--glow-strong);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.4; transform: scale(0.85); }
}

.masthead__clock {
  letter-spacing: 0.10em;
  color: var(--powder-90);
}

.masthead__moon {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.10em;
  color: var(--steel);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}
.moon-glyph {
  font-size: 14px;
  color: var(--powder-60);
  line-height: 1;
}
.moon-glyph.moon-strong { color: var(--glow-strong); text-shadow: 0 0 6px var(--glow); }
.moon-name { color: var(--powder-60); }
.moon-ill { color: var(--steel); font-variant-numeric: tabular-nums; }

@media (max-width: 640px) {
  .moon-name { display: none; }
}

.masthead__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2.4rem, 7vw, 4rem);
  letter-spacing: -0.035em;
  color: var(--powder);
  margin: 8px 0 14px;
  line-height: 1.0;
  text-shadow: 0 0 22px rgba(94, 150, 173, 0.08);
}

/* ===== VERDICT — captain's one-liner ===== */

.verdict {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 12px;
  padding: 14px 18px;
  margin: 0 0 14px;
  background:
    radial-gradient(ellipse 90% 100% at 0% 50%, rgba(94, 150, 173, 0.10), transparent 60%),
    linear-gradient(90deg, rgba(18, 35, 50, 0.6), rgba(10, 22, 32, 0.4));
  border: 1px solid var(--steel-25);
  border-left: 2px solid var(--glow);
  border-radius: 3px;
  font-family: var(--font-mono);
}

.verdict__tone {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--glow-strong);
  text-shadow: 0 0 10px var(--glow);
  white-space: nowrap;
}

.verdict__text {
  font-size: 14.5px;
  color: var(--powder-90);
  line-height: 1.4;
  letter-spacing: 0.01em;
}

.verdict[data-tone="calm"]     { border-left-color: var(--glow-strong); }
.verdict[data-tone="calm"]     .verdict__tone { color: var(--glow-strong); }

.verdict[data-tone="workable"] { border-left-color: var(--glow); }
.verdict[data-tone="workable"] .verdict__tone { color: var(--glow); }

.verdict[data-tone="rough"],
.verdict[data-tone="advisory"] {
  border-left-color: var(--warn-glow);
  background:
    radial-gradient(ellipse 90% 100% at 0% 50%, rgba(212, 151, 112, 0.10), transparent 60%),
    linear-gradient(90deg, rgba(18, 35, 50, 0.6), rgba(10, 22, 32, 0.4));
}
.verdict[data-tone="rough"]    .verdict__tone,
.verdict[data-tone="advisory"] .verdict__tone {
  color: var(--warn-glow);
  text-shadow: 0 0 10px var(--warn);
}

.verdict[data-tone="dark"] { border-left-color: var(--steel-40); }
.verdict[data-tone="dark"] .verdict__tone { color: var(--steel); text-shadow: none; }

.masthead__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-top: 10px;
  margin-top: 10px;
  border-top: 1px solid var(--steel-25);
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: var(--steel);
}

.masthead__meta [data-status] {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.masthead__refresh {
  border: 1px solid var(--steel-40);
  background: transparent;
  color: var(--powder);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-family: var(--font-mono);
  font-size: 17px;
  cursor: pointer;
  transition: background 220ms ease, border-color 220ms ease, transform 600ms ease, box-shadow 220ms ease;
}
.masthead__refresh:hover {
  background: var(--steel-08);
  border-color: var(--glow);
  box-shadow: 0 0 12px rgba(94, 150, 173, 0.30);
}
.masthead__refresh.is-spinning { animation: spin 900ms ease-in-out; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ----- GRID ----- */

.grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 16px 24px 40px;
  display: grid;
  gap: 18px;
  grid-template-columns: 1fr;
}

@media (min-width: 900px) {
  .grid {
    grid-template-columns: 1fr 1fr;
    gap: 22px;
    padding: 26px 24px 60px;
  }
  /* Fish is the news — give it the full row. */
  .card--fish { grid-column: 1 / -1; }
}

/* ----- CARD ----- */

.card {
  position: relative;
  background:
    radial-gradient(ellipse 90% 70% at 50% 0%, rgba(94, 150, 173, 0.025), transparent 60%),
    linear-gradient(180deg, var(--navy) 0%, rgba(18, 35, 50, 0.80) 100%);
  border: 1px solid var(--steel-15);
  border-radius: 5px;
  padding: 20px 20px 22px;
  overflow: hidden;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.03) inset,
    0 22px 44px -16px rgba(0, 0, 0, 0.40);
}

/* top highlight rail — glassy embossed feel */
.card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--powder-30), transparent);
}

.card--backup {
  opacity: 0.82;
}

.card__head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: 12px;
  padding-bottom: 14px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--steel-15);
}

.card__index {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  color: var(--steel);
  letter-spacing: 0.12em;
}

.card__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.3rem;
  letter-spacing: -0.015em;
  color: var(--powder);
  margin: 0;
}

.card__sub {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--steel);
  text-align: right;
}

@media (max-width: 480px) {
  .card__head { grid-template-columns: auto 1fr; }
  .card__sub  { grid-column: 1 / -1; text-align: left; padding-top: 2px; }
}

.card__placeholder {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--steel);
  margin: 0;
}

.card__error {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--warn-glow);
  margin: 0;
  padding: 10px 12px;
  background: rgba(176, 112, 80, 0.06);
  border: 1px solid rgba(176, 112, 80, 0.30);
  border-radius: 3px;
}

/* ============================================================
   GAUGE — shared circular instrument
   ============================================================ */

.gauge {
  position: relative;
  width: 100%;
  max-width: 260px;
  aspect-ratio: 1 / 1;
  margin: 0 auto;
}

.gauge svg { width: 100%; height: 100%; display: block; }

.gauge .arc-track { fill: none; stroke: var(--steel-15); stroke-linecap: round; }
.gauge .arc-fill  {
  fill: none;
  stroke: var(--glow);
  stroke-linecap: round;
  filter: drop-shadow(0 0 4px rgba(94, 150, 173, 0.5));
  stroke-dashoffset: var(--arc-target-offset, 0);
  animation: arc-sweep 1100ms cubic-bezier(.2,.7,.2,1) both;
}
@keyframes arc-sweep {
  from { stroke-dasharray: 0 9999; }
  to   { /* keeps the dasharray set by inline attribute */ }
}

@media (prefers-reduced-motion: reduce) {
  .gauge .arc-fill { animation: none; }
  .dot { animation: none; }
}
.gauge .tick      { stroke: var(--steel-40); }
.gauge .tick-lit  { stroke: var(--glow); filter: drop-shadow(0 0 3px var(--glow)); }
.gauge .tick-major { stroke: var(--powder-60); }

.gauge__center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.gauge__primary {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: clamp(1.8rem, 6vw, 2.6rem);
  letter-spacing: -0.02em;
  color: var(--powder);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 18px rgba(94, 150, 173, 0.2);
}

.gauge__primary--small { font-size: clamp(1.4rem, 5vw, 2rem); }

.gauge__unit {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  color: var(--steel);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-top: 4px;
}

.gauge__label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 500;
  color: var(--glow);
  letter-spacing: 0.20em;
  text-transform: uppercase;
  margin-top: 2px;
  text-shadow: 0 0 6px rgba(94, 150, 173, 0.5);
}

/* ============================================================
   TIDES card — sine curve
   ============================================================ */

.tides {
  display: grid;
  gap: 16px;
}

.tides__hero {
  display: grid;
  gap: 12px;
}

.tides__stage-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.tides__stage {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 2px;
  border: 1px solid var(--steel-25);
}
.tides__stage::before {
  content: "";
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--steel);
}
.tides__stage--flooding { color: var(--glow); border-color: rgba(94, 150, 173, 0.3); }
.tides__stage--flooding::before { background: var(--glow); box-shadow: 0 0 6px var(--glow); }
.tides__stage--ebbing   { color: var(--steel); }
.tides__stage--slack {
  color: var(--glow-strong);
  border-color: rgba(136, 184, 203, 0.4);
  background: rgba(94, 150, 173, 0.06);
}
.tides__stage--slack::before { background: var(--glow-strong); box-shadow: 0 0 8px var(--glow-strong); }
.tides__stage--slack.tides__stage--high {
  border-color: rgba(136, 184, 203, 0.6);
  background: rgba(94, 150, 173, 0.10);
}

.tides__range {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--steel);
  padding: 4px 9px;
  border-radius: 2px;
  border: 1px solid var(--steel-15);
}
.tides__range--neap     { color: var(--glow); border-color: rgba(94, 150, 173, 0.35); }
.tides__range--moderate { color: var(--powder-60); }
.tides__range--spring   { color: var(--warn-glow); border-color: rgba(212, 151, 112, 0.40); }

.tides__hero-meta {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.tides__next {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}

.tides__next-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--glow);
}

.tides__next-time {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 1.9rem;
  color: var(--powder);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  letter-spacing: -0.02em;
}

.tides__next-height {
  font-family: var(--font-mono);
  font-size: 1rem;
  color: var(--powder-60);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}

.tides__next-countdown {
  font-family: var(--font-mono);
  font-size: 12.5px;
  font-weight: 600;
  color: var(--glow-strong);
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  padding: 4px 10px;
  border: 1px solid rgba(136, 184, 203, 0.30);
  border-radius: 3px;
  white-space: nowrap;
}

.tide-curve {
  width: 100%;
  background: linear-gradient(180deg, rgba(94, 150, 173, 0.04), transparent 70%);
  border-radius: 4px;
  padding: 6px 0 0;
}
.tide-curve svg { width: 100%; height: auto; display: block; }
.tide-curve__marker {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 600;
  fill: var(--powder-90);
  letter-spacing: 0.04em;
}
.tide-curve__now {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.18em;
  fill: var(--glow-strong);
  text-transform: uppercase;
}
.tide-curve__hour {
  font-family: var(--font-mono);
  font-size: 9px;
  fill: var(--steel);
  letter-spacing: 0.06em;
}

.tides__events {
  list-style: none;
  margin: 0;
  padding: 14px 0 0;
  border-top: 1px solid var(--steel-15);
  display: grid;
  gap: 6px;
}

.tide-row {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 14px;
  align-items: baseline;
  padding: 4px 0;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.tide-row__tag {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--steel);
}
.tide-row[data-type="H"] .tide-row__tag { color: var(--powder); }
.tide-row[data-type="L"] .tide-row__tag { color: var(--glow); }

.tide-row__when { font-size: 13.5px; color: var(--powder-90); }
.tide-row__day  { font-size: 11px; color: var(--steel); letter-spacing: 0.08em; padding-right: 6px; }
.tide-row__h    { font-size: 13.5px; color: var(--powder); text-align: right; }

.tide-row.is-past { opacity: 0.35; }
.tide-row.is-next .tide-row__when {
  color: var(--glow-strong);
  text-shadow: 0 0 8px rgba(136, 184, 203, 0.3);
}
.tide-row.is-next .tide-row__h { color: var(--glow-strong); }

/* ============================================================
   MARINE card — Now (live obs) + simplified forecast strip
   ============================================================ */

.marine {
  display: grid;
  gap: 18px;
}

.marine-now {
  display: grid;
  gap: 12px;
}

.marine-now__head {
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.marine-now__label {
  color: var(--glow);
  font-weight: 700;
  letter-spacing: 0.20em;
}
.marine-now__source { color: var(--steel); flex: 1; min-width: 0; }
.marine-now__stamp  { color: var(--powder-60); font-variant-numeric: tabular-nums; }

.marine-now__row {
  display: grid;
  grid-template-columns: 72px auto 1fr;
  gap: 16px;
  align-items: center;
}

.compact-compass {
  width: 72px;
  height: 72px;
}
.compact-compass svg { width: 100%; height: 100%; display: block; }

.marine-now__wind {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.marine-now__wind-line {
  display: flex;
  align-items: baseline;
  gap: 6px;
}

.marine-now__wind-dir {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 16px;
  color: var(--glow);
  letter-spacing: 0.06em;
  min-width: 32px;
}

.marine-now__wind-speed {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 2.2rem;
  color: var(--powder);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.03em;
  line-height: 1;
}

.marine-now__wind-unit {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--steel);
  letter-spacing: 0.10em;
  text-transform: uppercase;
}

.marine-now__wind-gust {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--warn-glow);
  letter-spacing: 0.06em;
}

.marine-now__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 18px;
  align-items: baseline;
  justify-content: flex-end;
}

.marine-now__stat {
  display: flex;
  align-items: baseline;
  gap: 4px;
  font-family: var(--font-mono);
}
.marine-now__stat-value {
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--powder-90);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.marine-now__stat-unit {
  font-size: 10px;
  color: var(--steel);
  letter-spacing: 0.10em;
  text-transform: uppercase;
}
.marine-now__stat-label {
  font-size: 10px;
  color: var(--steel);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-left: 2px;
}

.marine-now__pressure--fall .marine-now__stat-value,
.marine-now__pressure--fall .marine-now__stat-unit { color: var(--glow-strong); }
.marine-now__pressure--fall .marine-now__stat-label::after { content: " · fish on"; color: var(--glow-strong); }
.marine-now__pressure--rise .marine-now__stat-value,
.marine-now__pressure--rise .marine-now__stat-unit { color: var(--warn-glow); }

.marine-now__stat--halibut .marine-now__stat-value { color: var(--glow-strong); }
.marine-now__stat--halibut .marine-now__stat-label { color: var(--glow); }

@media (max-width: 520px) {
  .marine-now__row { grid-template-columns: 60px 1fr; }
  .compact-compass { width: 60px; height: 60px; }
  .marine-now__stats { grid-column: 1 / -1; justify-content: flex-start; }
}

.marine__advisory {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--warn-glow);
  background:
    linear-gradient(90deg, rgba(176, 112, 80, 0.18), rgba(176, 112, 80, 0.06));
  border: 1px solid rgba(212, 151, 112, 0.50);
  border-left: 2px solid var(--warn-glow);
  padding: 10px 14px;
  margin: 0;
  border-radius: 3px;
  text-shadow: 0 0 8px rgba(176, 112, 80, 0.50);
  animation: advisory-pulse 3s ease-in-out infinite;
}
@keyframes advisory-pulse {
  0%, 100% { box-shadow: 0 0 0 rgba(212, 151, 112, 0); }
  50%      { box-shadow: 0 0 22px rgba(212, 151, 112, 0.18); }
}
@media (prefers-reduced-motion: reduce) {
  .marine__advisory { animation: none; }
}

.marine__issued {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--steel);
  margin: 4px 0 0;
}

/* Lite (backup) marine card — text-only period rows, no compass, no bars.
   Used for Kachemak where the captain just needs a glance at the south side. */
.marine--lite {
  display: grid;
  gap: 12px;
}
.marine--lite .marine__issued {
  margin: 0;
}
.marine__lines {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 2px;
}
.marine-line {
  display: grid;
  grid-template-columns: 90px 36px 1fr 56px;
  align-items: baseline;
  gap: 12px;
  padding: 7px 4px;
  border-top: 1px solid var(--steel-15);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.marine-line:first-child { border-top: none; }
.marine-line__period {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--powder-90);
}
.marine-line__dir {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--glow);
}
.marine-line__speed {
  font-size: 13px;
  color: var(--powder);
  font-weight: 600;
}
.marine-line__unit {
  font-size: 9px;
  color: var(--steel);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  margin-left: 2px;
}
.marine-line__seas {
  font-size: 12px;
  color: var(--powder-60);
  text-align: right;
}
.marine-line--rough .marine-line__speed { color: var(--warn-glow); }

.marine__forecast {
  padding-top: 14px;
  border-top: 1px solid var(--steel-15);
}

.marine__forecast-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: 8px;
}
.marine__scale { color: var(--powder-60); }

.marine__bars {
  display: grid;
  gap: 4px;
}

.wind-bar {
  display: grid;
  grid-template-columns: 80px 32px 1fr 64px 42px;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.wind-bar__period {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--powder-90);
}

.wind-bar__dir {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--glow);
  text-align: center;
}

.wind-bar__track {
  position: relative;
  height: 6px;
  background: var(--steel-08);
  border-radius: 2px;
  overflow: hidden;
}

.wind-bar__fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: linear-gradient(90deg, var(--teal), var(--glow));
  transition: width 800ms cubic-bezier(.2,.7,.2,1);
}

.wind-bar--rough .wind-bar__fill {
  background: linear-gradient(90deg, var(--warn), var(--warn-glow));
}

.wind-bar__speed {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--powder);
  text-align: right;
}
.wind-bar__unit {
  font-size: 9px;
  color: var(--steel);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  margin-left: 2px;
}
.wind-bar__gust {
  color: var(--warn-glow);
  font-size: 10.5px;
  font-weight: 500;
}

.wind-bar__seas {
  font-size: 11.5px;
  color: var(--powder-60);
  text-align: right;
}

@media (max-width: 520px) {
  .wind-bar {
    grid-template-columns: 68px 28px 1fr 56px 38px;
    gap: 7px;
  }
  .wind-bar__period { font-size: 9.5px; }
}

/* compass tick variants */
.compass-cardinal {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  fill: var(--powder-60);
  letter-spacing: 0.05em;
}
.compass-cardinal--lit { fill: var(--glow-strong); }

/* ============================================================
   FISH card — leaderboard rows (no gauges, numbers do the work)
   ============================================================ */

.fish-list {
  display: grid;
  gap: 0;
}

.fish-row {
  display: grid;
  grid-template-columns: minmax(150px, 1.3fr) 120px minmax(110px, auto) minmax(140px, 1fr);
  align-items: center;
  gap: 18px;
  padding: 13px 6px;
  border-top: 1px solid var(--steel-15);
  position: relative;
}
.fish-row:first-child { border-top: none; padding-top: 2px; }

.fish-row__spark {
  display: flex;
  align-items: center;
  justify-content: center;
}
.spark { display: inline-block; vertical-align: middle; }
.spark--empty { background: var(--steel-08); border-radius: 2px; }

.fish-row--home {
  background: linear-gradient(90deg, rgba(94, 150, 173, 0.10), rgba(94, 150, 173, 0.02) 70%);
  margin: 0 -6px;
  padding-left: 16px;
  padding-right: 12px;
  border-radius: 3px;
}
.fish-row--home::before {
  content: "";
  position: absolute;
  left: 0; top: 10px; bottom: 10px;
  width: 3px;
  background: var(--glow);
  box-shadow: 0 0 10px rgba(94, 150, 173, 0.55);
  border-radius: 2px;
}

.fish-row__label {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.fish-row__river {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--powder);
  letter-spacing: -0.01em;
  line-height: 1;
}

.fish-row__species {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--steel);
}

.fish-row--home .fish-row__species {
  color: var(--glow);
}

.fish-row__home-tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 8.5px;
  font-weight: 700;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--glow);
  border: 1px solid rgba(94, 150, 173, 0.35);
  padding: 1px 6px;
  border-radius: 2px;
  margin-left: 6px;
  vertical-align: 2px;
}

.fish-row__number {
  font-family: var(--font-mono);
  font-size: clamp(1.7rem, 3.5vw, 2.4rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--powder);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  text-align: right;
  white-space: nowrap;
}
.fish-row__number--zero { color: var(--steel-40); text-shadow: none; }
.fish-row__number--small { font-size: clamp(1.1rem, 3vw, 1.4rem); }
.fish-row__number-unit {
  font-size: 0.5em;
  font-weight: 500;
  color: var(--glow);
  margin-left: 2px;
  letter-spacing: 0.05em;
  vertical-align: 0.35em;
}
.fish-row__error { color: var(--warn-glow); font-size: 13px; font-weight: 500; }

/* Slim off-season variant — no sparkline, no big number; just text. */
.fish-row--slim {
  grid-template-columns: minmax(150px, 1.3fr) 1fr;
  align-items: center;
  padding: 10px 6px;
  font-family: var(--font-mono);
}
.fish-row--slim .fish-row__river  { font-size: 1rem; }
.fish-row--slim .fish-row__species { font-size: 10px; }

.fish-row__slim-meta {
  display: flex;
  justify-content: flex-end;
  align-items: baseline;
  gap: 18px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--steel);
  letter-spacing: 0.04em;
  text-align: right;
}
.fish-row__slim-meta strong {
  color: var(--powder);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.fish-row__slim-status {
  font-size: 10.5px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--steel-40, var(--steel));
}

@media (max-width: 820px) {
  .fish-row--slim {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    gap: 4px;
  }
  .fish-row__slim-meta { justify-content: flex-start; text-align: left; }
}

.fish-row__meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--steel);
  text-align: right;
}
.fish-row__meta strong {
  color: var(--powder-90);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

.fish-row__delta { font-weight: 600; letter-spacing: 0.04em; }
.fish-row__delta--up   { color: var(--glow-strong); }
.fish-row__delta--down { color: var(--warn-glow); }
.fish-row__delta--flat { color: var(--steel); }

.fish-row__error {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--warn-glow);
}

@media (max-width: 820px) {
  .fish-row {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto auto;
    gap: 8px 14px;
    padding: 14px 6px;
  }
  .fish-row__label  { grid-row: 1; grid-column: 1; }
  .fish-row__number { grid-row: 1; grid-column: 2; }
  .fish-row__spark  { grid-row: 2; grid-column: 1 / -1; justify-content: flex-start; }
  .fish-row__meta   { grid-row: 3; grid-column: 1 / -1; text-align: left; flex-direction: row; flex-wrap: wrap; gap: 4px 12px; }
  .fish-row__spark .spark { width: 100% !important; max-width: 220px; }
}

/* ============================================================
   TIDE BOOK — week-flip grid
   ============================================================ */

.tidebook {
  max-width: 1280px;
  margin: 0 auto;
  padding: 6px 24px 0;
}

.tidebook__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding: 0 4px 12px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--steel-15);
}

.tidebook__title-block {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
  min-width: 0;
}

.tidebook__index {
  font-size: 18px;
  color: var(--glow);
  line-height: 1;
}

.tidebook__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: -0.015em;
  color: var(--powder);
  margin: 0;
}

.tidebook__sub {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--steel);
}

.tidebook__nav {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.tidebook__btn {
  background: transparent;
  border: 1px solid var(--steel-25);
  color: var(--powder-90);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 3px;
  cursor: pointer;
  transition: background 220ms ease, border-color 220ms ease, color 220ms ease;
}
.tidebook__btn:hover {
  border-color: var(--glow);
  color: var(--glow-strong);
  background: rgba(94, 150, 173, 0.06);
}
.tidebook__btn--today {
  padding: 6px 14px;
}

.tidebook__grid {
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr;
  padding-top: 12px;
}

@media (min-width: 720px) {
  .tidebook__grid { grid-template-columns: repeat(7, 1fr); gap: 6px; }
}

.tidebook-day {
  background:
    linear-gradient(180deg, var(--navy) 0%, rgba(18, 35, 50, 0.85) 100%);
  border: 1px solid var(--steel-15);
  border-radius: 4px;
  padding: 12px 12px 14px;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
}

.tidebook-day--today {
  border-color: var(--glow);
  background:
    radial-gradient(ellipse 90% 70% at 50% 0%, rgba(94, 150, 173, 0.10), transparent 60%),
    linear-gradient(180deg, var(--navy) 0%, rgba(18, 35, 50, 0.85) 100%);
}
.tidebook-day--today::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--glow), transparent);
}

.tidebook-day--neap   { border-top: 2px solid rgba(94, 150, 173, 0.50); }
.tidebook-day--spring { border-top: 2px solid rgba(212, 151, 112, 0.50); }

.tidebook-day__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.tidebook-day__head-left {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.tidebook-day__head-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
}

/* ---- Halibut fish-rating glyphs ---- */
.fish-rating {
  display: inline-flex;
  align-items: center;
  gap: 2px;
}

.fish-pip {
  display: inline-block;
  width: 13px;
  height: 6px;
  line-height: 0;
}
.fish-pip .fish-glyph {
  width: 100%;
  height: 100%;
  display: block;
}
.fish-pip .fish-glyph path { fill: currentColor; }

.fish-pip--lit   { color: var(--glow-strong); }
.fish-pip--unlit { color: var(--steel-15); }

/* Today's day cell — lit fish get a small halo */
.tidebook-day--today .fish-pip--lit .fish-glyph path {
  filter: drop-shadow(0 0 2px var(--glow));
}

.tidebook-day__dow {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--steel);
}
.tidebook-day--today .tidebook-day__dow { color: var(--glow); }

.tidebook-day__date {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--powder);
  letter-spacing: -0.01em;
  line-height: 1.1;
}

.tidebook-day__range {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: 2px 6px;
  border-radius: 2px;
  border: 1px solid var(--steel-15);
  color: var(--steel);
  white-space: nowrap;
}
.tidebook-day__range--neap     { color: var(--glow);      border-color: rgba(94, 150, 173, 0.35); }
.tidebook-day__range--moderate { color: var(--powder-60); }
.tidebook-day__range--spring   { color: var(--warn-glow); border-color: rgba(212, 151, 112, 0.40); }

.tidebook-day__events {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 4px;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.tidebook-day__event {
  display: grid;
  grid-template-columns: 16px 1fr auto;
  align-items: baseline;
  gap: 6px;
  font-size: 11.5px;
  color: var(--powder-90);
  padding: 2px 0;
}

.tidebook-day__event-tag {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--steel);
}
.tidebook-day__event--high .tidebook-day__event-tag { color: var(--powder); }
.tidebook-day__event--low  .tidebook-day__event-tag { color: var(--glow); }

.tidebook-day__event-time { font-size: 11.5px; }
.tidebook-day__event-ft   { font-size: 11.5px; color: var(--powder); }
.tidebook-day__event-unit { font-size: 8.5px; color: var(--steel); letter-spacing: 0.10em; margin-left: 1px; }
.tidebook-day__event--empty { color: var(--steel); grid-template-columns: 1fr; text-align: center; }

/* ============================================================
   CHATTER — What's popping (RSS feed)
   ============================================================ */

.card--chatter { /* lives in row 3, right column on desktop, next to Kachemak */ }

.chatter {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 2px;
}

.chatter__row {
  border-top: 1px solid var(--steel-15);
  margin: 0;
}
.chatter__row:first-child { border-top: none; }

.chatter__link {
  display: block;
  padding: 10px 6px;
  text-decoration: none;
  color: inherit;
  border-radius: 3px;
  transition: background 180ms ease, transform 180ms ease;
}
.chatter__link:hover {
  background: rgba(94, 150, 173, 0.06);
  transform: translateX(2px);
}

.chatter__meta {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 4px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.chatter__source {
  font-weight: 700;
  color: var(--glow);
  padding: 1px 5px;
  border: 1px solid rgba(94, 150, 173, 0.35);
  border-radius: 2px;
}

.chatter__row--forums .chatter__source {
  color: var(--warn-glow);
  border-color: rgba(212, 151, 112, 0.35);
}

.chatter__when {
  color: var(--steel);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.08em;
}

.chatter__title {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.35;
  color: var(--powder-90);
  letter-spacing: -0.005em;
}
.chatter__link:hover .chatter__title { color: var(--powder); }

/* ----- RESOURCES STRIP ----- */

.resources {
  max-width: 1280px;
  margin: 0 auto;
  padding: 6px 24px 0;
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .resources { grid-template-columns: 1fr 1fr; }
}

.resource {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background:
    linear-gradient(180deg, var(--navy) 0%, rgba(18, 35, 50, 0.80) 100%);
  border: 1px solid var(--steel-15);
  border-radius: 4px;
  color: var(--powder);
  text-decoration: none;
  font-family: var(--font-mono);
  transition: border-color 220ms ease, background 220ms ease, transform 180ms ease;
}
.resource:hover {
  border-color: var(--glow);
  background:
    radial-gradient(ellipse 50% 100% at 0% 50%, rgba(94, 150, 173, 0.10), transparent 60%),
    linear-gradient(180deg, var(--navy) 0%, rgba(18, 35, 50, 0.80) 100%);
  transform: translateY(-1px);
}

.resource__icon {
  font-size: 22px;
  line-height: 1;
  color: var(--glow);
  text-align: center;
}

.resource__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.resource__title {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--powder);
}

.resource__sub {
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--steel);
}

.resource__arrow {
  font-size: 14px;
  color: var(--steel);
  transition: color 220ms ease, transform 220ms ease;
}
.resource:hover .resource__arrow {
  color: var(--glow-strong);
  transform: translate(2px, -2px);
}

/* ----- FOOTER ----- */

.footnotes {
  max-width: 1280px;
  margin: 0 auto;
  padding: 24px 24px 40px;
  text-align: center;
}
.footnotes p { margin: 0; }

.axiom {
  font-family: var(--font-display);
  font-size: 13px;
  font-style: italic;
  font-weight: 400;
  color: var(--steel);
  letter-spacing: 0.01em;
  line-height: 1.5;
  max-width: 32ch;
  margin: 0 auto;
  opacity: 0.75;
}
.axiom::before { content: "“ "; color: var(--glow); opacity: 0.6; }
.axiom::after  { content: " ”"; color: var(--glow); opacity: 0.6; }

/* ----- PRINT ----- */

@media print {
  :root { color-scheme: light; }
  body, .amb { background: white !important; color: black; }
  .amb { display: none; }
  .masthead__refresh, .footnotes { display: none; }
  .card {
    background: white !important;
    box-shadow: none;
    border: 1px solid #0A1620;
    page-break-inside: avoid;
  }
  .gauge .arc-fill { filter: none; stroke: #0A1620; }
  .gauge__primary, .card__title, .masthead__title { color: #0A1620; text-shadow: none; }
  .grid { gap: 12px; padding: 12px 0; }
}
