/* ============================================================
   LIGHTCAST — INDEX.CSS
   Styles specific to index.html only.
   Requires base.css to be loaded first.
   ============================================================ */


/* ── FULL-BLEED HERO ─────────────────────────────────────── */

/* Pre-search: body gets .hero-mode — nav floats over gradient */
body.hero-mode .nav-wrap {
  position: absolute;
  top: 0; left: 0; right: 0;
  z-index: 20;
  padding: 1.4rem 2rem 0;
  background: transparent !important;
}

/* Post-search: nav returns to normal flow */
body:not(.hero-mode) .nav-wrap {
  position: relative;
}

.hero-fullbleed {
  position: relative;
  width: 100%;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 0 1.5rem 3rem;
}

/* Photo background — swap background-image to use a real photo */
.hero-photo-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 130% 50% at 50% 100%, rgba(245,180,80,0.45) 0%, transparent 65%),
    radial-gradient(ellipse 90% 40% at 25% 100%, rgba(232,100,40,0.30) 0%, transparent 60%),
    radial-gradient(ellipse 90% 40% at 75% 100%, rgba(245,197,24,0.28) 0%, transparent 60%),
    linear-gradient(to bottom,
      #26202e 0%,
      #362838 25%,
      #4e3035 50%,
      #703a30 75%,
      #a05a38 100%);
  background-size: cover;
  background-position: center;
  z-index: 0;
}

/* Overlay — light at top to blend with page, just enough at base for text */
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(11,14,23,0.38) 0%,
    rgba(11,14,23,0.12) 30%,
    rgba(11,14,23,0.40) 65%,
    rgba(11,14,23,0.78) 100%
  );
  z-index: 1;
}

.hero-inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0;
  width: 100%;
  max-width: 680px;
  animation: fadeDown 1s ease both;
}

.hero-eyebrow {
  font-family: var(--mono);
  font-size: 0.48rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(246,242,234,0.45);
  margin-bottom: 1.1rem;
}

.hero-wordmark {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(3rem, 12vw, 7rem);
  letter-spacing: clamp(0.1em, 2.5vw, 0.32em);
  text-transform: uppercase;
  line-height: 1;
  margin-bottom: 1rem;
}
.hero-wordmark .light { color: var(--amber); }
.hero-wordmark .cast  { color: var(--star); }

.hero-tagline {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1rem, 3vw, 1.4rem);
  color: var(--muted);
  letter-spacing: 0.03em;
  margin-bottom: 2.2rem;
}

/* Search card inside hero */
.hero-search-card {
  width: 100%;
  background: rgba(10,8,6,0.55);
  border: 1px solid rgba(246,242,234,0.14);
  border-radius: 12px;
  padding: 1rem 1.1rem 0.85rem;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  position: relative;
  overflow: visible;
  margin-bottom: 1.2rem;
}

.hero-search-card::before {
  content: '';
  position: absolute;
  top: 0; left: 15%; right: 15%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,129,42,0.6), rgba(126,184,247,0.5), transparent);
}

.hero-search-row {
  display: flex;
  flex-direction: row;
  gap: 0.4rem;
  align-items: stretch;
}

/* City input — grows to fill space */
.hero-search-row .hub-search-inner {
  flex: 1 1 0;
  min-width: 0;
}

/* Uniform height for all controls — override hub-input's min-height:56px */
.hero-input,
.hero-date,
.hero-units {
  height: 44px !important;
  min-height: 44px !important;
  max-height: 44px !important;
  box-sizing: border-box;
  font-size: 0.7rem;
text-align: left;
}

/* City — readable placeholder size */
.hero-input {
  font-size: 0.85rem !important;
  padding: 0 1rem !important;
}

/* Date — compact fixed width */
.hero-date {
  flex: 0 0 130px;
  width: 130px;
}

/* Units — compact, readable font */
.hero-units {
  flex: 0 0 96px;
  width: 96px;
  font-size: 0.52rem;
  letter-spacing: 0.06em;
  padding-left: 0.55rem;
  padding-right: 1.6rem;
}

/* Forecast button — same height as every other control */
.hero-search-row .hub-search-btn {
  height: 44px !important;
  min-height: 44px !important;
  max-height: 44px !important;
  flex: 0 0 auto;
  box-sizing: border-box;
  font-size: 0.5rem;
}

@media (max-width: 640px) {
  .hero-search-row { flex-direction: column; gap: 0.35rem; }
  .hero-date, .hero-units { flex: none; width: 100%; }
  .hero-input,
  .hero-date,
  .hero-units { height: 46px !important; min-height: 46px !important; max-height: 46px !important; }
  .hero-search-row .hub-search-btn { height: 46px !important; min-height: 46px !important; max-height: 46px !important; width: 100% !important; }
}


/* ── COLLAPSED HERO (post-search) ────────────────────────── */
/* Sits directly under the nav — no sticky, no z-index fight.
   Visually merges with nav via matching bg and a single bottom border. */

.hero-collapsed {
  width: 100%;
  background: rgba(11,14,23,0.97);
  border-bottom: 1px solid rgba(246,242,234,0.1);
  animation: fadeDown 0.3s ease both;
}

.hero-collapsed__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0.6rem 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

/* Logo hidden in collapsed bar — nav already has it */
.hero-collapsed__logo {
  display: none;
}

/* Location + controls pill */
.hero-collapsed__search {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(246,242,234,0.12);
  border-radius: 8px;
  overflow: hidden;
  min-width: 0;
}

.hero-collapsed__location {
  font-family: var(--serif);
  font-style: normal;
  font-size: 0.9rem;
  color: var(--text);
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 0.5rem 0.9rem;
}

.hero-date--sm,
.hero-units--sm {
  height: 38px;
  font-size: 0.44rem;
  border: none;
  background: transparent;
  padding: 0 0.55rem;
  border-left: 1px solid rgba(246,242,234,0.1);
  border-radius: 0;
  color: var(--dimmed);
  flex-shrink: 0;
}

.hub-search-btn--sm {
  height: 36px !important;
  min-height: 36px !important;
  max-height: 36px !important;
  width: auto !important;
  font-size: 0.46rem;
  padding: 0 0.9rem;
  white-space: nowrap;
  flex: 0 0 auto !important;
  flex-shrink: 0;
  border-radius: 0 7px 7px 0;
  border: none;
  border-left: 1px solid rgba(246,242,234,0.1);
  box-sizing: border-box;
}

/* Clear button */
.hero-collapsed__inner .hub-reset-btn {
  flex-shrink: 0;
}

@media (max-width: 600px) {
  .hero-collapsed__inner {
    gap: 0.4rem;
    padding: 0.45rem 0.9rem;
    flex-wrap: nowrap;
  }
  .hero-date--sm, .hero-units--sm { display: none; }
  /* Edit and Clear must stay compact — never full width */
  .hub-search-btn--sm,
  .hero-collapsed__inner .hub-reset-btn {
    flex: 0 0 auto;
    width: auto !important;
    min-width: 0;
  }
  .hero-collapsed__search {
    flex: 1;
    min-width: 0;
  }
}


/* ── SCORE PILLS AS TABS ─────────────────────────────────── */

.hub-score-bar__pills--tabs {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
}

.hub-score-bar__pills--tabs .hub-score-pill {
  justify-content: center;
  padding: 0.6rem 0.5rem;
  border-radius: 8px;
  gap: 0.4rem;
  min-height: 48px;
}

/* Pill label text */
.hub-score-bar__pills--tabs .hub-score-pill__emoji {
  font-size: 1rem;
  line-height: 1;
}

.hub-score-bar__pills--tabs .hub-score-pill__name {
  font-size: 0.58rem;
  letter-spacing: 0.1em;
}

.hub-score-bar__pills--tabs .hub-score-pill__val {
  font-size: 1rem;
  font-weight: 500;
  margin-left: 0.15rem;
}

.hub-score-bar__pills--tabs .hub-score-pill.active {
  border-width: 1.5px;
}

.hub-score-pill--gold.active {
  border-color: rgba(232,129,42,0.7);
  background: rgba(232,129,42,0.12);
  color: var(--amber);
}
.hub-score-pill--star.active {
  border-color: rgba(126,184,247,0.7);
  background: rgba(126,184,247,0.1);
  color: var(--star);
}
.hub-score-pill--teal.active {
  border-color: rgba(45,212,191,0.7);
  background: rgba(45,212,191,0.1);
  color: var(--teal);
}

/* Mobile: keep name visible but shrink slightly */
@media (max-width: 480px) {
  .hub-score-bar__pills--tabs .hub-score-pill__name { font-size: 0.52rem; letter-spacing: 0.06em; }
  .hub-score-bar__pills--tabs .hub-score-pill__val  { font-size: 0.9rem; }
  .hub-score-bar__pills--tabs .hub-score-pill__emoji { font-size: 0.9rem; }
  .hub-score-bar__pills--tabs .hub-score-pill { padding: 0.5rem 0.3rem; min-height: 44px; }
}


/* ── EDITORIAL SPREADS ───────────────────────────────────── */

.hub-wrap {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1.5rem 3rem;
}

.editorial-spread {
  display: grid;
  grid-template-columns: 55% 45%;
  height: 300px;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 1px;
  border: 1px solid rgba(246,242,234,0.08);
  animation: fadeUp 0.8s ease both;
}

.editorial-spread--reverse {
  grid-template-columns: 45% 55%;
}

.editorial-spread__text {
  background: rgba(255,255,255,0.025);
  padding: 2rem 2.2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.75rem;
  position: relative;
}

.editorial-spread__image {
  background-size: cover;
  background-position: center;
  position: relative;
  width: 100%;
  height: 100%;
}


@media (max-width: 640px) {
  .editorial-spread {
    grid-template-columns: 1fr;
    height: auto;
  }
  .editorial-spread__image {
    aspect-ratio: 16 / 9;
    height: auto;
  }
  .editorial-spread--reverse .editorial-spread__image {
    order: 1;
  }
  .editorial-spread--reverse .editorial-spread__text {
    order: 0;
  }
}

/* Gradient placeholder backgrounds — replace with background-image for real photos */
.editorial-spread__image--gold {
  background: linear-gradient(135deg, #c8541a 0%, #e88a30 45%, #1a0d05 100%);
  background-image: url('../images/goldcast-spread.jpg');
  background-size: cover;
  background-position: center 30%;
}
.editorial-spread__image--star {
  background: linear-gradient(135deg, #05050f 0%, #0d0d3a 50%, #1a1a5a 100%);
  background-image: url('../images/starcast-spread.jpg');
  background-size: cover;
  background-position: center 30%;
}
.editorial-spread__image--teal {
  background: linear-gradient(135deg, #051a14 0%, #0e7c66 60%, #1fba9c22 100%);
  background-image: url('../images/dronecast-spread.jpg');
  background-size: cover;
  background-position: center 30%;
}
.editorial-spread__image--mono {
  background: linear-gradient(135deg, #0d0702 0%, #1a0b05 50%, #2a1a0a 100%);
  background-image: url('../images/tricast-spread.jpg');
  background-size: cover;
  background-position: center 30%;
}

/* Top accent per tool */
.editorial-spread--gold .editorial-spread__text::before,
.editorial-spread--star .editorial-spread__text::before,
.editorial-spread--teal .editorial-spread__text::before,
.editorial-spread--mono .editorial-spread__text::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
}
.editorial-spread--gold .editorial-spread__text::before { background: linear-gradient(90deg, var(--amber), transparent); }
.editorial-spread--star .editorial-spread__text::before { background: linear-gradient(90deg, var(--star), transparent); }
.editorial-spread--teal .editorial-spread__text::before { background: linear-gradient(90deg, var(--teal), transparent); }
.editorial-spread--mono .editorial-spread__text::before { background: linear-gradient(90deg, var(--gold), transparent); }

.editorial-spread__tag {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.65rem;
  border-radius: 20px;
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  width: fit-content;
}
.editorial-spread__tag--gold { border: 1px solid rgba(232,129,42,0.4); color: var(--amber); background: rgba(232,129,42,0.08); }
.editorial-spread__tag--star { border: 1px solid rgba(126,184,247,0.4); color: var(--star);  background: rgba(126,184,247,0.08); }
.editorial-spread__tag--teal { border: 1px solid rgba(45,212,191,0.4);  color: var(--teal);  background: rgba(45,212,191,0.08); }
.editorial-spread__tag--mono { border: 1px solid rgba(246,242,234,0.2); color: var(--muted); background: rgba(255,255,255,0.04); }

.editorial-spread__title {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(1.3rem, 3vw, 1.7rem);
  letter-spacing: 0.02em;
  color: var(--text);
  line-height: 1.25;
}

.editorial-spread__desc {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 0.92rem;
  line-height: 1.7;
  color: var(--muted);
  max-width: 34ch;
}

.editorial-spread__link {
  font-family: var(--mono);
  font-size: 0.5rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  margin-top: 0.25rem;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  transition: opacity 0.2s;
}
.editorial-spread__link:hover { opacity: 0.75; }
.editorial-spread__link--gold { color: var(--amber); }
.editorial-spread__link--star { color: var(--star); }
.editorial-spread__link--teal { color: var(--teal); }
.editorial-spread__link--mono { color: var(--muted); }

/* Stagger animation for spreads */
.editorial-spread:nth-child(1) { animation-delay: 0.1s; }
.editorial-spread:nth-child(2) { animation-delay: 0.2s; }
.editorial-spread:nth-child(3) { animation-delay: 0.3s; }
.editorial-spread:nth-child(4) { animation-delay: 0.4s; }

/* Post-search spreads section */
.editorial-spreads-postsearch {
  margin-top: 0.5rem;
}
.editorial-spreads-postsearch .editorial-spread {
  min-height: 180px;
}
.editorial-spreads-postsearch .editorial-spread__image {
  /* inherits aspect-ratio: 16/9 from base rule */
}
.editorial-spreads-postsearch .editorial-spread__text {
  padding: 1.5rem 1.8rem;
}
.editorial-spreads-postsearch .editorial-spread__title {
  font-size: clamp(1.1rem, 2.5vw, 1.4rem);
}
.editorial-spreads-postsearch .editorial-spread__desc {
  font-size: 0.85rem;
}


/* ── ALERTS ACCORDION ────────────────────────────────────── */

.alerts-accordion {
  margin-top: 1px;
  border: 1px solid rgba(246,242,234,0.1);
  border-radius: 12px;
  overflow: hidden;
  animation: fadeUp 0.8s ease both 0.45s;
}

.alerts-accordion__toggle {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  padding: 1.1rem 1.4rem;
  background: rgba(255,255,255,0.03);
  border: none;
  cursor: pointer;
  transition: background 0.2s;
  text-align: left;
}

.alerts-accordion__toggle:hover {
  background: rgba(255,255,255,0.05);
}

.alerts-accordion__pulse {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--amber);
  flex-shrink: 0;
  animation: pulse 2s ease infinite;
}

.alerts-accordion__label {
  font-family: var(--serif);
  font-style: normal;
  font-size: 0.95rem;
  color: var(--muted);
  flex: 1;
}

.alerts-accordion__chevron {
  font-family: var(--mono);
  font-size: 0.7rem;
  color: var(--dimmed);
  transition: transform 0.3s;
  flex-shrink: 0;
}

.alerts-accordion__body {
  border-top: 1px solid rgba(246,242,234,0.08);
}

/* ── OLD HEADER COMPAT (kept for wordmark class used elsewhere) ── */

.wordmark .light { color: var(--amber); }
.wordmark .cast  { color: var(--star); }

.hero-tagline-a {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 100;
  color: var(--muted);
  font-size: clamp(1rem, 4vw, 1.8rem);
  text-align: center;
}


/* ── HOW IT WORKS ───────────────────────────────────────── */

/* ── HOW IT WORKS ───────────────────────────────────────── */

.how-section {
  width: 100%;
  max-width: var(--max-width);
  margin: 2.5rem auto 0;
  padding: 0 1.5rem;
  animation: fadeUp 1s ease both 0.2s;
}

.how-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  padding: 1.1rem 1.4rem;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(246,242,234,0.1);
  border-radius: 10px;
  user-select: none;
  min-height: 52px;
  transition: 0.2s, border-color 0.2s;
}

.how-toggle:hover {
  background: rgba(255,255,255,0.04);
  border-color: var(--border-hover);
}

.how-toggle-label {
  font-family: var(--serif);
  font-style: normal;
  font-size: 0.95rem;
  font-weight: 300;
  color: var(--muted);
  letter-spacing: 0.03em;
}

.how-arrow {
  font-family: var(--mono);
  font-size: 0.7rem;
  color: var(--dimmed);
  transition: transform 0.3s;
  flex-shrink: 0;
}

.how-arrow.open { transform: rotate(180deg); }

.how-body { display: none; margin-top: 1px; }
.how-body.open { display: block; }

.how-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(246,242,234,0.06);
  border: 1px solid rgba(246,242,234,0.1);
  border-top: none;
  border-radius: 0 0 10px 10px;
  overflow: hidden;
}

@media (max-width: 640px) {
  .how-steps { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 380px) {
  .how-steps { grid-template-columns: 1fr; }
}

.how-step {
  background: rgba(255,255,255,0.02);
  backdrop-filter: blur(20px);
  padding: 1.4rem 1.3rem 1.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  position: relative;
  transition: 0.2s;
}

.how-step:hover { background: rgba(255,255,255,0.05); }

.how-step::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  opacity: 0.5;
  transition: opacity 0.2s;
}

.how-step:hover::before { opacity: 1; }

.how-step--gold::before   { background: linear-gradient(90deg, transparent, var(--amber), var(--gold), transparent); }
.how-step--teal::before   { background: linear-gradient(90deg, transparent, var(--teal), #22d3ee, transparent); }
.how-step--star::before   { background: linear-gradient(90deg, transparent, #4a7fc8, var(--star), transparent); }
.how-step--bright::before { background: linear-gradient(90deg, transparent, var(--gold), var(--amber), transparent); }

.how-step__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.2rem;
}

.how-step__num {
  font-family: var(--mono);
  font-size: 0.42rem;
  letter-spacing: 0.18em;
  color: var(--faint);
}

.how-step__tool {
  font-family: var(--mono);
  font-size: 0.4rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.how-step--gold   .how-step__tool { color: var(--amber); }
.how-step--teal   .how-step__tool { color: var(--teal); }
.how-step--star   .how-step__tool { color: var(--star); }
.how-step--bright .how-step__tool { color: var(--gold); }

.how-step__icon {
  font-size: 1.6rem;
  line-height: 1;
  margin: 0.3rem 0 0.1rem;
}

.how-step__title {
  font-family: var(--mono);
  font-size: 0.52rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.how-step--gold   .how-step__title { color: var(--amber); }
.how-step--teal   .how-step__title { color: var(--teal); }
.how-step--star   .how-step__title { color: var(--star); }
.how-step--bright .how-step__title { color: var(--gold); }

.how-step__desc {
  font-family: var(--serif);
  font-size: 0.9rem;
  line-height: 1.75;
  color: var(--muted);
  font-weight: 300;
  flex: 1;
}

/* ── APP CARDS GRID ─────────────────────────────────────── */

.apps-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  width: 100%;
  max-width: var(--max-width);
  margin: 1.8rem auto 0;
  padding: 0 1.5rem;
}

@media (max-width: 600px) {
  .apps-grid { grid-template-columns: 1fr; }
}

/* Wide cards span full width */
.app-card--drone,
.app-card--tri {
  grid-column: 1 / -1;
}

/* ── BASE CARD ── */
.app-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  animation: fadeUp 0.8s ease both;
  transition: border-color 0.3s, transform 0.28s cubic-bezier(0.34,1.4,0.64,1), box-shadow 0.3s;
  cursor: pointer;
  text-decoration: none;
  min-height: 400px;
  background: rgba(60, 38, 35, 0.78);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

@media (min-width: 600px) { .app-card { min-height: 450px; } }

/* Wide cards are shorter — consistent with each other */
.app-card--drone,
.app-card--tri {
  min-height: 200px;
}

@media (min-width: 640px) {
  .app-card--drone,
  .app-card--tri { min-height: 220px; }
}

/* Portrait card hover — slight lift */
.app-card--gold:hover,
.app-card--star:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 50px rgba(0,0,0,0.5);
}

/* Wide card hover — subtle only */
.app-card--drone:hover,
.app-card--tri:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0,0,0,0.35);
}

/* Per-card border accent on hover */
.app-card--gold:hover  { border-color: rgba(232,129,42,0.5); }
.app-card--star:hover  { border-color: rgba(126,184,247,0.45); }
.app-card--tri:hover   { border-color: rgba(232,129,42,0.4); }
.app-card--drone:hover { border-color: rgba(45,212,191,0.45); }

/* Animation stagger */
.app-card--gold  { animation-delay: 0.08s; }
.app-card--star  { animation-delay: 0.16s; }
.app-card--drone { animation-delay: 0.24s; }
.app-card--tri   { animation-delay: 0.32s; }

/* ── TOP ACCENT BAR (replaces the old sky gradient as primary device) ── */
.app-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  z-index: 2;
  transition: opacity 0.3s;
  opacity: 0.6;
}
.app-card:hover::before { opacity: 1; }

.app-card--gold::before  { background: linear-gradient(90deg, transparent 0%, var(--amber) 30%, var(--gold) 70%, transparent 100%); }
.app-card--star::before  { background: linear-gradient(90deg, transparent 0%, #4a7fc8 30%, var(--star) 70%, transparent 100%); }
.app-card--tri::before   { background: linear-gradient(90deg, transparent 0%, var(--amber) 40%, var(--star) 80%, transparent 100%); }
.app-card--drone::before { background: linear-gradient(90deg, transparent 0%, var(--teal) 40%, #22d3ee 80%, transparent 100%); }

/* ── SKY ATMOSPHERE UPDATED ── */
.app-card--gold .app-card__sky {
  background:
    linear-gradient(to bottom, #1e0d05 0%, #2a0f04 55%, rgba(60,38,35,0.85) 100%);
}

.app-card--star .app-card__sky {
  background:
    radial-gradient(ellipse 140% 50% at 50% -10%, rgba(70,150,245,0.25) 0%, transparent 65%),
    radial-gradient(ellipse 80% 40% at 15% 5%, rgba(120,100,230,0.18) 0%, transparent 55%),
    linear-gradient(to bottom, #05070f 0%, #0a0f1c 50%, rgba(30,20,18,0.85) 100%);
}

.app-card--tri .app-card__sky {
  background:
    radial-gradient(ellipse 100% 55% at 0% 50%, rgba(232,129,42,0.22) 0%, transparent 55%),
    radial-gradient(ellipse 70% 55% at 100% 50%, rgba(70,150,245,0.12) 0%, transparent 55%),
    linear-gradient(to bottom, #0d0702 0%, #1a0b05 55%, rgba(30,20,18,0.85) 100%);
}

.app-card--drone .app-card__sky {
  background:
    radial-gradient(ellipse 140% 45% at 50% -5%, rgba(45,212,191,0.28) 0%, transparent 60%),
    radial-gradient(ellipse 80% 35% at 80% 15%, rgba(0,180,200,0.12) 0%, transparent 55%),
    linear-gradient(to bottom, #03070c 0%, #050d12 50%, rgba(30,20,18,0.85) 100%);
}

/* ── CARD INNER ── */
.app-card__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1.8rem 1.8rem 0;
}

/* Portrait cards: CTA lives in a separate bottom bar */
.app-card--gold .app-card__inner,
.app-card--star .app-card__inner {
  padding-bottom: 0;
}

/* Wide card layout — horizontal on desktop */
@media (min-width: 640px) {
  .app-card--tri .app-card__inner,
  .app-card--drone .app-card__inner {
    flex-direction: row;
    align-items: stretch;
    padding: 0;
    gap: 0;
  }

  .app-card--tri .app-card__left,
  .app-card--drone .app-card__left {
    flex: 1.1;
    padding: 1.6rem 1.8rem;
    border-right: 1px solid var(--faint);
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .app-card--tri .app-card__right,
  .app-card--drone .app-card__right {
    flex: 1;
    padding: 1.6rem 1.8rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
}

@media (max-width: 639px) {
  .app-card--tri .app-card__left,
  .app-card--drone .app-card__left {
    padding: 1.6rem 1.8rem 0;
  }
  .app-card--tri .app-card__right,
  .app-card--drone .app-card__right {
    padding: 1rem 1.8rem 1.4rem;
  }
}

/* ── CARD TYPOGRAPHY ── */
.app-card__eyebrow {
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  margin-bottom: 0.55rem;
}

.app-card--gold .app-card__eyebrow  { color: var(--amber); }
.app-card--star .app-card__eyebrow  { color: var(--star); }
.app-card--tri .app-card__eyebrow   { color: var(--amber); }
.app-card--drone .app-card__eyebrow { color: var(--teal); }

.app-card__name {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2rem, 5vw, 3rem);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  line-height: 1;
  margin-bottom: 0.75rem;
  color: var(--text);
}

/* Wide cards get a smaller name */
.app-card--tri .app-card__name,
.app-card--drone .app-card__name {
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  margin-bottom: 0.5rem;
}

.app-card__name em { font-style: normal; }
.app-card--gold .app-card__name em   { color: var(--amber); }
.app-card--star .app-card__name em   { color: var(--star); }
.app-card--tri .app-card__name .tri  { color: var(--amber); }
.app-card--tri .app-card__name .cast { color: var(--star); }
.app-card--drone .app-card__name em  { color: var(--teal); }

.app-card__desc {
  font-family: var(--serif);
  font-weight: 300;
  font-style: normal;
  font-size: 0.98rem;
  line-height: 1.7;
  color: var(--muted);
  margin-bottom: 1.4rem;
  max-width: 26ch;
}

.app-card--tri .app-card__desc,
.app-card--drone .app-card__desc {
  max-width: 34ch;
  margin-bottom: 0.8rem;
  font-size: 0.92rem;
}

/* ── FEATURES LIST ── */
.app-card__features {
  list-style: none;
  display: flex;
  flex-direction: column;
  flex: 1;
  margin-bottom: 0;
  border-top: 1px solid var(--faint);
}

.app-card__features li {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  font-family: var(--mono);
  font-size: 0.51rem;
  letter-spacing: 0.07em;
  color: var(--muted);
  line-height: 1.3;
  padding: 0.55rem 0;
  border-bottom: 1px solid var(--faint);
}

.app-card__features li:last-child { border-bottom: none; }

/* Wide card features — no top border, tighter */
.app-card--tri .app-card__features,
.app-card--drone .app-card__features {
  border-top: none;
  flex: unset;
  margin-bottom: 1rem;
}

.app-card--tri .app-card__features li,
.app-card--drone .app-card__features li {
  padding: 0.3rem 0;
  border-bottom: 1px solid var(--faint);
  font-size: 0.50rem;
}

.app-card--tri .app-card__features li:last-child,
.app-card--drone .app-card__features li:last-child {
  border-bottom: none;
}

@media (max-width: 480px) {
  .app-card__features li:nth-child(n+4) { display: none; }
}

.feat-dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  flex-shrink: 0;
  opacity: 0.6;
}

.app-card--gold .feat-dot  { background: var(--amber); }
.app-card--star .feat-dot  { background: var(--star); }
.app-card--tri .feat-dot   { background: var(--amber); }
.app-card--drone .feat-dot { background: var(--teal); }

/* ── CARD CTA — bottom bar for portrait cards ── */
.app-card__cta-bar {
  position: relative;
  z-index: 1;
  margin-top: auto;
  border-top: 1px solid var(--faint);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.8rem;
  transition: 0.25s;
}

.app-card--gold .app-card__cta-bar  { background: rgba(232,129,42,0.05); }
.app-card--star .app-card__cta-bar  { background: rgba(126,184,247,0.05); }
.app-card--gold:hover .app-card__cta-bar { background: rgba(232,129,42,0.1); }
.app-card--star:hover .app-card__cta-bar { background: rgba(126,184,247,0.08); }

.app-card__cta-label {
  font-family: var(--mono);
  font-size: 0.52rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
  transition: color 0.2s;
}

.app-card--gold:hover .app-card__cta-label { color: var(--amber); }
.app-card--star:hover .app-card__cta-label { color: var(--star); }



.app-card__cta-arrow {
  font-family: var(--mono);
  font-size: 0.9rem;
  color: var(--dimmed);
  transition: transform 0.25s, color 0.2s;
}

.app-card--gold:hover .app-card__cta-arrow { color: var(--amber); transform: translateX(4px); }
.app-card--star:hover .app-card__cta-arrow { color: var(--star);  transform: translateX(4px); }

/* ── WIDE CARD CTA BUTTON ── */
.app-card__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--mono);
  font-size: 0.52rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0.7rem 1.2rem;
  border-radius: 2px;
  cursor: pointer;
  min-height: 40px;
  transition: 0.2s, border-color 0.2s, transform 0.15s;
  text-decoration: none;
  align-self: flex-start;
}

.app-card__btn:active { transform: scale(0.97); }

.app-card--tri .app-card__btn {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--border);
}

.app-card--tri:hover .app-card__btn {
  border-color: rgba(232,129,42,0.5);
  color: var(--amber);
  background: rgba(232,129,42,0.06);
}

.app-card--drone .app-card__btn {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--border);
}

.app-card--drone:hover .app-card__btn {
  border-color: rgba(45,212,191,0.5);
  color: var(--teal);
  background: rgba(45,212,191,0.05);
}

/* ── FEATURE PILLS (wide cards) ── */
.card-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.7rem;
}

.card-pill {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.28rem 0.65rem;
  border-radius: 20px;
  color: var(--dimmed);
}

.app-card--tri .card-pill   { border: 1px solid rgba(232,129,42,0.15); }
.app-card--drone .card-pill { border: 1px solid rgba(45,212,191,0.15); }


/* ── TEASER / QUICK FORECAST ────────────────────────────── */

.teaser-wrap {
  width: 100%;
  max-width: var(--max-width);
  margin: 2rem auto 0;
  padding: 0 1.5rem;
  animation: fadeUp 1s ease both 0.1s;
}

.teaser-search {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1.4rem;
  position: relative;
}

.teaser-search-inner {
  position: relative;
  width: 100%;
  max-width: 360px;
}

.teaser-input {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--text);
  font-family: var(--serif);
  font-style: normal;
  font-size: 0.95rem;
  letter-spacing: 0.03em;
  padding: 0.75rem 1.1rem;
  outline: none;
  transition: border-color 0.2s, 0.2s;
  min-height: 48px;
  -webkit-appearance: none;
}

.teaser-input:focus {
  border-color: rgba(240,236,228,0.25);
  background: rgba(255,255,255,0.06);
}

.teaser-input::placeholder {
  color: var(--dimmed);
  font-style: normal;
}

.teaser-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0; right: 0;
  background: #0c0a08;
  border: 1px solid var(--border);
  border-radius: 2px;
  z-index: 200;
  display: none;
  box-shadow: 0 12px 40px rgba(0,0,0,0.8);
  max-height: 220px;
  overflow-y: auto;
}

.teaser-dropdown.open { display: block; }

.teaser-dropdown-item {
  padding: 0.85rem 1.1rem;
  cursor: pointer;
  transition: 0.12s;
  border-bottom: 1px solid var(--faint);
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
  min-height: 48px;
}

.teaser-dropdown-item:last-child { border-bottom: none; }
.teaser-dropdown-item:active { background: rgba(240,236,228,0.05); }

.td-city   { font-family: var(--serif); font-size: 1rem; color: var(--text); flex-shrink: 0; }
.td-region { font-family: var(--mono); font-size: 0.48rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.td-status { padding: 0.8rem 1.1rem; font-family: var(--mono); font-size: 0.52rem; color: var(--dimmed); letter-spacing: 0.1em; animation: pulse 1.2s ease infinite; }

.search-hint {
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dimmed);
  text-align: center;
  margin-top: 0.7rem;
}

.forecast-label {
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dimmed);
  text-align: center;
  margin-bottom: 0.8rem;
}

.teaser-scores {
  display: none;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 3px;
  overflow: hidden;
}

.teaser-scores.visible { display: grid; }

.teaser-score {
  background: rgba(10,8,6,0.75);
  backdrop-filter: blur(16px);
  padding: 1.3rem 1.5rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  text-decoration: none;
  transition: 0.2s;
  cursor: pointer;
}

.teaser-score:hover { background: rgba(18,14,10,0.9); }

.teaser-score__label {
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.teaser-score--gold .teaser-score__label { color: var(--amber); }
.teaser-score--star .teaser-score__label { color: var(--star); }

.teaser-score__emoji {
  font-size: 1.3rem;
  line-height: 1;
  letter-spacing: 0.05em;
  min-height: 1.6rem;
}

.teaser-score__emoji .empty { opacity: 0.2; }

.teaser-score__emoji.loading {
  font-family: var(--mono);
  font-size: 0.52rem;
  color: var(--dimmed);
  letter-spacing: 0.1em;
  animation: pulse 1.4s ease infinite;
}

.teaser-score__cta {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dimmed);
  margin-top: 0.1rem;
}

.teaser-score--gold:hover .teaser-score__cta { color: var(--amber); }
.teaser-score--star:hover .teaser-score__cta { color: var(--star); }



/* ════════════════════════════════════════════════════
   HUB — TONIGHT AT A GLANCE
════════════════════════════════════════════════════ */

.hub-wrap {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1.5rem 2rem;
}

/* ── SEARCH BLOCK ── */
.hub-search-block {
  margin-bottom: 2rem;
  animation: fadeUp 0.9s ease both 0.15s;
}

.hub-hero-eyebrow {
  font-family: var(--mono);
  font-size: 0.5rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--dimmed);
  text-align: center;
  margin-bottom: 0.9rem;
}

.hub-hero-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(246,242,234,0.1);
  border-radius: 12px;
  padding: 1.6rem 1.6rem 1.2rem;
  position: relative;
  overflow: hidden;
  max-width: 680px;
  margin: 0 auto;
}

.hub-hero-card::before {
  content: '';
  position: absolute;
  top: 0; left: 15%; right: 15%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,129,42,0.55), rgba(126,184,247,0.55), transparent);
}

.hub-hero-card::after {
  content: '';
  position: absolute;
  top: -80px; left: 50%;
  transform: translateX(-50%);
  width: 400px; height: 160px;
  background: radial-gradient(ellipse, rgba(126,184,247,0.07) 0%, transparent 70%);
  pointer-events: none;
}

.hub-tool-pills {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 1.1rem;
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}

.hub-tool-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.3rem 0.75rem;
  border-radius: 20px;
  border: 1px solid rgba(246,242,234,0.1);
  font-family: var(--mono);
  font-size: 0.48rem;
  letter-spacing: 0.08em;
  color: rgba(246,242,234,0.35);
  background: rgba(255,255,255,0.02);
}

.hub-tool-pill--gold { border-color: rgba(232,129,42,0.25); color: rgba(232,129,42,0.65); }
.hub-tool-pill--star { border-color: rgba(126,184,247,0.25); color: rgba(126,184,247,0.65); }
.hub-tool-pill--teal { border-color: rgba(45,212,191,0.25);  color: rgba(45,212,191,0.65); }
.hub-tool-pill--mono { border-color: rgba(246,242,234,0.12); color: rgba(246,242,234,0.35); }

.hub-intent {
  font-family: var(--serif);
  font-style: normal;
  font-size: 0.92rem;
  color: var(--muted);
  line-height: 1.7;
  text-align: center;
  margin-bottom: 1.2rem;
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}

.intent-gold { color: var(--amber); font-style: normal; font-weight: 600; }
.intent-star { color: var(--star);  font-style: normal; font-weight: 600; }
.intent-teal { color: var(--teal);  font-style: normal; font-weight: 600; }

.hub-search-row {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  align-items: stretch;
}

.hub-search-inner {
  width: 100%;
}

.hub-search-inner {
  flex: 1;
  position: relative;
}

.hub-input {
  width: 100%;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(246,242,234,0.12);
  border-radius: 8px;
  color: var(--text);
  font-family: var(--serif);
  font-style: normal;
  font-size: 1.15rem;
  letter-spacing: 0.02em;
  padding: 0.95rem 1.3rem;
  outline: none;
  transition: border-color 0.2s, 0.2s, box-shadow 0.2s;
  min-height: 56px;
  -webkit-appearance: none;
}

.hub-input:focus {
  border-color: rgba(240,236,228,0.28);
  background: rgba(255,255,255,0.07);
  box-shadow: 0 0 0 3px rgba(240,236,228,0.04);
}

.hub-input::placeholder { color: var(--dimmed); font-style: normal; }

.hub-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0; right: 0;
  background: #0c0a08;
  border: 1px solid var(--border);
  border-radius: 2px;
  z-index: 200;
  display: none;
  box-shadow: 0 14px 44px rgba(0,0,0,0.85);
  max-height: 200px;
  overflow-y: auto;
}

.hub-dropdown.open { display: block; }

.hub-units-select {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(246,242,234,0.12);
  border-radius: 8px;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  padding: 0 0.8rem;
  min-height: 48px;
  outline: none;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(253,244,232,0.3)'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.6rem center;
  background-size: 8px;
  padding-right: 1.8rem;
  transition: border-color 0.2s;
  white-space: nowrap;
}

.hub-units-select:focus { border-color: var(--border-hover); }
.hub-units-select option { background: #0c0a08; color: var(--text); }

.hub-search-btn {
  background: rgba(232,129,42,0.3);
  border: 1px solid rgba(232,129,42,0.35);
  border-radius: 8px;
  color: var(--text);
  font-family: var(--mono);
  font-size: 0.52rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 0 1.4rem;
  min-height: 48px;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: 0.2s, border-color 0.2s, transform 0.15s;
}

.hub-search-btn:hover { background: rgba(232,129,42,0.5); border-color: rgba(232,129,42,0.6); transform: translateY(-1px); }
.hub-search-btn:active { transform: scale(0.97); }

.hub-hint {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--faint);
  text-align: center;
  margin-top: 0.65rem;
}

@media (max-width: 520px) {
  .hub-search-row { flex-wrap: wrap; }
  .hub-units-select { flex: 1; min-width: 0; font-size: 0.6rem; }
  .hub-search-btn { width: 100%; flex: none; }
  .hub-hero-card { padding: 1.2rem 1rem 1rem; border-radius: 10px; }
}



/* ── PRE-SEARCH: TOOL CARD ── */
.hub-tool-card {
  cursor: pointer;
  text-decoration: none;
  background: rgba(255,255,255,0.03);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(246,242,234,0.1);
  border-radius: 12px;
  backdrop-filter: blur(20px);
  overflow: hidden;
  margin-bottom: 0;
  animation: fadeUp 0.8s ease both 0.3s;
  position: relative;
}

.hub-tool-card__tools {
  display: grid;
  background: transparent;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1px;
}

@media (max-width: 560px) {
  .hub-tool-card__tools { grid-template-columns: 1fr; }
}

.hub-tool-link {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding: 1.1rem 1.3rem;
  background: rgba(255,255,255,0.02);
  text-decoration: none;
  transition: 0.2s;
  position: relative;
}

.hub-tool-link::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  opacity: 0;
  transition: opacity 0.25s;
}

.hub-tool-link:hover::before { opacity: 1; }
.hub-tool-link--gold::before { background: linear-gradient(90deg, transparent, var(--amber), transparent); }
.hub-tool-link--star::before { background: linear-gradient(90deg, transparent, var(--star), transparent); }
.hub-tool-link--teal::before { background: linear-gradient(90deg, transparent, var(--teal), transparent); }

.hub-tool-link:hover { background: rgba(255,255,255,0.05); }

.hub-tool-link__icon { font-size: 1.5rem; flex-shrink: 0; line-height: 1; }

.hub-tool-link__name {
  font-family: var(--mono);
  font-size: 0.56rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 0.2rem;
}

.hub-tool-link--gold .hub-tool-link__name { color: var(--amber); }
.hub-tool-link--star .hub-tool-link__name { color: var(--star); }
.hub-tool-link--teal .hub-tool-link__name { color: var(--teal); }

.hub-tool-link__desc {
  font-family: var(--serif);
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1.4;
}

.hub-tool-link__arrow {
  font-family: var(--mono);
  font-size: 0.8rem;
  color: var(--faint);
  margin-left: auto;
  flex-shrink: 0;
  transition: transform 0.2s, color 0.2s;
}

.hub-tool-link:hover .hub-tool-link__arrow { transform: translateX(4px); color: var(--muted); }

/* ── SCORE BAR ── */
.hub-score-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.6rem;
  padding: 0.9rem 1.2rem;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(246,242,234,0.1);
  border-radius: 12px 12px 0 0;
  margin-bottom: 0;
  animation: fadeDown 0.4s ease both;
  flex-direction: column;
  align-items: stretch;
  gap: 0.5rem;
}

.hub-score-bar__loc {
  font-family: var(--serif);
  font-style: normal;
  font-size: 0.95rem;
  color: var(--muted);
  flex-shrink: 0;
  max-width: none;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  flex: 1;
}

.hub-score-bar__pills {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  align-items: center;
  flex: 1;
  overflow: hidden;
  flex-wrap: nowrap;
}

@media (max-width: 915px) {
  .hub-score-bar__pills {
    display: flex;
    gap: 0.25rem;
    align-items: center;
    flex-wrap: nowrap;
    padding: 0 0.2rem;
    box-sizing: border-box;
    width: 100%;
  }

  .hub-score-bar__pills > * {
    flex: 1 1 0;
    min-width: 0;
    min-height: 32px;
    padding: 0.3rem 0.4rem;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
  }
}

.hub-score-pill {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--mono);
  font-size: 0.5rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.4rem 0.75rem;
  border-radius: 2px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.03);
  color: var(--dimmed);
  cursor: pointer;
  transition: 0.18s, border-color 0.18s, transform 0.15s;
}

.hub-score-pill__emoji { font-size: 0.5rem; line-height: 1; }
.hub-score-pill__name  { font-size: 0.5rem; }
.hub-score-pill__val   { font-size: 0.5rem; font-weight: 400; }

.hub-score-pill:hover { background: rgba(255,255,255,0.07); }
.hub-score-pill.active { background: rgba(255,255,255,0.08); border-color: var(--border-hover); color: var(--text); }

/* Score quality tints */
.hub-score-pill--gold.is-great .hub-score-pill__val { color: #4ade80; }
.hub-score-pill--gold.is-ok   .hub-score-pill__val { color: var(--amber); }
.hub-score-pill--gold.is-poor .hub-score-pill__val { color: #f87171; }
.hub-score-pill--star.is-great .hub-score-pill__val { color: #4ade80; }
.hub-score-pill--star.is-ok   .hub-score-pill__val { color: var(--star); }
.hub-score-pill--star.is-poor .hub-score-pill__val { color: #f87171; }
.hub-score-pill--teal.is-great .hub-score-pill__val { color: #4ade80; }
.hub-score-pill--teal.is-ok   .hub-score-pill__val { color: var(--teal); }
.hub-score-pill--teal.is-poor .hub-score-pill__val { color: #f87171; }

.hub-reset-btn {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dimmed);
  background: none;
  border: 1px solid var(--faint);
  border-radius: 2px;
  padding: 0.4rem 0.7rem;
  cursor: pointer;
  transition: color 0.2s, border-color 0.2s;
  margin-left: auto;
  flex-shrink: 0;
}

.hub-reset-btn:hover { color: var(--coral); border-color: rgba(217,79,32,0.4); }

/* ── TABS ── */
.hub-tabs {
  display: flex;
  gap: 1px;
  background: rgba(246,242,234,0.06);
  border: 1px solid rgba(246,242,234,0.1);
  border-top: none;
  border-radius: 0;
  overflow: hidden;
}

.hub-tab {
  flex: 1;
  font-family: var(--mono);
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.9rem 1.9em;
  background: rgba(255,255,255,0.02);
  color: var(--dimmed);
  border: none;
  cursor: pointer;
  transition: 0.2s, color 0.2s;
  min-height: 44px;
  position: relative;
}

.hub-tab::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  opacity: 0;
  transition: opacity 0.25s;
}

.hub-tab--gold::after { background: linear-gradient(90deg, var(--amber), var(--gold)); }
.hub-tab--star::after { background: linear-gradient(90deg, #4a7fc8, var(--star)); }
.hub-tab--teal::after { background: linear-gradient(90deg, #14b8a6, var(--teal)); }

.hub-tab.active { background: rgba(255,255,255,0.05); }
.hub-tab.active::after { opacity: 1; }
.hub-tab--gold.active { color: var(--amber); }
.hub-tab--star.active { color: var(--star); }
.hub-tab--teal.active { color: var(--teal); }
.hub-tab:hover:not(.active) { background: rgba(255,255,255,0.04); color: var(--muted); }

/* ── PANELS ── */
.hub-panel {
  border: 1px solid rgba(246,242,234,0.1);
  border-top: none;
  border-radius: 0 0 12px 12px;
  padding: 1.5rem;
  background: rgba(255,255,255,0.02);
  backdrop-filter: blur(24px);
  animation: fadeUp 0.35s ease both;
}

.hub-panel--gold { border-color: rgba(232,129,42,0.18); }
.hub-panel--star { border-color: rgba(126,184,247,0.18); }
.hub-panel--teal {
  background: rgba(18, 16, 22, 0.55);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border-color: rgba(45,212,191,0.18);
}

.hub-panel__loading {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  padding: 2rem 0;
  font-family: var(--mono);
  font-size: 0.5rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dimmed);
  animation: pulse 1.4s ease infinite;
}

.hub-loader {
  width: 16px; height: 16px;
  border-radius: 50%;
  border: 2px solid transparent;
  animation: spin 0.9s linear infinite;
  flex-shrink: 0;
}

.hub-loader--gold { border-top-color: var(--amber); border-right-color: rgba(232,129,42,0.3); }
.hub-loader--star { border-top-color: var(--star);  border-right-color: rgba(126,184,247,0.3); }
.hub-loader--teal { border-top-color: var(--teal);  border-right-color: rgba(45,212,191,0.3); }

@keyframes spin { to { transform: rotate(360deg); } }

/* ── CARDS ROW ── */
.hub-cards-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

@media (max-width: 915px) {
  .hub-cards-row { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 915px) {
  .hub-cards-row { grid-template-columns: 1fr; }
}

.hub-card {
  border: 1px solid rgba(246,242,234,0.08);
  border-radius: 10px;
  padding: 1rem 1.1rem;
  background: rgba(255,255,255,0.03);
  position: relative;
  overflow: hidden;
}

.hub-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  opacity: 0.4;
}

.hub-card--gold::before { background: linear-gradient(90deg, transparent, var(--amber), transparent); }
.hub-card--star::before { background: linear-gradient(90deg, transparent, var(--star), transparent); }
.hub-card--teal::before { background: linear-gradient(90deg, transparent, var(--teal), transparent); }

.hub-card--wide {
  grid-column: 1 / -1;
}

.hub-card__eyebrow {
  font-family: var(--mono);
  font-size: 0.42rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dimmed);
  margin-bottom: 0.6rem;
}

.hub-card__big {
  font-family: var(--mono);
  font-size: 1.4rem;
  letter-spacing: 0.08em;
  color: var(--text);
  line-height: 1.3;
  margin-bottom: 0.2rem;
}

.hub-card__sub {
  font-family: var(--serif);
  font-style: normal;
  font-size: 1.2rem;
  color: var(--dimmed);
  line-height: 1.4;
}

.hub-card__reading {
  font-family: var(--serif);
  font-size: 0.92rem;
  color: var(--muted);
  line-height: 1.7;
  font-weight: 300;
}

/* Score ring card */
.hub-card--score {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.hub-ring-wrap {
  position: relative;
  width: 100px; height: 100px;
  margin: 0.4rem 0;
}

.hub-ring-svg {
  width: 100px; height: 100px;
  transform: rotate(-90deg);
}

.hub-ring-track {
  fill: none;
  stroke: rgba(255,255,255,0.07);
  stroke-width: 5;
}

.hub-ring-fill {
  fill: none;
  stroke-width: 5;
  stroke-linecap: round;
  stroke-dasharray: 0 214;
}

.hub-ring-fill--gold { stroke: var(--amber); }
.hub-ring-fill--star { stroke: var(--star); }
.hub-ring-fill--teal { stroke: var(--teal); }

.hub-ring-inner {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  pointer-events: none;
}

.hub-ring-num {
  font-family: var(--mono);
  font-size: 1.8rem;
  letter-spacing: -0.02em;
  color: var(--text);
  line-height: 1;
  display: block;
}

.hub-ring-label {
  font-family: var(--mono);
  font-size: 0.38rem;
  letter-spacing: 0.1em;
  color: var(--dimmed);
  margin-top: 0.1rem;
  display: block;
  line-height: 1;
}

.hub-card__score-label {
  font-family: var(--mono);
  font-size: 0.6rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-top: 0.3rem;
}

.hub-card--gold .hub-card__score-label { color: var(--amber); }
.hub-card--star .hub-card__score-label { color: var(--star); }
.hub-card--teal .hub-card__score-label { color: var(--teal); }

/* ── WHY DROPDOWN ── */
.hub-why {
  margin-bottom: 0.75rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  overflow: hidden;
}

.hub-why__toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.8rem 1.1rem;
  font-family: var(--mono);
  font-size: 0.48rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  background: rgba(10,8,6,0.5);
  border: none;
  cursor: pointer;
  transition: 0.2s;
  min-height: 40px;
}

.hub-why__toggle:hover { background: rgba(20,14,10,0.8); }

.hub-why--gold .hub-why__toggle:hover { color: var(--amber); }
.hub-why--star .hub-why__toggle:hover { color: var(--star); }
.hub-why--teal .hub-why__toggle:hover { color: var(--teal); }

.hub-why__arrow {
  font-size: 0.65rem;
  transition: transform 0.25s;
  flex-shrink: 0;
}

.hub-why__body {
  display: none;
  padding: 0.8rem 1.1rem;
  background: rgba(6,5,4,0.6);
  border-top: 1px solid var(--faint);
}

.hub-why__factors {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
}

@media (max-width: 480px) {
  .hub-why__factors { grid-template-columns: 1fr 1fr; }
}

.hub-factor {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 0.6rem;
  border-radius: 2px;
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.08em;
}

.hub-factor--pos { background: rgba(74,222,128,0.06); border: 1px solid rgba(74,222,128,0.15); }
.hub-factor--neg { background: rgba(248,113,113,0.06); border: 1px solid rgba(248,113,113,0.15); }
.hub-factor--neu { background: rgba(255,255,255,0.03); border: 1px solid var(--faint); }

.hub-factor__icon { flex-shrink: 0; }
.hub-factor--pos .hub-factor__icon { color: #4ade80; }
.hub-factor--neg .hub-factor__icon { color: #f87171; }
.hub-factor--neu .hub-factor__icon { color: var(--dimmed); }

.hub-factor__label { color: var(--muted); flex: 1; }
.hub-factor__val { color: var(--text); flex-shrink: 0; }

/* ── NEARBY ── */
.hub-nearby {
  margin-bottom: 0.75rem;
  padding: 0.9rem 1.1rem;
  background: rgba(10,8,6,0.5);
  border: 1px solid var(--faint);
  border-radius: 3px;
}

.hub-nearby__label {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dimmed);
  margin-bottom: 0.6rem;
}

.hub-nearby__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.hub-nearby__loading {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.1em;
  color: var(--faint);
  animation: pulse 1.4s ease infinite;
}

.hub-nearby-chip {
  font-family: var(--mono);
  font-size: 0.56rem;
  letter-spacing: 0.1em;
  padding: 0.35rem 0.7rem;
  border-radius: 20px;
  border: 1px solid var(--faint);
  color: var(--muted);
}

.hub-nearby-chip strong { margin-left: 0.3em; }
.nearby-great { border-color: rgba(74,222,128,0.25); color: #4ade80; }
.nearby-ok    { border-color: rgba(251,191,36,0.25); color: #fbbf24; }
.nearby-poor  { border-color: rgba(248,113,113,0.2); color: #f87171; }

/* ── CTA ── */
.hub-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.95rem 1.3rem;
  border-radius: 10px;
  font-family: var(--serif);
  font-size: 0.62rem;
  letter-spacing: 0.16em;
  text-decoration: none;
  margin-bottom: 0.75rem;
  transition: opacity 0.2s, transform 0.18s;
  min-height: 44px;
}

.hub-cta:hover { opacity: 0.85; transform: translateY(-1px); }
.hub-cta:active { transform: scale(0.98); }

.hub-cta--gold {
  background: rgba(232,129,42,0.18);
  border: 1px solid rgba(232,129,42,0.35);
  color: var(--amber);
}

.hub-cta--star {
  background: rgba(126,184,247,0.12);
  border: 1px solid rgba(126,184,247,0.3);
  color: var(--star);
}

.hub-cta--teal {
  background: rgba(45,212,191,0.12);
  border: 1px solid rgba(45,212,191,0.3);
  color: var(--teal);
  letter-spacing: normal;
}

.hub-cta__arrow {
  font-family: var(--mono);
  font-size: 1rem;
  transition: transform 0.2s;
}

.hub-cta:hover .hub-cta__arrow { transform: translateX(5px); }

/* ── INLINE ALERTS ── */
.hub-alert-inline {
  border: 1px solid var(--faint);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 0.5rem;
}

.hub-alert-details summary { list-style: none; }
.hub-alert-details summary::-webkit-details-marker { display: none; }

.hub-alert-summary {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.85rem 1.1rem;
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dimmed);
  cursor: pointer;
  transition: 0.2s;
  min-height: 40px;
}

.hub-alert-inline--gold .hub-alert-summary:hover { background: rgba(232,129,42,0.06); color: var(--amber); }
.hub-alert-inline--star .hub-alert-summary:hover { background: rgba(126,184,247,0.06); color: var(--star); }
.hub-alert-inline--teal .hub-alert-summary:hover { background: rgba(45,212,191,0.06); color: var(--teal); }

.hub-alert-chevron { margin-left: auto; flex-shrink: 0; transition: transform 0.25s; }
details[open] .hub-alert-chevron { transform: rotate(180deg); }

.hub-alert-pulse {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
  animation: gcpulse 2.2s ease-in-out infinite;
}

.hub-alert-pulse--gold { background: var(--amber); }
.hub-alert-pulse--teal { background: var(--teal); }

.hub-alert-body {
  padding: 0.9rem 1.1rem 1rem;
  border-top: 1px solid var(--faint);
  background: rgba(6,5,4,0.5);
}

.hub-alert-row {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.hub-alert-email {
  flex: 1;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 0.55rem 0.8rem;
  color: var(--text);
  font-family: var(--mono);
  font-size: 0.52rem;
  outline: none;
  min-height: 38px;
  transition: border-color 0.2s;
  -webkit-appearance: none;
}

.hub-alert-email:focus { border-color: rgba(240,236,228,0.25); }
.hub-alert-email::placeholder { color: var(--faint); }

.hub-alert-threshold {
  width: 68px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 0.55rem 0.6rem;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 0.52rem;
  outline: none;
  min-height: 38px;
  text-align: center;
  flex-shrink: 0;
  transition: border-color 0.2s;
  -webkit-appearance: none;
}

.hub-alert-threshold:focus { border-color: rgba(240,236,228,0.25); }

.hub-alert-btn {
  font-family: var(--mono);
  font-size: 0.5rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.55rem 1rem;
  border-radius: 2px;
  border: none;
  cursor: pointer;
  flex-shrink: 0;
  min-height: 38px;
  transition: opacity 0.2s, transform 0.15s;
}

.hub-alert-btn--gold { background: rgba(232,129,42,0.3); color: var(--text); }
.hub-alert-btn--star { background: rgba(126,184,247,0.2); color: var(--text); }
.hub-alert-btn--teal { background: rgba(45,212,191,0.2); color: var(--text); }
.hub-alert-btn:hover { opacity: 0.85; transform: translateY(-1px); }

.hub-alert-msg {
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.08em;
  margin-top: 0.5rem;
  min-height: 1em;
}

.hub-alert-msg--success { color: #4ade80; }
.hub-alert-msg--error   { color: #f87171; }

@media (max-width: 440px) {
  .hub-alert-row { flex-wrap: wrap; }
  .hub-alert-threshold { width: 58px; }
  .hub-alert-btn { flex: 1; }
}

/* ── DRONE BAR ── */
.hub-drone-bar {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.9rem;
  padding: 0.75rem 1rem;
  background: rgba(10,8,6,0.5);
  border: 1px solid var(--border);
  border-radius: 3px;
}

.hub-drone-bar__label {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dimmed);
  flex-shrink: 0;
}

.hub-drone-select {
  flex: 1;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 0.5rem;
  padding: 0.5rem 1.8rem 0.5rem 0.7rem;
  outline: none;
  min-height: 36px;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(253,244,232,0.3)'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.6rem center;
  background-size: 8px;
  transition: border-color 0.2s;
}

.hub-drone-select:focus { border-color: rgba(45,212,191,0.35); }
.hub-drone-select option { background: #0c0a08; color: var(--text); }

.hub-drone-update-btn {
  font-family: var(--mono);
  font-size: 0.48rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.5rem 1rem;
  background: rgba(45,212,191,0.18);
  border: 1px solid rgba(45,212,191,0.3);
  border-radius: 2px;
  color: var(--teal);
  cursor: pointer;
  flex-shrink: 0;
  min-height: 36px;
  transition: 0.2s, opacity 0.2s;
}

.hub-drone-update-btn:hover { background: rgba(45,212,191,0.28); }
.hub-drone-update-btn:disabled { opacity: 0.45; cursor: not-allowed; }

/* ── BRIEFING GRID ── */
.hub-briefing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.6rem;
  margin-top: 0.6rem;
}

@media (max-width: 560px) {
  .hub-briefing-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 360px) {
  .hub-briefing-grid { grid-template-columns: 1fr; }
}

.hub-briefing-item {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  padding: 0.7rem 0.8rem;
  border-radius: 2px;
  border: 1px solid var(--faint);
  background: rgba(6,5,4,0.5);
  position: relative;
}

.hub-bstatus-go     { border-color: rgba(74,222,128,0.2);  background: rgba(74,222,128,0.04); }
.hub-bstatus-caution{ border-color: rgba(251,191,36,0.2);  background: rgba(251,191,36,0.04); }
.hub-bstatus-no-go  { border-color: rgba(248,113,113,0.25);background: rgba(248,113,113,0.05); }

.hub-briefing-icon  { font-size: 1.1rem; flex-shrink: 0; margin-top: 0.1rem; }

.hub-briefing-content { flex: 1; }
.hub-briefing-label {
  font-family: var(--mono);
  font-size: 0.4rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dimmed);
  margin-bottom: 0.15rem;
}

.hub-briefing-val {
  font-family: var(--mono);
  font-size: 0.65rem;
  letter-spacing: 0.06em;
  color: var(--text);
  margin-bottom: 0.1rem;
}

.hub-briefing-sub {
  font-family: var(--serif);
  font-size: 0.8rem;
  color: var(--dimmed);
  font-style: normal;
}

.hub-briefing-badge {
  font-family: var(--mono);
  font-size: 0.6rem;
  width: 18px; height: 18px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-weight: bold;
  margin-left: auto;
}

.hub-bbadge-go      { background: rgba(74,222,128,0.2);  color: #4ade80; }
.hub-bbadge-caution { background: rgba(251,191,36,0.2);  color: #fbbf24; }
.hub-bbadge-no-go   { background: rgba(248,113,113,0.2); color: #f87171; }

/* ════════════════════════════════════════════════════
   GOLDCAST TAB — Goldcast.html visual consistency
════════════════════════════════════════════════════ */

/* Panel background: warm ember glow, matches goldcast form-card */
.hub-panel--gold {
  background: rgba(18, 16, 22, 0.55);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border-color: rgba(232,129,42,0.22);
}

/* Top accent bar on goldcast panel: 2px amber-to-gold gradient (like goldcast cards) */
.hub-panel--gold::before {
  content: '';
  display: block;
  height: 2px;
  margin: -1.5rem -1.5rem 1.5rem;
  background: linear-gradient(90deg, transparent 5%, var(--amber) 35%, var(--gold, #f5c518) 65%, transparent 95%);
  opacity: 0.55;
}

/* Score ring: gold fill on goldcast tab, amber on others */
.hub-ring-fill--gold {
  stroke: var(--amber);
}

/* Score ring track: warmer on gold panel */
.hub-panel--gold .hub-ring-track {
  stroke: rgba(232,129,42,0.12);
}

/* Score card: frosted neutral */
.hub-panel--gold .hub-card--score {
  background:
    radial-gradient(ellipse 120% 80% at 50% 100%, rgba(232,129,42,0.07) 0%, transparent 70%),
    rgba(18, 16, 22, 0.6);
  border-color: rgba(232,129,42,0.22);
}

/* Score number: large, serif, goldcast-style warm color */
.hub-panel--gold .hub-ring-num {
  font-family: var(--serif);
  font-size: 2.2rem;
  font-weight: 300;
  letter-spacing: -0.02em;
  color: var(--text);
}

/* Verdict label — match goldcast color bands exactly */
.hub-panel--gold .hub-card__score-label {
  font-family: var(--serif);
  font-style: normal;
  font-size: 1.3rem;
  letter-spacing: 0.02em;
  text-transform: none;
  margin-top: 0.4rem;
}

/* Color-coded verdict states matching goldcast .col-epic/great/decent/weak */
.hub-panel--gold .hub-card__score-label.gc-epic   { color: #ff8040; }
.hub-panel--gold .hub-card__score-label.gc-great  { color: var(--gold, #f5c518); }
.hub-panel--gold .hub-card__score-label.gc-decent { color: #9abf98; }
.hub-panel--gold .hub-card__score-label.gc-weak   { color: #7899aa; }

/* Goldcast cards: amber-tinted borders, warmer backgrounds */
.hub-panel--gold .hub-card {
  background: rgba(20, 10, 4, 0.6);
  border-color: rgba(232,129,42,0.14);
}

/* Sunset time card — headline-weight, matches goldcast shoot-window-time */
.hub-panel--gold #gcSunsetTime {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 1.9rem;
  letter-spacing: 0.04em;
  color: var(--amber);
  line-height: 1.3;
  margin-bottom: 0.25rem;
}

/* Best window time — slightly smaller but same serif treatment */
.hub-panel--gold #gcWindow {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 1.8rem;
  letter-spacing: 0.04em;
  color: var(--amber);
  line-height: 1.3;
  margin-bottom: 0.25rem;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  word-break: break-word;
}

/* Sub-labels: italic serif, dimmed — matches goldcast subtext */
.hub-panel--gold .hub-card__sub {
  font-family: var(--serif);
  font-style: normal;
  font-size: 1rem;
  color: var(--dimmed, rgba(253,244,232,0.28));
  line-height: 1.45;
}

/* Sky Reading card: match goldcast narrative-text — larger, looser line height */
.hub-panel--gold .hub-card__reading {
  font-family: var(--serif);
  font-size: 0.98rem;
  line-height: 1.82;
  color: rgba(253,244,232,0.55);
  font-weight: 300;
  font-style: normal;
}

/* Eyebrow labels: amber on goldcast panel */
.hub-panel--gold .hub-card__eyebrow {
  color: rgba(232,129,42,0.65);
  letter-spacing: 0.22em;
}

/* Why this score toggle: amber hover */
.hub-panel--gold .hub-why {
  border-color: rgba(232,129,42,0.15);
}

.hub-panel--gold .hub-why__toggle {
  background: rgba(18, 8, 3, 0.55);
}

.hub-panel--gold .hub-why__toggle:hover {
  background: rgba(232,129,42,0.07);
  color: var(--amber);
}

/* Positive/neutral/negative factors: goldcast amber tint on pos */
.hub-panel--gold .hub-factor--pos {
  background: rgba(232,129,42,0.07);
  border-color: rgba(232,129,42,0.2);
}

.hub-panel--gold .hub-factor--pos .hub-factor__icon { color: var(--amber); }

/* Nearby section: amber-tinted */
.hub-panel--gold .hub-nearby {
  background: rgba(14, 7, 2, 0.55);
  border-color: rgba(232,129,42,0.12);
}

.hub-panel--gold .hub-nearby__label {
  color: rgba(232,129,42,0.6);
}

/* CTA button: goldcast gradient style */
.hub-cta--gold {
  background: rgba(232,129,42,0.14);
  border-color: rgba(232,129,42,0.32);
  color: var(--amber);
  font-style: normal;
  font-family: var(--serif);
  font-size: 0.88rem;
  letter-spacing: 0.03em;
  text-transform: none;
}

.hub-cta--gold:hover {
  background: rgba(232,129,42,0.24);
  border-color: rgba(232,129,42,0.5);
}

.hub-score-pill--gold .hub-score-pill__val {
  font-size: 0.5rem;
  letter-spacing: 0;
}
.hub-score-pill--gold .hub-score-pill__val {
  font-size: .9rem;
}

/* Score quality ring animation override: amber for goldcast */
.hub-panel--gold .hub-ring-fill--gold {
  stroke: var(--amber);
  transition: stroke-dasharray 1.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Active goldcast tab: amber underline */
.hub-tab--gold.active {
  color: var(--amber);
  background: rgba(18, 8, 4, 0.95);
}

.hub-tab--gold::after {
  background: linear-gradient(90deg, var(--amber), #f5c518);
}

/* Score pill active state — amber tint */
.hub-score-pill--gold.active {
  background: rgba(232,129,42,0.1);
  border-color: rgba(232,129,42,0.35);
  color: var(--amber);
}

/* Loading text: amber spinner */
.hub-panel--gold .hub-panel__loading {
  color: rgba(232,129,42,0.5);
}

/* Second row of cards (Sky Reading wide card) */
.hub-panel--gold .hub-cards-row + .hub-cards-row .hub-card--wide {
  border-left: 2px solid rgba(232,129,42,0.35);
  padding-left: 1.2rem;
}

/* Alert inline section: amber pulse on goldcast */
.hub-panel--gold .hub-alert-inline {
  border-color: rgba(232,129,42,0.15);
}



/* ════════════════════════════════════════════════════
   HUB DATE INPUT
════════════════════════════════════════════════════ */

.hub-date-input {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(246,242,234,0.12);
  border-radius: 8px;
  color: var(--muted);
  text-align: left;
  font-family: var(--mono);
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  padding: 0 0.8rem;
  min-height: 48px;
  outline: none;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color 0.2s;
  flex-shrink: 0;
  white-space: nowrap;
}

.hub-date-input:focus { border-color: rgba(232,129,42,0.35); }
.hub-date-input::-webkit-calendar-picker-indicator {
  filter: invert(0.6) sepia(0.3);
  cursor: pointer;
}

@media (max-width: 915px){
  .hub-date-input {
    flex: 1;
    min-width: 0;
    font-size: 0.65rem;       /* smaller base size for mobile */
    white-space: nowrap;
    overflow: hidden;        /* prevents spilling */
    text-overflow: clip;     /* just clips excess text */
    padding: 0 0.5rem;
  }
}



/* ════════════════════════════════════════════════════
   GOLDCAST PANEL TOPBAR (refresh / date / tod controls)
════════════════════════════════════════════════════ */

.gc-panel-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-bottom: 1.2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(232,129,42,0.12);
}

.gc-panel-loc {
  font-family: var(--serif);
  font-style: normal;
  font-size: 0.95rem;
  color: var(--muted);
  flex: 1 1 0;
  min-width: 0;
  max-width: none;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  word-break: break-word;
}

.gc-panel-controls {
  display: flex;
  gap: 0.45rem;
  align-items: center;
  flex-shrink: 0;
  flex-wrap: nowrap;
  flex-shrink: 0;
}

.gc-tod-select {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.1em;
  padding: 0.4rem 1.8rem 0.4rem 0.7rem;
  outline: none;
  min-height: 34px;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(253,244,232,0.3)'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.5rem center;
  background-size: 7px;
  transition: border-color 0.2s;
  flex-shrink: 0;
}
.gc-tod-select option { background: #0c0a08; color: var(--text); }
.gc-tod-select:focus { border-color: rgba(232,129,42,0.35); }

.gc-date-pick {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.07em;
  padding: 0.4rem 0.7rem;
  outline: none;
  min-height: 34px;
  cursor: pointer;
  -webkit-appearance: none;
  transition: border-color 0.2s;
  flex-shrink: 0;
}
.gc-date-pick:focus { border-color: rgba(232,129,42,0.35); }
.gc-date-pick::-webkit-calendar-picker-indicator {
  filter: invert(0.6) sepia(0.3);
  cursor: pointer;
  opacity: 0.6;
}

.gc-refresh-btn {
  background: rgba(232,129,42,0.18);
  border: 1px solid rgba(232,129,42,0.32);
  border-radius: 2px;
  color: var(--amber);
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.4rem 0.9rem;
  min-height: 34px;
  cursor: pointer;
  flex-shrink: 0;
  transition: 0.2s, border-color 0.2s, transform 0.15s;
}
.gc-refresh-btn:hover { background: rgba(232,129,42,0.30); border-color: rgba(232,129,42,0.5); transform: translateY(-1px); }
.gc-refresh-btn:active { transform: scale(0.97); }

@media (max-width: 480px) {
  .gc-panel-topbar { flex-direction: column; align-items: flex-start; }
  .gc-panel-controls { width: 100%; }
}


/* ════════════════════════════════════════════════════
   WHY THIS SCORE — Goldcast format
   (more-data-toggle, why-score-card, factor-*, band-*)
════════════════════════════════════════════════════ */

.more-data-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  padding: 0.85rem 1.1rem;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border);
  border-radius: 2px;
  user-select: none;
  transition: 0.2s, border-color 0.2s;
}

.more-data-toggle:hover {
  background: rgba(255,255,255,0.04);
  border-color: var(--border-hover);
}

.gc-why-toggle:hover {
  background: rgba(232,129,42,0.06);
  border-color: rgba(232,129,42,0.3);
}

.more-data-toggle-label {
  font-family: var(--mono);
  font-size: 0.48rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.more-data-arrow {
  font-family: var(--mono);
  font-size: 0.7rem;
  color: var(--dimmed);
  transition: transform 0.3s;
  flex-shrink: 0;
}

.more-data-arrow.open { transform: rotate(180deg); }

.more-data-body {
  display: none;
  border: 1px solid var(--border);
  border-top: none;
  border-radius: 0 0 2px 2px;
  overflow: hidden;
}

.more-data-body.open { display: block; }

/* Why score card */
.why-score-card {
  background: rgba(10,6,3,0.65);
  border: none;
  padding: 1rem 1.1rem;
}

.why-score-grid {
  display: grid;
  grid-template-columns: 1fr 0.7fr 1.4fr;
  gap: 0.35rem 0.7rem;
}

.why-factor { display: contents; }

.factor-label {
  font-family: var(--mono);
  font-size: 0.5rem;
  color: var(--muted);
  letter-spacing: 0.04em;
  padding: 0.15rem 0;
}

.factor-val {
  font-family: var(--mono);
  font-size: 0.5rem;
  text-align: center;
  padding: 0.15rem 0;
}

.factor-note {
  font-family: var(--mono);
  font-size: 0.5rem;
  text-align: right;
  color: rgba(253,244,232,0.28);
  padding: 0.15rem 0;
}

/* Why sentence */
.why-sentence {
  font-family: var(--serif);
  font-size: 0.85rem;
  color: rgba(253,244,232,0.6);
  font-style: normal;
  margin: 0 1.1rem 0.5rem;
  padding-top: 0.7rem;
  border-top: 1px solid rgba(253,244,232,0.08);
  line-height: 1.65;
}

/* Score bands */
.why-bands-section {
  margin: 0 1.1rem 1rem;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(253,244,232,0.07);
}

.why-bands-label {
  font-family: var(--mono);
  font-size: 0.4rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dimmed);
  margin-bottom: 0.5rem;
}

.explainer-bands {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.band-row {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
}

.band-swatch {
  width: 9px; height: 9px;
  border-radius: 1px;
  flex-shrink: 0;
  margin-top: 3px;
}

.band-info {
  font-family: var(--mono);
  font-size: 0.48rem;
  letter-spacing: 0.04em;
  color: var(--dimmed);
  line-height: 1.6;
}

.band-info strong {
  font-weight: 500;
  color: var(--muted);
}

.band-row-active .band-info {
  color: var(--text);
}

.band-row-active .band-info strong {
  font-weight: 600;
  color: var(--text);
}


/* ════════════════════════════════════════════════════
   NOTIF CARD — Goldcast alert form (goldcast.css port)
════════════════════════════════════════════════════ */

.notif-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(246,242,234,0.1);
  border-radius: 10px;
  padding: 1.2rem 1.3rem 1.4rem;
  position: relative;
  overflow: hidden;
}

.notif-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 5%, #f5c518 40%, #e8812a 60%, transparent 95%);
  opacity: 0.3;
}

.notif-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.55rem;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.notif-title {
  font-family: var(--mono);
  font-size: 0.5rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--amber);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.notif-title::before {
  content: '';
  display: inline-block;
  width: 5px; height: 5px;
  background: var(--amber);
  border-radius: 50%;
  animation: gcpulse 2.2s ease-in-out infinite;
}

.notif-body {
  font-family: var(--serif);
  font-size: 0.88rem;
  line-height: 1.65;
  color: var(--muted);
  margin-bottom: 0.9rem;
}

.notif-fields-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.45rem;
  margin-bottom: 0.45rem;
}

@media (max-width: 400px) {
  .notif-fields-grid { grid-template-columns: 1fr; }
}

.notif-field {
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
}

.notif-field label {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dimmed);
}

.notif-field input,
.notif-field select {
  background: rgba(253,244,232,0.04);
  border: 1px solid rgba(253,244,232,0.1);
  border-radius: 2px;
  padding: 0.5rem 0.7rem;
  color: var(--text);
  font-family: var(--mono);
  font-size: 0.58rem;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  width: 100%;
  min-height: 40px;
  -webkit-appearance: none;
  appearance: none;
  letter-spacing: 0.04em;
}

.notif-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(253,244,232,0.3)'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.7rem center;
  background-size: 8px;
  padding-right: 2rem;
  cursor: pointer;
}

.notif-field select option { background: #1c0a06; color: var(--text); }
.notif-field input::placeholder { color: rgba(253,244,232,0.2); }

.notif-field input:focus,
.notif-field select:focus {
  border-color: rgba(245,197,24,0.38);
  box-shadow: 0 0 0 3px rgba(232,129,42,0.12);
}

.notif-email-row {
  display: flex;
  gap: 0.45rem;
  align-items: flex-end;
}

.notif-email-row .notif-field { flex: 1; }

.notif-btn {
  background: linear-gradient(135deg, #f5c518, #e8812a);
  border: none;
  border-radius: 2px;
  height: 40px;
  padding: 0 1rem;
  color: #100806;
  font-family: var(--mono);
  font-size: 0.52rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: opacity 0.2s, transform 0.15s;
  box-shadow: 0 2px 10px rgba(245,197,24,0.12);
  min-width: 84px;
}

.notif-btn:hover { opacity: 0.88; transform: translateY(-1px); }
.notif-btn:disabled { opacity: 0.38; cursor: not-allowed; transform: none; }

.notif-btn.enabled {
  background: rgba(60,180,80,0.12);
  border: 1px solid rgba(60,180,80,0.45);
  color: #80e090;
  cursor: default;
  box-shadow: none;
  transform: none;
}

.notif-success-inline {
  display: none;
  font-family: var(--mono);
  font-size: 0.5rem;
  color: #80e090;
  letter-spacing: 0.08em;
  margin-top: 0.5rem;
  padding: 0.45rem 0.7rem;
  background: rgba(60,180,80,0.06);
  border: 1px solid rgba(60,180,80,0.18);
  border-radius: 2px;
  line-height: 1.5;
}

.notif-error-inline {
  display: none;
  font-family: var(--mono);
  font-size: 0.46rem;
  color: #e05050;
  letter-spacing: 0.06em;
  margin-top: 0.4rem;
  line-height: 1.5;
}

@media (max-width: 400px) {
  .notif-email-row { flex-wrap: wrap; }
  .notif-btn { flex: 1; height: 40px; }
}



/* ════════════════════════════════════════════════════
   SEARCH Z-INDEX FIX — dropdown must float above cards
════════════════════════════════════════════════════ */

.hub-search-block {
  position: relative;
  z-index: 20;
}

.hub-search-row {
  position: relative;
  z-index: 20;
}

.hub-search-inner {
  position: relative;
  z-index: 20;
}

.hub-dropdown {
  z-index: 300;
}

/* Pre-search card and tool card sit below search */
#hubPreSearch {
  position: relative;
  z-index: 1;
}


/* Blank default option on tod select renders dimmed */
.gc-tod-select option[value=""][disabled] {
  color: rgba(253,244,232,0.28);
}

/* ════════════════════════════════════
   HUB PAGE — SEARCH ROW & CONTROLS
   ════════════════════════════════════ */

/* Search controls row */
.hub-search-controls-row {
  display: flex;
  gap: 0.45rem;
  align-items: center;
  width: 100%;
  flex-wrap: nowrap;
  box-sizing: border-box;
}

.hub-search-controls-row .hub-date-input {
  flex: 1;
  min-width: 0;
  min-height: 48px;
  box-sizing: border-box;
}

.hub-search-controls-row .hub-units-select {
  flex: 1;
  min-width: 0;
  min-height: 48px;
  font-size: 0.6rem;
  box-sizing: border-box;
}

.hub-search-controls-row .hub-search-btn {
  flex: 1;
  min-width: 0;
  min-height: 48px;
  font-size: 0.5rem;
  padding: 0 0.7rem;
  white-space: nowrap;
  box-sizing: border-box;
}

/* Score bar top row */
.hub-score-bar-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  width: 100%;
}

/* Better Light distance */
.bl-dist {
  font-size: 0.60rem;
  opacity: 0.55;
}

/* Goldcast topbar controls */
.gc-tod-select,
.gc-date-pick,
.gc-refresh-btn {
  flex-shrink: 0;
  white-space: nowrap;
}

/* ── TABLET ── */
@media (max-width: 915px) {
  .hub-tab {
    font-size: 0.5rem;
    padding: 0.8rem 0.3rem;
    letter-spacing: 0.03em;
  }
  .hub-score-pill { flex-shrink: 1; min-width: 0; }
  .hub-score-pill__name { display: none; }
}

/* ── MOBILE ── */
@media (max-width: 600px) {
  .hub-search-controls-row {
    flex-wrap: wrap;
    gap: 0.4rem;
    width: 100%;
    max-width: 100vw;
    overflow: hidden;
  }

  .hub-search-controls-row .hub-date-input,
  .hub-search-controls-row .hub-units-select,
  .hub-search-controls-row .hub-search-btn {
    flex: 1 1 0;
    width: 0;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
    font-size: 0.55rem;
  }

  input[type="date"],
  select {
    max-width: 100%;
    box-sizing: border-box;
  }

  .gc-panel-topbar { flex-direction: column !important; align-items: stretch !important; }
  .gc-panel-controls { width: 100%; }
  .gc-tod-select,
  .gc-date-pick { flex: 1; min-width: 0; }
  .bl-dist  { font-size: 0.52rem; }
  .bl-emoji { font-size: 0.6rem !important; letter-spacing: 0 !important; }
}



/* ════════════════════════════════════════════════════
   STARCAST PANEL — StarCast visual consistency
════════════════════════════════════════════════════ */

/* Panel background: deep night blue, matches starcast form-card */
.hub-panel--star {
  background: rgba(18, 16, 22, 0.55);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border-color: rgba(126,184,247,0.22);
}

/* Top accent bar */
.hub-panel--star::before {
  content: '';
  display: block;
  height: 2px;
  margin: -1.5rem -1.5rem 1.5rem;
  background: linear-gradient(90deg, transparent 5%, #4a7fc8 35%, var(--star) 65%, transparent 95%);
  opacity: 0.5;
}

/* Cards: warm ember background matching goldcast — same as .hub-panel--gold cards */
.hub-panel--star .hub-card {
  background: rgba(20, 10, 4, 0.6);
  border-color: rgba(126,184,247,0.14);
}

.hub-panel--star .hub-card--score {
  background:
    radial-gradient(ellipse 120% 80% at 50% 100%, rgba(70,130,245,0.07) 0%, transparent 70%),
    rgba(10, 6, 3, 0.65);
  border-color: rgba(126,184,247,0.2);
}

/* Score ring: star blue */
.hub-panel--star .hub-ring-track {
  stroke: rgba(126,184,247,0.12);
}

/* Score number: serif, large */
.hub-panel--star .hub-ring-num {
  font-family: var(--serif);
  font-size: 2.2rem;
  font-weight: 300;
  letter-spacing: -0.02em;
  color: var(--text);
}

/* Verdict label — starcast color bands */
.hub-panel--star .hub-card__score-label {
  font-family: var(--serif);
  font-style: normal;
  font-size: 1.3rem;
  letter-spacing: 0.02em;
  text-transform: none;
  margin-top: 0.4rem;
}

.hub-panel--star .hub-card__score-label.sc-pristine { color: #d4eaff; }
.hub-panel--star .hub-card__score-label.sc-excellent { color: #7eb8f7; }
.hub-panel--star .hub-card__score-label.sc-good      { color: #4a7fd4; }
.hub-panel--star .hub-card__score-label.sc-poor      { color: #6a7a9a; }

/* Big time/data display in cards */
.hub-panel--star #scWindow,
.hub-panel--star #scBortle {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 1.9rem;
  letter-spacing: 0.04em;
  color: var(--star);
  line-height: 1.3;
  margin-bottom: 0.25rem;
}

/* Sub-labels */
.hub-panel--star .hub-card__sub {
  font-family: var(--serif);
  font-style: normal;
  font-size: 1rem;
  color: var(--dimmed);
  line-height: 1.45;
}

/* Sky Reading */
.hub-panel--star .hub-card__reading {
  font-family: var(--serif);
  font-size: 0.98rem;
  line-height: 1.82;
  color: rgba(253,244,232,0.55);
  font-weight: 300;
  font-style: normal;
}

/* Eyebrow labels */
.hub-panel--star .hub-card__eyebrow {
  color: rgba(126,184,247,0.6);
  letter-spacing: 0.22em;
}

/* Why this score toggle */
.hub-panel--star .more-data-toggle {
  border-color: rgba(126,184,247,0.15);
}
.hub-panel--star .more-data-toggle:hover {
  background: rgba(126,184,247,0.06);
  border-color: rgba(126,184,247,0.3);
}

/* CTA button — starcast blue style, serif like goldcast */
.hub-cta--star {
  background: rgba(126,184,247,0.12);
  border: 1px solid rgba(126,184,247,0.3);
  color: var(--star);
  font-style: normal;
  font-family: var(--serif);
  font-size: 0.88rem;
  letter-spacing: 0.03em;
  text-transform: none;
}
.hub-cta--star:hover {
  background: rgba(126,184,247,0.2);
  border-color: rgba(126,184,247,0.5);
}

/* Topbar — same as goldcast gc-panel-topbar */
.sc-panel-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-bottom: 1.2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(126,184,247,0.12);
}
.sc-panel-loc {
  font-family: var(--serif);
  font-style: normal;
  font-size: 0.95rem;
  color: var(--muted);
  flex: 1 1 0;
  min-width: 0;
  white-space: normal;
  overflow: visible;
  word-break: break-word;
}
.sc-panel-controls {
  display: flex;
  gap: 0.45rem;
  align-items: center;
  flex-shrink: 0;
}
.sc-target-select {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.1em;
  padding: 0.4rem 1.8rem 0.4rem 0.7rem;
  outline: none;
  min-height: 34px;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(253,244,232,0.3)'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.5rem center;
  background-size: 7px;
  transition: border-color 0.2s;
}
.sc-target-select option { background: #0c0a08; color: var(--text); }
.sc-target-select:focus { border-color: rgba(126,184,247,0.35); }

.sc-date-pick {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.07em;
  padding: 0.4rem 0.7rem;
  outline: none;
  min-height: 34px;
  cursor: pointer;
  -webkit-appearance: none;
  transition: border-color 0.2s;
}
.sc-date-pick:focus { border-color: rgba(126,184,247,0.35); }
.sc-date-pick::-webkit-calendar-picker-indicator {
  filter: invert(0.6) sepia(0.3);
  cursor: pointer;
  opacity: 0.6;
}

.sc-refresh-btn {
  background: rgba(126,184,247,0.15);
  border: 1px solid rgba(126,184,247,0.3);
  border-radius: 2px;
  color: var(--star);
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.4rem 0.9rem;
  min-height: 34px;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.2s, border-color 0.2s, transform 0.15s;
}
.sc-refresh-btn:hover { background: rgba(126,184,247,0.26); border-color: rgba(126,184,247,0.5); transform: translateY(-1px); }
.sc-refresh-btn:active { transform: scale(0.97); }

/* Better Skies Nearby — styled like Better Light Nearby */
.hub-panel--star .better-skies-banner {
  margin-bottom: 0.75rem;
  border: 1px solid rgba(126,184,247,0.14);
  border-radius: 3px;
  overflow: hidden;
  background: rgba(6,8,18,0.5);
}
.hub-panel--star .better-skies-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid rgba(126,184,247,0.1);
}
.hub-panel--star .better-skies-eyebrow {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(126,184,247,0.6);
}
.hub-panel--star .better-skies-link {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.1em;
  color: var(--dimmed);
  text-decoration: none;
}
.hub-panel--star .better-skies-link:hover { color: var(--star); }
.hub-panel--star .better-skies-scanning {
  font-family: var(--mono);
  font-size: 0.44rem;
  letter-spacing: 0.1em;
  color: var(--faint);
  padding: 0.75rem 1rem;
  animation: pulse 1.4s ease infinite;
}
.hub-panel--star .better-skies-none {
  font-family: var(--serif);
  font-size: 0.88rem;
  color: var(--dimmed);
  padding: 0.75rem 1rem;
  font-style: normal;
}
.hub-panel--star .better-skies-item {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid rgba(126,184,247,0.08);
  text-decoration: none;
  transition: background 0.15s;
  cursor: pointer;
}
.hub-panel--star .better-skies-item:last-child { border-bottom: none; }
.hub-panel--star .better-skies-item:hover { background: rgba(126,184,247,0.05); }
.hub-panel--star .bs-rank {
  font-family: var(--serif);
  font-size: 0.42rem;
  color: var(--faint);
  width: 14px;
  flex-shrink: 0;
}
.hub-panel--star .bs-left { flex: 1; min-width: 0; }
.hub-panel--star .bs-place {
  font-family: var(--serif);
  font-size: 0.9rem;
  letter-spacing: 0.06em;
  color: var(--text);
  margin-bottom: 0.15rem;
}
.hub-panel--star .bs-dist {
  font-family: var(--mono);
  font-size: 0.58rem;
  color: var(--dimmed);
  letter-spacing: 0.06em;
}
.hub-panel--star .bs-right {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  flex-shrink: 0;
}
.hub-panel--star .bs-score {
  font-family: var(--mono);
  font-size: 0.58rem;
  font-weight: 500;
}
.hub-panel--star .bs-arrow {
  font-family: var(--mono);
  font-size: 0.7rem;
  color: var(--faint);
}
.hub-panel--star .better-skies-item:hover .bs-arrow { color: var(--star); }

@media (max-width: 480px) {
  .sc-panel-topbar { flex-direction: column !important; align-items: stretch !important; }
  .sc-panel-controls { width: 100%; }
  .sc-target-select { flex: 1; min-width: 0; }
  .sc-date-pick { flex: 1; min-width: 0; }
}

/* StarCast — Best Dark Window: force single line, scale to fit */
.hub-panel--star #scWindow {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(1.1rem, 2.8vw, 1.9rem);
  letter-spacing: 0.02em;
  color: var(--star);
  line-height: 1.3;
  margin-bottom: 0.25rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Score bar date ── */
.hub-score-bar__date {
  font-family: var(--mono);
  font-size: 0.5rem;
  letter-spacing: 0.1em;
  color: var(--amber);
  flex-shrink: 0;
  padding: 0.15rem 0.4rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
}

/* ── Dronecast panel topbar ── */
.dc-panel-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-bottom: 1.2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(45,212,191,0.12);
}
.dc-panel-loc {
  font-family: var(--serif);
  font-style: normal;
  font-size: 0.95rem;
  color: var(--muted);
  flex: 1 1 0;
  min-width: 0;
  white-space: normal;
  overflow: visible;
  word-break: break-word;
}
.dc-panel-controls {
  display: flex;
  gap: 0.45rem;
  align-items: center;
  flex-shrink: 0;
  flex-wrap: nowrap;
}
.dc-drone-select {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--muted);
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.08em;
  padding: 0.4rem 1.8rem 0.4rem 0.7rem;
  outline: none;
  min-height: 34px;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(253,244,232,0.3)'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.5rem center;
  background-size: 7px;
  transition: border-color 0.2s;
  max-width: 180px;
}
.dc-drone-select option { background: #0c0a08; color: var(--text); }
.dc-drone-select:focus { border-color: rgba(45,212,191,0.35); }

.dc-refresh-btn {
  background: rgba(45,212,191,0.15);
  border: 1px solid rgba(45,212,191,0.3);
  border-radius: 2px;
  color: var(--teal);
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.4rem 0.9rem;
  min-height: 34px;
  cursor: pointer;
  flex-shrink: 0;
  transition: 0.2s, border-color 0.2s, transform 0.15s;
}
.dc-refresh-btn:hover { background: rgba(45,212,191,0.26); border-color: rgba(45,212,191,0.5); transform: translateY(-1px); }
.dc-refresh-btn:active { transform: scale(0.97); }

@media (max-width: 480px) {
  .dc-panel-topbar { flex-direction: column !important; align-items: stretch !important; }
  .dc-panel-controls { width: 100%; }
  .dc-drone-select { flex: 1; min-width: 0; max-width: none; }
}

/* ── Dronecast why-score teal tint ── */
.hub-panel--teal .more-data-toggle {
  border-color: rgba(45,212,191,0.15);
}
.hub-panel--teal .more-data-toggle:hover {
  background: rgba(45,212,191,0.05);
  border-color: rgba(45,212,191,0.3);
}

/* ── Starcast cards: neutral frosted ── */
.hub-panel--star .hub-card {
  background: rgba(18, 16, 22, 0.6);
  border-color: rgba(126,184,247,0.14);
}

/* ── Flight briefing mobile: 2 columns at 480px, 1 below 360px ── */
@media (max-width: 480px) {
  .hub-briefing-grid { grid-template-columns: 1fr 1fr; gap: 0.5rem; }
  .hub-briefing-label { font-size: 0.38rem; }
  .hub-briefing-val { font-size: 0.58rem; }
  .hub-briefing-sub { font-size: 0.72rem; }
  .hub-briefing-icon { font-size: 0.95rem; }
}
@media (max-width: 340px) {
  .hub-briefing-grid { grid-template-columns: 1fr; }
}

/* ════ DRONECAST TAB — card backgrounds match goldcast ════ */

.hub-panel--teal .hub-card {
  background: rgba(18, 16, 22, 0.6);
  border-color: rgba(45,212,191,0.14);
}

.hub-panel--teal .hub-card--score {
  background:
    radial-gradient(ellipse 120% 80% at 50% 100%, rgba(45,212,191,0.07) 0%, transparent 70%),
    rgba(18, 16, 22, 0.6);
  border-color: rgba(45,212,191,0.2);
}

/* Best Flight Window text — serif large like goldcast #gcWindow */
.hub-panel--teal #dcWindow {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 1.7rem;
  letter-spacing: 0.04em;
  color: var(--teal);
  line-height: 1.3;
  margin-bottom: 0.25rem;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  word-break: break-word;
}

.hub-panel--teal .hub-card__sub {
  font-family: var(--serif);
  font-style: normal;
  font-size: 1rem;
  color: var(--dimmed);
  line-height: 1.45;
}

.hub-panel--teal .hub-card__reading {
  font-family: var(--serif);
  font-size: 0.98rem;
  line-height: 1.82;
  color: rgba(253,244,232,0.55);
  font-weight: 300;
  font-style: normal;
}

.hub-panel--teal .hub-card__eyebrow {
  color: rgba(45,212,191,0.6);
  letter-spacing: 0.22em;
}

.hub-panel--teal .hub-ring-track {
  stroke: rgba(45,212,191,0.12);
}

.hub-panel--teal .hub-ring-num {
  font-family: var(--serif);
  font-size: 2.2rem;
  font-weight: 300;
  letter-spacing: -0.02em;
  color: var(--text);
}

/* ════ FLIGHT BRIEFING — mobile fix ════ */

.hub-briefing-grid {
  grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 600px) {
  .hub-briefing-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 360px) {
  .hub-briefing-grid { grid-template-columns: 1fr; }
}

.hub-briefing-item {
  min-width: 0;
  overflow: hidden;
}

.hub-briefing-val {
  font-size: 0.6rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.hub-briefing-sub {
  font-size: 0.75rem;
  white-space: normal;
  word-break: break-word;
  overflow-wrap: break-word;
}

.hub-briefing-label {
  font-size: 0.38rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ════ FLIGHT BRIEFING — mobile spacing & consistent badges ════ */

/* Prevent cards from overflowing their grid cell */
.hub-briefing-item {
  min-width: 0;
  overflow: hidden;
  box-sizing: border-box;
}

/* Label: truncate cleanly, never wrap */
.hub-briefing-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Value: allow wrapping on tiny screens */
.hub-briefing-val {
  white-space: normal;
  word-break: break-word;
  overflow-wrap: break-word;
  line-height: 1.3;
}

/* Sub: allow wrapping, tighter size on mobile */
.hub-briefing-sub {
  white-space: normal;
  word-break: break-word;
  overflow-wrap: break-word;
  line-height: 1.4;
}

/* Badge: fixed size, centered symbol, consistent across all three states */
.hub-briefing-badge {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 0.55rem;
  font-family: var(--mono);
  font-weight: 700;
  line-height: 1;
  align-self: flex-start;
  margin-top: 0.1rem;
}

/* Tighten grid gap on mobile so cards don't overflow */
@media (max-width: 600px) {
  .hub-briefing-grid {
    grid-template-columns: 1fr 1fr;
    gap: 0.45rem;
  }
  .hub-briefing-item {
    padding: 0.55rem 0.6rem;
    gap: 0.4rem;
  }
  .hub-briefing-val {
    font-size: 0.58rem;
  }
  .hub-briefing-sub {
    font-size: 0.7rem;
  }
  .hub-briefing-label {
    font-size: 0.36rem;
  }
  .hub-briefing-icon {
    font-size: 0.9rem;
  }
  .hub-briefing-badge {
    width: 17px;
    height: 17px;
    font-size: 0.48rem;
  }
}

@media (max-width: 360px) {
  .hub-briefing-grid { grid-template-columns: 1fr; }
}

.hub-alert-inline--star { border-color: rgba(126,184,247,0.25); }
.hub-alert-pulse--star { background: var(--star) !important; box-shadow: 0 0 0 3px rgba(126,184,247,0.18) !important; }
.notif-btn--star {
  background: rgba(126,184,247,0.12) !important;
  border: 1px solid rgba(126,184,247,0.45) !important;
  color: var(--star) !important;
  box-shadow: none !important;
}
.notif-btn--star:hover { background: rgba(126,184,247,0.2) !important; opacity: 1; }
.notif-btn--star:disabled { background: rgba(126,184,247,0.06) !important; color: rgba(126,184,247,0.4) !important; }
#scAlertDetails .notif-field input:focus,
#scAlertDetails .notif-field select:focus {
  border-color: rgba(126,184,247,0.38) !important;
  box-shadow: 0 0 0 3px rgba(126,184,247,0.12) !important;
}
#scAlertDetails .notif-title { color: var(--star); }

/* ── DC BRIEFING: MOBILE PILL TABS ── */
.dc-briefing-desktop { display: block; }
.dc-briefing-mobile  { display: none; }

@media (max-width: 560px) {
  .dc-briefing-desktop { display: none; }
  .dc-briefing-mobile  { display: block; }
}

.dc-pill-tabs {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 0.9rem;
  flex-wrap: nowrap;
  justify-content: space-between;
}

.dc-pill-tab {
  flex: 1;
  height: 36px;
  border-radius: 6px;
  border: 1px solid transparent;
  background: rgba(255,255,255,0.04);
  font-size: 0.95rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color 0.15s, background 0.15s;
  min-width: 0;
}

.dc-pill-tab--active {
  background: rgba(45,212,191,0.08);
}

.dc-pill-tab:hover:not(.dc-pill-tab--active) {
  background: rgba(255,255,255,0.07);
}

.dc-pill-detail {
  padding: 0.1rem 0;
}

.dc-pill-detail__top {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.4rem;
}

.dc-pill-detail__icon {
  font-size: 1rem;
  line-height: 1;
  flex-shrink: 0;
}

.dc-pill-detail__label {
  font-family: var(--mono);
  font-size: 0.5rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--teal);
  flex: 1;
}

.dc-pill-detail__badge {
  font-family: var(--mono);
  font-size: 0.48rem;
  font-weight: bold;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.dc-pill-detail__val {
  font-family: var(--serif);
  font-size: 1.4rem;
  letter-spacing: 0.04em;
  color: var(--dimmed);
  margin-bottom: 0.25rem;
  line-height: 1.2;
}

.dc-pill-detail__sub {
  font-family: var(--serif);
  font-size: 0.82rem;
  color: var(--dimmed);
  line-height: 1.5;
}

/* ── TOOL PILL GRID (In-Depth Insights) ── */
.tool-pill-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
  padding: 1rem 1rem 0.75rem;
}

@media (max-width: 480px) {
  .tool-pill-grid { grid-template-columns: repeat(2, 1fr); }
}

.tool-pill {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  padding: 0.85rem 0.5rem;
  border-radius: 10px;
  border: 1px solid rgba(246,242,234,0.08);
  background: rgba(255,255,255,0.02);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}

.tool-pill:hover { background: rgba(255,255,255,0.05); }

.tool-pill.active.tool-pill--gold { border-color: rgba(232,129,42,0.45); background: rgba(232,129,42,0.08); }
.tool-pill.active.tool-pill--star { border-color: rgba(126,184,247,0.45); background: rgba(126,184,247,0.08); }
.tool-pill.active.tool-pill--teal { border-color: rgba(45,212,191,0.45);  background: rgba(45,212,191,0.08); }
.tool-pill.active.tool-pill--mono { border-color: rgba(246,242,234,0.3);  background: rgba(255,255,255,0.05); }

.tool-pill__icon { font-size: 1.3rem; line-height: 1; }

.tool-pill__name {
  font-family: var(--mono);
  font-size: 0.46rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dimmed);
}

.tool-pill.active .tool-pill__name { color: var(--muted); }
.tool-pill.active.tool-pill--gold .tool-pill__name { color: var(--amber); }
.tool-pill.active.tool-pill--star .tool-pill__name { color: var(--star); }
.tool-pill.active.tool-pill--teal .tool-pill__name { color: var(--teal); }

.tool-pill-detail {
  border-top: 1px solid rgba(246,242,234,0.07);
  margin: 0;
}

.tool-pill-detail__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.9rem 1rem;
  text-decoration: none;
  transition: background 0.15s;
}

.tool-pill-detail__link:hover { background: rgba(255,255,255,0.03); }

.tool-pill-detail__desc {
  font-family: var(--serif);
  font-size: 0.88rem;
  color: var(--muted);
  line-height: 1.55;
  font-style: normal;
}

.tool-pill-detail__arrow {
  font-family: var(--mono);
  font-size: 0.5rem;
  letter-spacing: 0.1em;
  color: var(--dimmed);
  white-space: nowrap;
  flex-shrink: 0;
  transition: transform 0.15s;
}

.tool-pill-detail__link:hover .tool-pill-detail__arrow { transform: translateX(3px); }
