/* ─────────────────────────────────────────
   FRESTA — Inteligência Cultural
   styles.css
───────────────────────────────────────── */

/* ── Variables ── */
:root {
  /* ── Design system v2 tokens ── */
  --f-edit: 'Space Grotesk', sans-serif;
  --f-data: 'IBM Plex Mono', monospace;

  --bg-page:  #F2EFE8;
  --bg-card:  #F7F4ED;
  --bg-hero:  #FDFAF4;
  --bg-sat:   #F6EFE9;
  --bg-dark:  #161616;
  --bg-pulse: #E8E4DC;

  --ink-1:  #12110E;
  --ink-2:  #5C5950;
  --ink-3:  #9A9790;
  --ink-inv:#E4E0D8;

  --new-c:  #185A82; --new-bg:  #EBF2F7;
  --emg-c:  #466B3A; --emg-bg:  #EBF3EE;
  --grw-c:  #A85E18; --grw-bg:  #F7EFE4;
  --sat-c:  #822018; --sat-bg:  #F5ECEA;

  --amber: #B06A20;
  --green: #466B3A;
  --red:   #922018;

  --b-light: rgba(18,17,14,0.07);
  --b-med:   rgba(18,17,14,0.13);

  /* ── Legacy aliases ── */
  --black:        #12110E;
  --white:        #FDFAF4;
  --off:          #F2EFE8;
  --muted:        #9A9790;
  --font-display: var(--f-edit);
  --font-mono:    var(--f-data);
  --border:        0.5px solid var(--b-light);
  --border-strong: 0.5px solid var(--b-med);
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --text-l1: #12110E;
  --text-l2: #5C5950;
  --text-l3: #9A9790;
  --text-l4: rgba(18,17,14,0.22);
  --fill-tag: rgba(18,17,14,0.07);
  --fill-tag-text: rgba(18,17,14,0.65);
}

/* ── Reset ── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

body {
  font-family: var(--font-display);
  background: var(--white);
  color: var(--black);
  overflow-x: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  font-family: var(--font-display);
  background: none;
  border: none;
  cursor: pointer;
  color: inherit;
}

.mono {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
}

/* ── Header ── */
.site-header {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 0 2.5rem;
  height: 52px;
  border-bottom: 0.5px solid rgba(10,10,10,0.08);
  background: #F5F5F2;
  position: sticky;
  top: 0;
  z-index: 100;
}

.header-left {
  display: flex;
  flex-direction: column;
  gap: 0;
  justify-content: center;
}

.header-logo {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.1em;
  color: #0A0A0A;
  font-weight: 700;
  text-decoration: none;
  line-height: 1;
}

/* Row 2: tagline + AO VIVO side by side */
.header-bottom-line {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  margin-top: 0.35rem;
}

.header-tagline {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.02em;
  color: rgba(10,10,10,0.42);
  line-height: 1;
  font-weight: 400;
  text-transform: lowercase;
  margin-top: 2px;
}

.site-nav {
  display: flex;
  gap: 1.5rem;
  align-items: center;
  justify-content: center;
}

.site-nav a {
  font-size: 12px;
  color: rgba(10,10,10,0.45);
  text-decoration: none;
  transition: color 0.15s;
  letter-spacing: 0.01em;
}

.site-nav a:hover { color: #0A0A0A; }

/* AO VIVO — lives inside .header-bottom-line */
.header-live {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  position: relative;
  cursor: default;
}

.live-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
  animation: livepulse 2.4s ease-in-out infinite;
}

@keyframes livepulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.25; }
}

.live-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: rgba(10,10,10,0.4);
}

/* Lang selector */
.lang-selector {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  justify-content: flex-end;
}

.lang-btn {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(10,10,10,0.3);
  padding: 0;
  transition: color 0.15s;
}

.lang-btn:hover { color: rgba(10,10,10,0.7); }
.lang-btn.active { color: #0A0A0A; }

.lang-sep {
  font-size: 0.44rem;
  color: rgba(10,10,10,0.15);
}

/* ── Ticker ── */
/* ── Tension Bar ── */
@keyframes breathe {
  0%,100% { opacity: 1; }
  50%      { opacity: 0.35; }
}

.tension-bar {
  background: #0A0A0A;
  display: flex;
  align-items: center;
  padding: 0 0;
  border-bottom: none;
  overflow: hidden;
  height: 36px;
}

.tb-live {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0 1.25rem;
  border-right: 0.5px solid rgba(255,255,255,0.08);
  flex-shrink: 0;
  height: 100%;
}

.tb-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #466B3A;
  animation: breathe 2s ease-in-out infinite;
}

.tb-live-label {
  font-size: 0.5rem;
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.5);
}

.tb-items {
  display: flex;
  align-items: center;
  gap: 0;
  overflow: hidden;
  flex: 1;
  height: 100%;
}

.tb-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0 1.5rem;
  border-right: 0.5px solid rgba(255,255,255,0.06);
  height: 100%;
  cursor: pointer;
  transition: background 0.15s;
  flex-shrink: 0;
}

.tb-item:hover { background: rgba(255,255,255,0.04); }

.tb-a {
  font-family: var(--font-mono);
  font-size: 0.52rem;
  letter-spacing: 0.08em;
  color: #FAFAFA;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.tb-dir-up   { color: #466B3A; }
.tb-dir-down { color: #E24B4A; }

.tb-delta {
  font-family: var(--font-mono);
  font-size: 0.46rem;
  opacity: 0.5;
}

.tb-sep {
  font-size: 0.5rem;
  color: rgba(255,255,255,0.15);
  margin: 0 0.1rem;
}

.tb-b {
  font-family: var(--font-mono);
  font-size: 0.52rem;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.35);
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

/* ── Hero ── */
.hero {
  display: grid;
  grid-template-columns: 1fr 380px;
  border-bottom: var(--border);
  min-height: 52vh;
}

.hero-left {
  padding: 3rem 3.5rem 4rem;
  border-right: var(--border);
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.hero-right {
  display: flex;
  flex-direction: column;
}

/* System meta row */
.hero-meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.hero-dot-live {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
}

.hero-meta-text {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.04em;
  opacity: 0.4;
}

/* Three-line title */
.hero-title {
  display: flex;
  flex-direction: column;
  gap: 0;
  line-height: 0.95;
}

.ht-line {
  display: block;
  font-size: clamp(2.2rem, 6vw, 4rem);
  letter-spacing: -0.03em;
  line-height: 0.95;
}

.ht-light {
  font-weight: 300;
  color: rgba(10,10,10,0.45);
}

.ht-bold {
  font-weight: 700;
  color: var(--black);
}

.ht-dot {
  color: var(--green);
}

/* Hero subtitle */
.hero-subtitle {
  font-size: clamp(0.88rem, 1.4vw, 1rem);
  font-weight: 300;
  line-height: 1.7;
  opacity: 0.6;
  max-width: 30rem;
}

/* Right column metric blocks */
.hero-stat {
  padding: 2rem 2.5rem;
  border-bottom: var(--border);
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.4rem;
}

.hero-stat-num {
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
}

.hero-stat-label {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  opacity: 0.4;
}

/* Alert block */
.hero-alert-block {
  background: #EAF3DE;
  border-left: 3px solid #466B3A;
  padding: 2rem 2.5rem;
  flex: 1.2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.45rem;
}

.hero-alert-eyebrow {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  color: #466B3A;
}

.hero-alert-name {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--black);
  line-height: 1.2;
}

.hero-alert-pct {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: #466B3A;
  letter-spacing: 0.02em;
}

/* Scroll hint */
.hero-scroll-hint {
  margin-top: auto;
  padding-top: 1.5rem;
  opacity: 0.35;
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(4px); }
}

.hero-scroll-hint span { animation: float 3s ease-in-out infinite; display: inline-block; }

/* ── Agora Strip ── */
.agora-strip {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 0.55rem 2.5rem;
  border-bottom: 0.5px solid rgba(10,10,10,0.08);
  background: rgba(10,10,10,0.02);
}
.agora-label {
  font-family: var(--font-mono);
  font-size: 0.52rem;
  letter-spacing: 0.14em;
  color: rgba(10,10,10,0.3);
  flex-shrink: 0;
}
.agora-items {
  display: flex;
  gap: 0;
  flex-wrap: nowrap;
  overflow: hidden;
}
.agora-item {
  font-family: var(--font-mono);
  font-size: 0.54rem;
  letter-spacing: 0.04em;
  color: rgba(10,10,10,0.5);
  padding-right: 1.5rem;
  cursor: pointer;
  transition: color 0.15s;
  white-space: nowrap;
}
.agora-item:hover { color: #0A0A0A; }
.agora-item::before { content: ''; }
.agora-item.saturacao { color: #E24B4A; }
.agora-item.aceleracao { color: #BA7517; }
.agora-item.tensao { color: #466B3A; }
.agora-item.expansao { color: #466B3A; }
.agora-time {
  font-family: var(--font-mono);
  font-size: 0.44rem;
  opacity: 0.4;
  margin-left: 0.4rem;
}

.agora-freshness {
  margin-left: auto;
  font-size: 0.52rem;
  letter-spacing: 0.06em;
  color: rgba(10,10,10,0.28);
  white-space: nowrap;
  flex-shrink: 0;
}

.connection-tag:hover {
  background: #0A0A0A;
  color: #FAFAFA;
  border-color: #0A0A0A;
}

/* ── Homepage v4 overrides ── */
.site-header {
  height: 62px;
  padding: 0 1.5rem;
  align-items: flex-start;
  background: #f3f0ea;
}

.header-left,
.site-nav,
.lang-selector {
  padding-top: 0.75rem;
}

.header-logo {
  font-size: 0.82rem;
  letter-spacing: 0.16em;
}

.header-bottom-line {
  gap: 0.8rem;
  margin-top: 0.18rem;
}

.header-tagline {
  font-size: 0.64rem;
  letter-spacing: 0.05em;
  color: rgba(10, 10, 10, 0.56);
}

.live-label,
.lang-btn,
.site-nav a {
  font-size: 0.62rem;
}

.site-nav a,
.live-label,
.lang-btn,
.lang-sep {
  color: rgba(10, 10, 10, 0.5);
}

.tension-bar {
  height: 0;
  min-height: 0;
  border-bottom: none;
  background: transparent;
}

.tb-items {
  display: none;
}

.axes-bar {
  background: #1a1a1a;
  padding: 0 1.5rem;
  display: flex;
  align-items: stretch;
  gap: 1.1rem;
  overflow-x: auto;
}

.axis-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.28rem;
  padding: 0.72rem 0 0.62rem;
  border-bottom: 2px solid transparent;
  color: #666;
  white-space: nowrap;
  transition: border-color 0.18s, color 0.18s;
}

.axis-btn.active {
  border-bottom-color: #c87533;
}

.axis-btn.active .axis-a,
.axis-btn.active .axis-delta {
  color: #e8954a;
}

.axis-a,
.axis-b,
.axis-sep,
.axis-delta,
.axis-lens {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
}

.axis-a { color: #8a8a8a; font-weight: 700; }
.axis-b { color: #474747; }
.axis-sep { color: #3a3a3a; }
.axis-delta { color: #466B3A; margin-left: 0.18rem; }

.axis-lens {
  display: none;
  margin-left: auto;
  align-items: center;
  color: #646464;
}

.axis-lens.visible {
  display: inline-flex;
}

.axis-lens em {
  color: #c87533;
  font-style: normal;
  font-weight: 700;
  margin-left: 0.35rem;
}

.agora-strip {
  padding: 0.46rem 1.5rem;
  background: #eae7e0;
  gap: 0.75rem;
}

.agora-label {
  font-size: 0.56rem;
  color: rgba(10, 10, 10, 0.34);
}

.agora-items {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  overflow: auto;
}

.agora-item {
  position: relative;
  font-size: 0.62rem;
  color: rgba(10, 10, 10, 0.58);
  padding-right: 0;
}

.agora-item a {
  color: #b8722a;
  font-weight: 500;
}

.agora-item:hover {
  color: #0a0a0a;
}

.agora-tip {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  width: 220px;
  background: #1a1a1a;
  color: rgba(250, 250, 250, 0.86);
  font-family: var(--font-display);
  font-size: 0.68rem;
  line-height: 1.5;
  padding: 0.55rem 0.65rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s ease;
  z-index: 30;
  white-space: normal;
}

.agora-item:hover .agora-tip {
  opacity: 1;
}

.filter-bar {
  height: auto;
  min-height: 44px;
  padding: 0.56rem 1.5rem;
  background: #f3f0ea;
}

.filter-left {
  gap: 0.14rem;
  flex-wrap: wrap;
}

.filter-btn {
  font-size: 0.62rem;
  letter-spacing: 0.07em;
  padding: 0.34rem 0.7rem;
  border: 0.5px solid transparent;
  border-radius: 1px;
  color: rgba(10, 10, 10, 0.52);
}

.filter-btn:hover {
  border-color: rgba(10, 10, 10, 0.18);
}

.filter-btn.active {
  background: #1a1a1a;
  border-color: #1a1a1a;
  color: #fff;
}

.view-toggle {
  border: 0.5px solid rgba(10, 10, 10, 0.18);
  border-radius: 1px;
  overflow: hidden;
}

.view-btn {
  font-size: 0.62rem;
  letter-spacing: 0.07em;
  padding: 0.34rem 0.8rem;
  border: none;
  border-right: 0.5px solid rgba(10, 10, 10, 0.12);
}

.view-btn:last-child {
  border-right: none;
}

.signals {
  border-bottom: none;
}

.signals-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  padding: 0.9rem 1.5rem 1.75rem;
  background: rgba(10, 10, 10, 0.07);
}

.signal-card {
  position: relative;
  background: #f9f6f0;
  border: 0.5px solid rgba(10, 10, 10, 0.07);
  padding: 1.15rem 1.2rem 1rem;
  gap: 0.6rem;
  transition: transform 140ms ease, box-shadow 140ms ease, border-color 140ms ease, background 140ms ease, opacity 220ms ease;
}

.signal-card:hover {
  background: #ede8de;
  transform: translateY(-3px);
  box-shadow: 0 10px 26px rgba(10, 10, 10, 0.08);
  border-color: rgba(10, 10, 10, 0.16);
}

.signal-card.hero-card {
  grid-column: span 2;
  padding: 1.5rem 1.6rem 1.2rem;
  background: #faf7f1;
}

.signal-card.hero-card:hover {
  background: #ece7dd;
}

.signal-card.featured-secondary {
  background: #f8f2ee;
}

.signal-card.featured-secondary:hover {
  background: #ede4dc;
}

.signal-card.card-dim {
  opacity: 0.18;
  transform: scale(0.985);
}

.signal-card.card-match {
  opacity: 1;
}

.signal-card .card-header {
  gap: 0.45rem;
}

.card-status {
  font-size: 0.56rem;
  letter-spacing: 0.09em;
  padding: 0.15rem 0.42rem;
  border-width: 1px;
}

.card-territories {
  gap: 0;
}

.territory-tag {
  font-size: 0.56rem;
  color: rgba(10, 10, 10, 0.52);
  opacity: 1;
}

.card-title {
  font-size: 1.28rem;
  line-height: 1.14;
  margin-top: 0.05rem;
}

.hero-card .card-title {
  font-size: clamp(1.7rem, 2.8vw, 2.15rem);
}

.card-connections {
  border-top: none;
  padding-top: 0;
  gap: 0.28rem;
  margin-top: 0.05rem;
}

.connections-label {
  display: none;
}

.connection-pair {
  display: inline-flex;
  align-items: center;
  gap: 0.24rem;
  margin-right: 0.2rem;
}

.connection-type {
  font-family: var(--font-mono);
  font-size: 0.54rem;
  color: #b8722a;
  font-style: italic;
}

.connection-tag {
  font-size: 0.56rem;
  padding: 0.12rem 0.45rem;
  border: 0.5px solid rgba(184, 114, 42, 0.35);
  background: rgba(184, 114, 42, 0.06);
  color: #b8722a;
}

.connection-tag:hover {
  background: rgba(184, 114, 42, 0.14);
  border-color: rgba(184, 114, 42, 0.5);
  color: #9e621f;
}

.card-desc {
  font-size: 0.72rem;
  line-height: 1.54;
  color: rgba(10, 10, 10, 0.62);
  display: block;
  -webkit-line-clamp: 3;
}

.card-trigger,
.card-changed,
.card-insight {
  font-size: 0.65rem;
  line-height: 1.48;
}

.card-trigger {
  color: #8a6a40;
  font-weight: 500;
}

.card-trigger.stage-saturating {
  color: #8a3a2a;
}

.card-trigger.stage-new {
  color: #1a5a8a;
}

.card-changed {
  color: #6a5a40;
  border-left: 1.5px solid #c87533;
  padding-left: 0.5rem;
}

.card-changed.stage-saturating {
  border-left-color: #a03228;
  color: #7a4030;
}

.card-insight {
  background: rgba(10, 10, 10, 0.04);
  color: rgba(10, 10, 10, 0.62);
  padding: 0.45rem 0.55rem;
  border-radius: 1px;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: opacity 0.18s ease, max-height 0.22s ease;
}

.hero-card:hover .card-insight,
.featured-secondary:hover .card-insight {
  opacity: 1;
  max-height: 64px;
}

.hero-card:hover .card-changed,
.featured-secondary:hover .card-changed {
  display: none;
}

.card-divider {
  height: 0.5px;
  background: rgba(10, 10, 10, 0.09);
  margin: 0.12rem 0 0;
}

.card-footer {
  gap: 0.4rem;
}

.card-metrics {
  display: flex;
  gap: 0.7rem;
  align-items: center;
  flex-wrap: wrap;
}

.metric-inline {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  color: rgba(10, 10, 10, 0.56);
}

.metric-inline strong {
  color: #0a0a0a;
  font-weight: 700;
}

.metric-inline .metric-up { color: #466B3A; }
.metric-inline .metric-flat { color: #999; }
.metric-inline .metric-down { color: #a03228; }

.accel-flag {
  position: absolute;
  top: 0.78rem;
  right: 0.78rem;
  font-family: var(--font-mono);
  font-size: 0.54rem;
  letter-spacing: 0.06em;
  color: #466B3A;
  font-weight: 600;
}

.card-evidence {
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
  margin-top: 0.1rem;
}

.card-evidence-label {
  font-family: var(--f-data);
  font-size: 0.5rem;
  letter-spacing: 0.12em;
  color: rgba(10,10,10,0.32);
  text-transform: uppercase;
}

.card-evidence-text {
  font-family: var(--f-data);
  font-size: 0.6rem;
  letter-spacing: 0.02em;
  color: rgba(10,10,10,0.55);
  line-height: 1.45;
}

.card-micro-insight {
  font-size: 0.68rem;
  font-weight: 500;
  line-height: 1.48;
  color: rgba(10,10,10,0.72);
  border-left: 1.5px solid var(--green);
  padding-left: 0.55rem;
  margin-top: 0.1rem;
}

.card-cta-link {
  font-family: var(--f-data);
  font-size: 0.58rem;
  letter-spacing: 0.06em;
  color: rgba(10,10,10,0.45);
  text-decoration: none;
  transition: color 0.15s;
  display: inline-block;
  position: relative;
  z-index: 2;
}

.card-cta-link:hover {
  color: var(--black);
}

.signal-card .card-link {
  z-index: 2;
}

.signal-card > *:not(.card-link) {
  position: relative;
  z-index: 3;
}

.signal-card.hidden {
  display: none;
}

.map-ax {
  font-size: 0.62rem;
  color: rgba(10, 10, 10, 0.52);
}

.map-tooltip {
  width: 220px;
  background: #1a1a1a;
  color: rgba(250, 250, 250, 0.88);
}

.tt-name {
  font-size: 0.74rem;
  margin-bottom: 0.45rem;
}

.tt-status-row {
  margin-bottom: 0.4rem;
}

.tt-summary {
  font-size: 0.66rem;
  line-height: 1.5;
  color: rgba(250, 250, 250, 0.7);
}

.map-bubble {
  cursor: pointer;
}

.mb-name {
  font-size: 0.68rem;
  line-height: 1.15;
  white-space: normal;
  max-width: 72%;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.mb-name.is-outside {
  position: absolute;
  left: calc(100% + 10px);
  top: 50%;
  transform: translateY(-50%);
  width: 110px;
  text-align: left;
  color: #0a0a0a;
  background: transparent;
  max-width: 110px;
}

.mb-name.is-outside::before {
  content: '';
  position: absolute;
  left: -9px;
  top: 50%;
  width: 7px;
  height: 0.5px;
  background: rgba(10, 10, 10, 0.35);
}

.map-legend,
.ml-note,
.ml-item {
  font-size: 0.62rem;
}

.site-footer {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  padding: 1rem 1.5rem;
}

@media (max-width: 980px) {
  .site-header {
    height: auto;
    min-height: 62px;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.6rem 1rem;
    padding-bottom: 0.7rem;
  }

  .header-left,
  .site-nav,
  .lang-selector {
    padding-top: 0.6rem;
  }

  .signals-grid {
    grid-template-columns: 1fr 1fr;
  }

  .signal-card.hero-card {
    grid-column: span 2;
  }
}

@media (max-width: 720px) {
  .site-header {
    padding: 0 1rem 0.8rem;
  }

  .axes-bar,
  .agora-strip,
  .filter-bar,
  .signals-grid,
  .site-footer {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .filter-bar {
    align-items: flex-start;
    gap: 0.7rem;
    flex-direction: column;
  }

  .signals-grid {
    grid-template-columns: 1fr;
  }

  .signal-card.hero-card {
    grid-column: span 1;
  }

  .agora-items {
    gap: 0.9rem;
  }

  .mb-name.is-outside {
    width: 84px;
    font-size: 0.58rem;
  }
}

/* ── Filter + Toggle Bar ── */
.filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2.5rem;
  height: 36px;
  border-bottom: var(--border);
}

.filter-left {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.filter-btn {
  font-family: var(--font-mono);
  font-size: 0.52rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: rgba(10,10,10,0.35);
  transition: color 0.2s;
}

.filter-btn.active { color: #0A0A0A; }
.filter-btn:hover  { color: #0A0A0A; }

.view-toggle {
  display: flex;
  align-items: center;
  gap: 0;
}

.view-btn {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.06em;
  padding: 0.3rem 0.9rem;
  border: 0.5px solid rgba(10,10,10,0.18);
  cursor: pointer;
  background: transparent;
  color: rgba(10,10,10,0.4);
  transition: background 0.15s, color 0.15s;
}

.view-btn + .view-btn { border-left: none; }

.view-btn.active {
  background: #0A0A0A;
  color: #FAFAFA;
  border-color: #0A0A0A;
}

.view-btn:not(.active):hover { color: #0A0A0A; }

.view-sep {
  font-size: 0.55rem;
  color: rgba(10,10,10,0.2);
  padding: 0 0.25rem;
  display: none; /* separator hidden; buttons are adjacent */
}

/* ── Section commons ── */
.section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 2rem 2.5rem 1.5rem;
  border-bottom: var(--border);
}

.section-title {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
}

.section-meta {
  opacity: 0.4;
}

/* ── Signals Section ── */
.signals {
  border-bottom: var(--border);
}

.signal-filters {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.filter-btn {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.06em;
  padding: 0.4rem 0.9rem;
  border: var(--border);
  color: var(--black);
  opacity: 0.5;
  transition: opacity 0.2s, background 0.15s, color 0.15s, border-color 0.15s;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.filter-btn:hover { opacity: 1; }
.filter-btn.active {
  opacity: 1;
  background: var(--black);
  color: var(--white);
  border-color: var(--black);
}

/* Status dots */
.dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

.dot--novo      { border: 0.5px solid var(--black); background: transparent; }
.dot--emergindo { background: var(--green); }
.dot--crescendo { background: var(--amber); }
.dot--saturando { background: var(--red); }

/* Signal Grid */
.signals-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.signal-card {
  padding: 2.5rem;
  border-right: var(--border);
  border-bottom: var(--border);
  border-left: 2px solid transparent;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: background 0.2s, border-left-color 0.2s;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.signal-card[data-status="emergindo"] { border-left-color: var(--green); }
.signal-card[data-status="crescendo"] { border-left-color: var(--amber); }
.signal-card[data-status="saturando"] { border-left-color: var(--red); }
.signal-card[data-status="novo"]      { border-left-color: rgba(10,10,10,0.25); }

.signal-card:nth-child(3n) { border-right: none; }
.signal-card:hover { background: rgba(10,10,10,0.02); }

.card-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}

/* Status badge — bordered chip */
.card-status {
  font-family: var(--font-mono);
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  padding: 0.18rem 0.5rem;
  white-space: nowrap;
  flex-shrink: 0;
  display: inline-block;
}

.status--emergindo { border: 1.5px solid var(--green); color: var(--green); }
.status--crescendo { border: 1.5px solid var(--amber); color: var(--amber); }
.status--saturando { border: 1.5px solid var(--red);   color: var(--red);   }
.status--novo      { border: 1.5px solid var(--black); color: var(--black); }

/* Territory tags — plain inline text in cards */
.card-territories {
  display: flex;
  align-items: center;
  gap: 0;
}

.territory-tag {
  font-family: var(--font-mono);
  font-size: 0.48rem;
  letter-spacing: 0.02em;
  color: var(--text-l3);
  opacity: 0.5;
  border: none;
  background: none;
  padding: 0;
}

.territory-tag + .territory-tag::before {
  content: ' · ';
  opacity: 0.6;
}

/* Territory tags in territory section — keep bordered */
.signal-territory-tags .territory-tag,
.territory-themes .territory-tag {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.04em;
  border: var(--border);
  padding: 0.15rem 0.4rem;
  opacity: 0.55;
}

.card-title {
  font-size: clamp(1.4rem, 2vw, 1.8rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.1;
  color: var(--text-l1);
}

.card-desc {
  font-size: 0.85rem;
  font-weight: 300;
  line-height: 1.6;
  color: var(--text-l3);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}

.card-metric-line {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-mono);
  font-size: 0.52rem;
  color: rgba(10,10,10,0.45);
  margin-top: 0.5rem;
}

.card-footer {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-top: auto;
}

.card-intensity {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.intensity-label { color: var(--text-l3); font-size: 0.5rem; }

.card-intensity-label {
  position: relative;
  display: inline-flex;
  align-items: center;
  cursor: default;
}
.card-intensity-label:hover .card-metric-tooltip {
  opacity: 1;
  transition-delay: 0.15s;
}
.card-metric-tooltip {
  position: absolute;
  bottom: calc(100% + 6px);
  left: 0;
  background: #0A0A0A;
  color: #FAFAFA;
  font-family: var(--font-mono);
  font-size: 0.44rem;
  letter-spacing: 0.04em;
  padding: 0.35rem 0.6rem;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.15s ease;
  transition-delay: 0s;
  z-index: 10;
}

.intensity-bar {
  flex: 1;
  height: 3px;
  background: rgba(10,10,10,0.08);
  position: relative;
  border-radius: 1.5px;
}

.intensity-fill {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  transition: width 0.8s var(--ease);
}

.emergindo-fill { background: var(--green); }
.crescendo-fill { background: var(--amber); }
.saturando-fill { background: var(--red); }
.novo-fill      { background: var(--black); opacity: 0.4; }

.intensity-val { opacity: 0.5; }

.card-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.card-time { opacity: 0.3; }

.card-link {
  position: absolute;
  inset: 0;
  z-index: 0;
  /* text is hidden — whole card is the link; keep for screen readers */
  font-size: 0;
  color: transparent;
  text-decoration: none;
}

.card-connections {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  align-items: center;
  padding-top: 0.75rem;
  border-top: var(--border);
  position: relative;
  z-index: 1;
}

.connections-label {
  opacity: 0.35;
  margin-right: 0.2rem;
}

.connection-tag {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.03em;
  padding: 0.12rem 0.4rem;
  background: var(--fill-tag);
  border: 0.5px solid rgba(10,10,10,0.12);
  color: var(--text-l2);
}

.signals-more {
  display: flex;
  justify-content: center;
  padding: 2.5rem;
  border-top: var(--border);
}

.btn-outline {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  padding: 0.75rem 2rem;
  border: var(--border-strong);
  transition: background 0.2s, color 0.2s;
}

.btn-outline:hover {
  background: var(--black);
  color: var(--white);
}

/* ── Territories ── */
.territories {
  border-bottom: var(--border);
}

.territory-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  border-top: var(--border);
}

.territory-cell {
  padding: 1.75rem 1.5rem 1.5rem;
  border-right: var(--border);
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  cursor: pointer;
  transition: background 0.18s, box-shadow 0.18s;
  position: relative;
  user-select: none;
}

.territory-cell:last-child { border-right: none; }
.territory-cell:hover { background: var(--off); }
.territory-cell.active {
  background: var(--black);
  color: var(--white);
}
.territory-cell.active .territory-bar-fill { background: var(--white); }
.territory-cell.active .territory-code,
.territory-cell.active .territory-name,
.territory-cell.active .mini-val { opacity: 0.5; color: var(--white); }
.territory-cell.active .territory-count { color: var(--white); }
.territory-cell.active .theme-tag { border-color: rgba(255,255,255,0.15); color: rgba(255,255,255,0.6); }
.territory-cell.active .territory-bar-wrap { background: rgba(255,255,255,0.1); }

/* ── Territory header (code + bubble) ── */
.territory-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.territory-code {
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  opacity: 0.35;
}

/* ── Bubble heatmap ── */
.territory-bubble {
  width: var(--bsize, 32px);
  height: var(--bsize, 32px);
  border-radius: 50%;
  background: var(--bcolor, var(--amber));
  opacity: 0.22;
  flex-shrink: 0;
  transition: opacity 0.2s;
}

.territory-cell:hover .territory-bubble,
.territory-cell.active .territory-bubble { opacity: 0.35; }

/* ── Territory info ── */
.territory-info {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.territory-count {
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
}

.territory-name {
  font-size: 0.76rem;
  font-weight: 500;
  opacity: 0.65;
}

/* ── Bar ── */
.territory-bar-wrap {
  height: 1px;
  background: rgba(10,10,10,0.1);
  margin: 0.1rem 0;
}

.territory-bar-fill {
  height: 100%;
  background: var(--black);
  opacity: 0.35;
  transition: width 0.8s cubic-bezier(0.16,1,0.3,1);
}

/* ── Status breakdown ── */
.territory-statuses {
  display: flex;
  align-items: center;
  gap: 0.3rem;
}

.mini-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

/* Explicit colors — no opacity wash */
.mini-dot.dot--emergindo { background: var(--green); }
.mini-dot.dot--crescendo { background: var(--amber); }
.mini-dot.dot--saturando { background: var(--red); }
.mini-dot.dot--novo      { border: 0.5px solid currentColor; background: transparent; }

.mini-val {
  font-size: 0.58rem;
  opacity: 0.45;
  margin-right: 0.25rem;
}

/* ── Active themes inside territory ── */
.territory-themes {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  padding-top: 0.5rem;
  border-top: var(--border);
  margin-top: 0.2rem;
}

.theme-tag {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.62rem;
  font-weight: 400;
  opacity: 0.6;
  font-family: var(--font-mono);
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Legend ── */
.territory-legend {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.9rem 2.5rem;
  border-top: var(--border);
  flex-wrap: wrap;
}

.legend-label {
  letter-spacing: 0.1em;
  opacity: 0.35;
  margin-right: 0.5rem;
}

.legend-item {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.04em;
  cursor: pointer;
  padding: 0.3rem 0.7rem;
  border: var(--border);
  background: none;
  color: var(--black);
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  opacity: 0.6;
}

.legend-item:hover { opacity: 1; }

.legend-item.active {
  background: var(--black);
  color: var(--white);
  border-color: var(--black);
  opacity: 1;
}

.legend-reset {
  opacity: 0.3;
  border-color: transparent;
  display: none;
}

.legend-reset.visible { display: flex; opacity: 0.5; }
.legend-reset:hover { opacity: 1; }

/* Legend dot — full color, no container opacity */
.legend-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}

.legend-dot.dot--emergindo { background: var(--green); }
.legend-dot.dot--crescendo { background: var(--amber); }
.legend-dot.dot--saturando { background: var(--red); }

/* ── Email Capture ── */
.capture {
  padding: 5rem 2.5rem;
  border-bottom: var(--border);
  background: var(--black);
  color: var(--white);
}

.capture-inner {
  max-width: 64rem;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4rem;
}

.capture-text {
  flex: 1;
}

.capture-eyebrow {
  display: block;
  opacity: 0.4;
  letter-spacing: 0.12em;
  margin-bottom: 1rem;
}

.capture-title {
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin-bottom: 1rem;
}

.capture-sub {
  font-size: 0.9rem;
  font-weight: 300;
  line-height: 1.65;
  opacity: 0.55;
  max-width: 28rem;
}

.capture-form {
  flex: 1;
  max-width: 26rem;
}

.form-row {
  display: flex;
  border: 0.5px solid rgba(255,255,255,0.25);
  margin-bottom: 0.75rem;
}

.form-input {
  flex: 1;
  padding: 0.85rem 1rem;
  background: transparent;
  border: none;
  color: var(--white);
  font-family: var(--font-display);
  font-size: 0.9rem;
  outline: none;
}

.form-input::placeholder {
  color: rgba(255,255,255,0.3);
}

.form-submit {
  padding: 0.85rem 1.25rem;
  background: var(--white);
  color: var(--black);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  font-weight: 700;
  white-space: nowrap;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
  border: none;
}

.form-submit:hover {
  background: var(--green);
  color: var(--white);
}

.form-note {
  opacity: 0.3;
  font-size: 0.62rem;
}

.form-success {
  display: none;
  color: var(--green);
  font-size: 0.72rem;
  margin-top: 0.5rem;
}

.form-success.visible { display: block; }

/* ── Footer ── */
.site-footer {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 1rem 2.5rem;
  border-top: var(--border);
}

.footer-logo {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: #0A0A0A;
  opacity: 0.7;
  text-decoration: none;
}

.footer-nav {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 12px;
  color: rgba(10,10,10,0.38);
}

.footer-nav a {
  color: rgba(10,10,10,0.38);
  text-decoration: none;
  transition: color 0.15s;
}

.footer-nav a:hover { color: #0A0A0A; }

.footer-dot {
  opacity: 0.3;
  font-size: 11px;
}

.footer-copy {
  font-family: var(--font-mono);
  font-size: 11px;
  color: rgba(10,10,10,0.25);
  text-align: right;
}

.footer-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-size: 12px;
  color: rgba(10,10,10,0.38);
}

.footer-links a {
  color: rgba(10,10,10,0.38);
  text-decoration: none;
  transition: color 0.15s;
}

.footer-links a:hover { color: #0A0A0A; }

.footer-sep {
  opacity: 0.3;
  font-size: 11px;
}

.footer-brand {
  font-family: var(--font-mono);
  font-size: 11px;
  color: rgba(10,10,10,0.25);
  text-align: right;
  opacity: 1;
  letter-spacing: 0;
}

.footer-left {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.footer-logo {
  font-size: 0.85rem;
}

.footer-tagline {
  opacity: 0.3;
}

.footer-center {
  display: flex;
  gap: 2rem;
}

.footer-center a {
  font-size: 0.8rem;
  opacity: 0.4;
  transition: opacity 0.2s;
}

.footer-center a:hover { opacity: 1; }

.footer-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.2rem;
}

.footer-copy,
.footer-location {
  opacity: 0.3;
}

/* ── Responsive ── */
@media (max-width: 1100px) {
  .territory-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .territory-cell:nth-child(3) { border-right: none; }
  .territory-cell:nth-child(4) { border-right: var(--border); }
  .territory-themes { display: none; }
}

@media (max-width: 900px) {
  .site-header {
    padding: 1rem 1.25rem;
    flex-wrap: wrap;
    gap: 0.75rem;
  }

  .site-nav { display: none; }

  .lang-selector { margin-left: auto; }

  .hero { padding: 3rem 1.25rem 4rem; }

  .hero-sub { flex-direction: column; gap: 2rem; }
  .hero-stats { flex-direction: row; gap: 1.5rem; }

  .signals-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .signal-card:nth-child(3n) { border-right: var(--border); }
  .signal-card:nth-child(2n) { border-right: none; }

  .section-header {
    flex-direction: column;
    gap: 1rem;
    padding: 1.5rem 1.25rem;
  }

  .signal-filters { flex-wrap: wrap; }

  .territory-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .territory-cell:nth-child(3) { border-right: var(--border); }
  .territory-cell:nth-child(2n) { border-right: none; }

  .capture-inner { flex-direction: column; gap: 2.5rem; }
  .capture-form { max-width: 100%; width: 100%; }

  .site-footer {
    flex-direction: column;
    gap: 1.5rem;
    align-items: flex-start;
    padding: 1.5rem 1.25rem;
  }

  .footer-right { align-items: flex-start; }
}

@media (max-width: 600px) {
  .hero { padding: 2.5rem 1rem 3rem; }

  .signals-grid { grid-template-columns: 1fr; }
  .signal-card { border-right: none; }
  .signal-card:nth-child(2n) { border-right: none; }

  .territory-grid { grid-template-columns: 1fr 1fr; }

  .signals-more { padding: 1.5rem; }

  .capture { padding: 3rem 1.25rem; }

  .form-row { flex-direction: column; }
  .form-submit { text-align: center; }
}

/* ── Signal card hidden state (filter) ── */
.signal-card.hidden {
  display: none;
}

/* ── Bubble Map ── */
.bubble-map-section {
  border-bottom: var(--border);
}

.bubble-field {
  position: relative;
  height: 400px;
  border-top: var(--border);
  overflow: hidden;
  background: var(--off);
}

@keyframes bubble-float {
  0%, 100% { transform: translate(-50%, -50%); }
  50%       { transform: translate(-50%, calc(-50% - 7px)); }
}

.bubble {
  position: absolute;
  left: var(--bx);
  top: var(--by);
  width: var(--bs);
  height: var(--bs);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.2rem;
  text-decoration: none;
  text-align: center;
  padding: 0.75rem;
  transition: opacity 0.2s;
  opacity: 0.9;
  cursor: pointer;
  animation: bubble-float 6s ease-in-out infinite;
  animation-delay: var(--bd, 0s);
}

.bubble:hover {
  animation: none;
  transform: translate(-50%, -50%) scale(1.08);
  opacity: 1;
}

/* Axis labels */
.map-label {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 0.5rem;
  letter-spacing: 0.12em;
  opacity: 0.22;
  pointer-events: none;
  z-index: 0;
  white-space: nowrap;
}
.map-label--top    { top: 0.5rem; left: 50%; transform: translateX(-50%); }
.map-label--bottom { bottom: 0.5rem; left: 50%; transform: translateX(-50%); }
.map-label--left   { left: 0.3rem; top: 50%; transform: translateY(-50%) rotate(-90deg); }
.map-label--right  { right: 0.3rem; top: 50%; transform: translateY(-50%) rotate(90deg); }
.axis-line { stroke: rgba(10,10,10,0.05); stroke-dasharray: 3 5; }

.bubble--emergindo {
  background: rgba(99, 153, 34, 0.15);
  border: 1.5px solid rgba(99, 153, 34, 0.45);
}
.bubble--crescendo {
  background: rgba(186, 117, 23, 0.15);
  border: 1.5px solid rgba(186, 117, 23, 0.45);
}
.bubble--saturando {
  background: rgba(226, 75, 74, 0.15);
  border: 1.5px solid rgba(226, 75, 74, 0.45);
}
.bubble--novo {
  background: rgba(10, 10, 10, 0.04);
  border: 1.5px solid rgba(10, 10, 10, 0.25);
}

.bubble-connections {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.conn-line {
  stroke: rgba(10,10,10,0.1);
  stroke-width: 1;
}

.bubble-legend {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 0.9rem 2.5rem;
  border-top: var(--border);
}

.legend-dot-item {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.04em;
  opacity: 0.6;
}

.legend-dot.dot--novo {
  border: 1px solid var(--black);
  background: transparent;
}

.bubble-name {
  font-family: var(--font-display);
  font-size: 0.6rem;
  font-weight: 500;
  line-height: 1.3;
  text-align: center;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.bubble-pct {
  font-size: 0.55rem;
  opacity: 0.65;
}

.bubble--emergindo .bubble-name { color: #466B3A; }
.bubble--emergindo .bubble-pct  { color: #466B3A; }
.bubble--crescendo .bubble-name { color: #BA7517; }
.bubble--crescendo .bubble-pct  { color: #BA7517; }
.bubble--saturando .bubble-name { color: #E24B4A; }
.bubble--saturando .bubble-pct  { color: #E24B4A; }
.bubble--novo .bubble-name      { color: var(--black); }

@media (max-width: 700px) {
  .bubble-field { height: 300px; }
}

/* ── Hero stat alert ── */
.stat--alert {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  background: #EAF3DE;
  border-left: 3px solid #466B3A;
  padding: 1rem;
  margin-left: 1rem;
}

.stat-alert-label {
  font-size: 10px;
  letter-spacing: 0.14em;
  color: #466B3A;
  font-family: var(--font-mono);
  text-transform: uppercase;
}

.stat-alert-name {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: var(--black);
}

.stat-alert-val {
  font-size: 11px;
  letter-spacing: 0.04em;
  color: #466B3A;
  font-family: var(--font-mono);
}

/* ── Territory tag as link ── */
a.tag--link {
  cursor: pointer;
  transition: opacity 0.15s, background 0.15s;
  text-decoration: none;
}

a.tag--link:hover {
  opacity: 1;
  background: rgba(10,10,10,0.06);
}

/* ── Blockquote citation ── */
.pull-cite {
  display: block;
  margin-top: 0.75rem;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  opacity: 0.45;
}

/* ── Support band ── */
.support-band {
  border-bottom: var(--border);
  border-top: var(--border);
  padding: 4rem 2.5rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: start;
  background: var(--off);
}

.support-left {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.support-right {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  padding-top: 0.25rem;
}

.support-eyebrow {
  display: block;
  font-size: 0.62rem;
  letter-spacing: 0.14em;
  opacity: 0.35;
}

.support-title {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.support-body {
  font-size: 0.9rem;
  font-weight: 300;
  line-height: 1.75;
  opacity: 0.65;
  max-width: 36rem;
}

.support-cta {
  display: inline-block;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  padding: 0.7rem 1.5rem;
  border: var(--border-strong);
  color: var(--black);
  text-decoration: none;
  transition: background 0.18s, color 0.18s;
  align-self: flex-start;
}

.support-cta:hover {
  background: var(--black);
  color: var(--white);
}

.support-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  padding: 0;
}

.support-list li {
  font-size: 0.88rem;
  font-weight: 300;
  line-height: 1.65;
  color: rgba(10,10,10,0.65);
  padding-left: 1.1rem;
  position: relative;
}

.support-list li::before {
  content: '—';
  position: absolute;
  left: 0;
  font-family: var(--f-data);
  font-size: 0.7rem;
  color: var(--green);
  top: 0.1em;
}

@media (max-width: 700px) {
  .support-band {
    grid-template-columns: 1fr;
    gap: 1.5rem;
    padding: 3rem 1.25rem;
  }
}

/* ── Contact section ── */
.contact {
  padding: 5rem 2.5rem;
  border-bottom: var(--border);
}

.contact-inner {
  max-width: 64rem;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 5rem;
  align-items: start;
}

.contact-left {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-top: 0.25rem;
}

.contact-eyebrow {
  display: block;
  font-size: 0.62rem;
  letter-spacing: 0.14em;
  opacity: 0.35;
}

.contact-title {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.contact-desc {
  font-size: 0.9rem;
  font-weight: 300;
  line-height: 1.65;
  opacity: 0.55;
  max-width: 22rem;
}

.contact-right {
  display: flex;
  flex-direction: column;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.contact-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.contact-field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.contact-label {
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  opacity: 0.5;
  font-size: 11px;
}

.contact-input {
  background: var(--white);
  border: 1px solid #000;
  padding: 12px;
  font-family: var(--font-display);
  font-size: 0.9rem;
  color: var(--black);
  outline: none;
  transition: border-color 0.2s;
  resize: none;
  border-radius: 0;
  -webkit-appearance: none;
  width: 100%;
  box-sizing: border-box;
}

.contact-input:focus {
  border-color: var(--black);
}

.contact-textarea {
  min-height: 7rem;
}

.contact-submit {
  width: 100%;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  padding: 0.9rem 2rem;
  border: none;
  background: var(--black);
  color: var(--white);
  cursor: pointer;
  transition: opacity 0.2s;
  border-radius: 0;
  margin-top: 0.5rem;
  text-align: center;
}

.contact-submit:hover {
  opacity: 0.8;
}

.contact-success {
  display: none;
  font-size: 0.72rem;
  color: var(--green);
  margin-top: 0.75rem;
}

.contact-success.visible { display: block; }

@media (max-width: 900px) {
  .contact-inner { grid-template-columns: 1fr; gap: 2.5rem; }
}

@media (max-width: 600px) {
  .contact-row { grid-template-columns: 1fr; }
  .contact { padding: 3rem 1.25rem; }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .tb-dot { animation: none; }
  .b-accelerating { animation: none; }
  .hero-scroll-hint { animation: none; }
  * { transition-duration: 0.01ms !important; }
}

/* ── Signal Map — 2-axis analytical ── */
.signal-map {
  border-bottom: var(--border);
}

.map-container {
  position: relative;
  height: 580px;
  background: #F0EFE8;
  border-top: var(--border);
  overflow: hidden;
}

.map-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.map-grid-line {
  stroke: rgba(10,10,10,0.06);
  stroke-width: 0.5px;
}

.map-axis-line {
  stroke: rgba(10,10,10,0.18);
  stroke-width: 0.5px;
}

/* Axis labels */
.map-ax {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  opacity: 0.55;
  pointer-events: none;
  z-index: 1;
  white-space: nowrap;
}

.map-ax--nicho       { left: 1rem; bottom: 1.25rem; }
.map-ax--mainstream  { right: 1rem; bottom: 1.25rem; }
.map-ax--saturando   { left: 50%; top: 0.5rem; transform: translateX(-50%); }
.map-ax--emergindo   { left: 50%; bottom: 2.5rem; transform: translateX(-50%); }

/* Bubbles */
.map-bubble {
  position: absolute;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.1rem;
  text-align: center;
  padding: 0.5rem;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.2s;
  z-index: 2;
  overflow: hidden;
}

.map-bubble--emergindo {
  background: rgba(99,153,34,0.15);
  border: 1.5px solid rgba(99,153,34,0.35);
}

.map-bubble--crescendo {
  background: rgba(186,117,23,0.12);
  border: 1.5px solid rgba(186,117,23,0.3);
}

.map-bubble--saturando {
  background: rgba(226,75,74,0.12);
  border: 1.5px solid rgba(226,75,74,0.28);
}

.map-bubble--novo {
  background: rgba(10,10,10,0.05);
  border: 1.5px solid rgba(10,10,10,0.15);
}

/* ── Map bubble states ── */
.b-accelerating {
  animation: bubblePulse 2.5s ease-in-out infinite;
}
@keyframes bubblePulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(186,117,23,0.15); }
  50% { box-shadow: 0 0 0 8px rgba(186,117,23,0); }
}
.b-fading { opacity: 0.7; }

/* Fixed minimum font size — labels never shrink below legible threshold */
.mb-name {
  font-family: var(--font-display);
  font-size: 0.6rem;   /* fixed: ~10px — do NOT make this relative to bubble size */
  font-weight: 600;
  line-height: 1.2;
  text-align: center;
  white-space: nowrap;
}

.map-bubble--emergindo .mb-name { color: #2d5a0a; }
.map-bubble--crescendo .mb-name { color: #633806; }
.map-bubble--saturando .mb-name { color: #791f1f; }
.map-bubble--novo      .mb-name { color: rgba(10,10,10,0.5); }

.mb-pct {
  font-family: var(--font-mono);
  font-size: 0.5rem;   /* fixed: ~8px min */
  opacity: 0.65;
}

.map-bubble--emergindo .mb-pct { color: #2d5a0a; }
.map-bubble--crescendo .mb-pct { color: #633806; }
.map-bubble--saturando .mb-pct { color: #791f1f; }
.map-bubble--novo      .mb-pct { color: rgba(10,10,10,0.5); }

.mb-locs {
  font-family: var(--font-mono);
  font-size: 0.42rem;
  opacity: 0;
  transition: opacity 0.2s;
  white-space: nowrap;
  margin-top: 0.1rem;
}

.map-bubble:hover .mb-locs { opacity: 0.65; }

/* Connection SVG overlay */
.map-conn-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 3;
}

/* Tooltip */
.map-tooltip {
  position: absolute;
  background: #0A0A0A;
  color: #FAFAFA;
  padding: 0.75rem 1rem;
  z-index: 20;
  pointer-events: none;
  min-width: 140px;
}

.tt-name {
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
  letter-spacing: -0.01em;
}

.tt-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 0.2rem;
}

.tt-label {
  font-family: var(--font-mono);
  font-size: 0.46rem;
  letter-spacing: 0.08em;
  opacity: 0.45;
  white-space: nowrap;
}

.tt-val {
  font-family: var(--font-mono);
  font-size: 0.46rem;
  letter-spacing: 0.02em;
  opacity: 0.9;
}

/* Map legend */
.map-legend {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 0.75rem 2.5rem;
  border-top: var(--border);
  flex-wrap: wrap;
}

.ml-item {
  font-family: var(--font-mono);
  font-size: 0.58rem;
  letter-spacing: 0.06em;
  opacity: 0.7;
}

.ml-emergindo { color: #466B3A; }
.ml-crescendo { color: #BA7517; }
.ml-saturando { color: #E24B4A; }
.ml-novo      { color: rgba(10,10,10,0.5); }

.ml-sep {
  font-family: var(--font-mono);
  font-size: 0.58rem;
  opacity: 0.25;
}

.ml-note {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  opacity: 0.45;
}

@media (max-width: 700px) {
  .map-container { height: 360px; }
  .filter-bar { padding: 0 1.25rem; }
}

/* ── Homepage Final Mockup Fidelity ── */
.home-page {
  background: #f3f0ea;
}

.home-page .site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: 94px;
  padding: 0 3.6rem 0 3.4rem;
  align-items: flex-start;
  background: #f4f1ea;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}

.home-page .header-left,
.home-page .site-nav,
.home-page .lang-selector {
  padding-top: 1.5rem;
}

.home-page .header-left {
  min-width: 270px;
}

.home-page .site-nav {
  align-self: flex-start;
  justify-content: center;
  gap: 1.1rem;
}

.home-page .site-nav a {
  color: rgba(10,10,10,0.7);
  font-weight: 500;
}

.home-page .site-nav a:hover {
  color: rgba(10,10,10,0.95);
}

.home-page .header-bottom-line {
  margin-top: 0.25rem;
  gap: 0.6rem;
}

.home-page .header-tagline {
  color: rgba(10,10,10,0.72);
}

.home-page .header-live {
  gap: 0.38rem;
}

.home-page .live-label {
  color: rgba(10,10,10,0.82);
  letter-spacing: 0.04em;
}

.home-page .lang-selector {
  gap: 0.42rem;
}

.home-page .lang-btn {
  color: rgba(10,10,10,0.62);
}

.home-page .lang-btn.active {
  color: rgba(10,10,10,0.96);
}

.home-page .axes-bar {
  background: #1f1f1f;
  padding: 0 3.5rem;
  gap: 2.9rem;
  min-height: 60px;
}

.home-page .axis-btn {
  padding: 1rem 0 0.92rem;
  border-bottom-width: 0;
}

.home-page .axis-btn.active {
  border-bottom-width: 2px;
}

.home-page .axis-a,
.home-page .axis-b,
.home-page .axis-sep,
.home-page .axis-delta {
  font-family: var(--font-display);
  font-size: 0.96rem;
  letter-spacing: 0.01em;
  font-weight: 700;
}

.home-page .axis-a { color: rgba(255,255,255,0.38); }
.home-page .axis-b,
.home-page .axis-sep { color: rgba(255,255,255,0.18); }
.home-page .axis-delta { color: #7cb74d; font-weight: 800; }

.home-page .axis-lens {
  font-family: var(--font-display);
  font-size: 0.82rem;
}

.home-page .agora-strip {
  padding: 0.78rem 3.5rem;
  gap: 1rem;
  background: #f1eee7;
  border-bottom: 1px solid rgba(0,0,0,0.05);
}

.home-page .agora-label {
  font-family: var(--font-display);
  font-size: 0.88rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: rgba(10,10,10,0.34);
}

.home-page .agora-items {
  gap: 2.6rem;
  overflow: hidden;
  flex-wrap: nowrap;
}

.home-page .agora-item,
.home-page .agora-item a {
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 600;
  color: rgba(10,10,10,0.78);
  white-space: nowrap;
}

.home-page .agora-item a {
  color: #bb7c2f;
}

.home-page .agora-time {
  font-family: var(--font-display);
  font-size: 0.86rem;
  font-weight: 500;
  margin-left: 0.32rem;
  color: rgba(10,10,10,0.24);
}

.home-page .filter-bar {
  min-height: auto;
  padding: 0 3.55rem;
  height: 44px;
  background: #f3f0ea;
  border-bottom: 1px solid rgba(0,0,0,0.07);
}

.home-page .filter-left {
  gap: 0.1rem;
  flex-wrap: nowrap;
}

.home-page .filter-btn {
  height: 30px;
  padding: 0 0.9rem;
  border: 0.5px solid rgba(0,0,0,0.14);
  border-radius: 2px;
  background: transparent;
  color: rgba(10,10,10,0.5);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  box-shadow: none;
}

.home-page .filter-btn:hover {
  color: #0a0a0a;
  border-color: rgba(0,0,0,0.3);
  background: rgba(0,0,0,0.03);
}

.home-page .filter-btn.active {
  background: #0a0a0a;
  color: #f3f0ea;
  border-color: #0a0a0a;
}

.home-page .view-toggle {
  border: 0.5px solid rgba(0,0,0,0.14);
  border-radius: 2px;
  overflow: hidden;
  gap: 0;
}

.home-page .view-btn {
  height: 30px;
  padding: 0 0.9rem;
  border: none;
  border-radius: 0;
  background: transparent;
  color: rgba(10,10,10,0.5);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  box-shadow: none;
  min-width: auto;
}

.home-page .view-btn:hover {
  color: #0a0a0a;
  background: rgba(0,0,0,0.03);
}

.home-page .view-btn.active {
  background: #0a0a0a;
  color: #f3f0ea;
}

.home-page .view-btn + .view-btn {
  border-left: 0.5px solid rgba(0,0,0,0.14);
}

.home-page .signals-grid {
  display: block;
  background: transparent;
  padding: 1.45rem 3.55rem 1.4rem;
}

.home-page .sg-row-hero {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 1px;
  margin-bottom: 1px;
  background: rgba(10,10,10,0.06);
}

.home-page .sg-row-mid,
.home-page .sg-row-low {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1px;
  margin-bottom: 1px;
  background: rgba(10,10,10,0.06);
}

.home-page .sg-row-sep {
  height: 0.5px;
  background: rgba(0,0,0,0.07);
  margin-bottom: 1px;
}

.home-page .sg-row-single {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1px;
  background: rgba(10,10,10,0.06);
}

.home-page .signal-card {
  background: #fbf8f2;
  border: 1px solid rgba(0,0,0,0.07);
  padding: 2.95rem 2.7rem 2rem;
  gap: 0.82rem;
  box-shadow: none;
  transform: none;
}

.home-page .signal-card:hover {
  background: #f8f4ec;
  transform: translateY(-3px);
  box-shadow: 0 12px 24px rgba(0,0,0,0.055);
  border-color: rgba(0,0,0,0.12);
}

.home-page .signal-card.hero-card {
  grid-column: auto;
  padding: 3.05rem 2.75rem 2.05rem;
}

.home-page .signal-card.featured-secondary {
  padding: 2.75rem 2.3rem 2rem;
}

.home-page .card-status {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: 0.18rem 0.52rem 0.14rem;
  border-width: 1px;
  border-radius: 1px;
}

.home-page .territory-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 400;
  color: rgba(10,10,10,0.52);
  white-space: normal;
}

.home-page .card-title {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: #1a1a1a;
}

.home-page .hero-card .card-title {
  font-size: 26px;
  letter-spacing: -0.03em;
  line-height: 1.05;
  max-width: 36rem;
}

.home-page .featured-secondary .card-title {
  font-size: 22px;
  letter-spacing: -0.025em;
}

.home-page .card-connections {
  gap: 0.42rem;
  margin-top: 0.12rem;
  max-width: 32rem;
}

.home-page .connection-type {
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-style: italic;
  font-weight: 700;
}

.home-page .connection-tag {
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 500;
  padding: 0.22rem 0.72rem;
  border-radius: 2px;
  max-width: 13rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.home-page .card-desc {
  display: block;
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.6;
  color: rgba(10,10,10,0.65);
  max-width: 40rem;
}

.home-page .card-changed,
.home-page .card-insight,
.home-page .card-trigger {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.5;
}

.home-page .card-changed {
  max-width: 34rem;
  padding-left: 0.78rem;
}

.home-page .featured-secondary .card-changed {
  max-width: 22rem;
}

.home-page .card-trigger {
  max-width: 18rem;
  min-height: 2.8em;
}

.home-page .card-divider {
  margin-top: 0.42rem;
}

.home-page .metric-inline {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 400;
  color: rgba(10,10,10,0.65);
}

.home-page .metric-inline strong {
  font-weight: 600;
  color: rgba(10,10,10,0.9);
}

.home-page .accel-flag {
  top: 14px;
  right: 16px;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: #466B3A;
}

.home-page .featured-secondary .accel-flag,
.home-page .signal-card:not(.hero-card) .accel-flag {
  top: 12px;
  right: 14px;
}

.home-page .card-dim {
  opacity: 0.2;
}

@media (max-width: 1100px) {
  .home-page .site-header,
  .home-page .axes-bar,
  .home-page .agora-strip,
  .home-page .filter-bar,
  .home-page .signals-grid {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .home-page .hero-card .card-title {
    font-size: 2.5rem;
  }

  .home-page .sg-row-hero {
    grid-template-columns: 1fr;
  }

  .home-page .sg-row-mid,
  .home-page .sg-row-low {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 720px) {
  .home-page .sg-row-hero,
  .home-page .sg-row-mid,
  .home-page .sg-row-low {
    grid-template-columns: 1fr;
  }
}

/* ── Global Consistency Overrides ── */
body {
  background: #F3F0EA;
}

.site-header {
  background: #F3F0EA;
}

.header-logo,
.footer-logo {
  font-weight: 700;
  letter-spacing: 0.1em;
  font-size: 13px;
}

.header-tagline {
  font-size: 11px;
  margin-top: 2px;
}

.live-label {
  font-size: 10px;
}

.site-nav a {
  font-size: 12px;
}

.lang-btn {
  font-size: 11px;
}

.site-footer {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: baseline;
  padding: 1rem 2.5rem;
  border-top: 1px solid rgba(0,0,0,0.06);
  background: #F3F0EA;
}

.footer-logo {
  justify-self: start;
}

.footer-links {
  justify-self: center;
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

.footer-links a,
.footer-sep {
  font-size: 12px;
  color: rgba(10,10,10,0.72);
}

.footer-brand {
  justify-self: end;
  font-size: 12px;
}

.signal-title {
  font-size: clamp(36px, 6vw, 72px);
  font-weight: 700;
}

.analysis-label,
.analytical-label,
.obs-label,
.sig-block-label,
.ter-section-label,
.sidebar-heading {
  font-size: 10px;
  letter-spacing: 0.1em;
  font-weight: 500;
}

.signal-analysis p,
.signal-logline,
.connected-desc,
.conn-reason,
.tl-text,
.obs-context,
.sig-next-movement,
.sig-watch-list li,
.sig-definition,
.sig-why-matters {
  font-size: 13px;
  line-height: 1.6;
}

.sig-id,
.sig-detected,
.sig-detected-date,
.bc-link,
.bc-current,
.tl-date {
  font-size: 11px;
}

.metric-label,
.gauge-label {
  font-size: 12px;
  font-weight: 400;
}

.gauge-value {
  font-size: 12px;
  font-weight: 600;
}

.home-page .hero-card {
  min-height: 440px;
}

.home-page .connection-pair:nth-child(n+3) {
  display: none;
}

@media (max-width: 720px) {
  .site-footer {
    grid-template-columns: 1fr;
    gap: 0.5rem;
    text-align: center;
  }

  .footer-logo,
  .footer-links,
  .footer-brand {
    justify-self: center;
  }
}

/* ── Layout Stabilization Layer ── */
:root {
  --layout-page-x: 2.5rem;
  --layout-gap-xs: 0.35rem;
  --layout-gap-sm: 0.6rem;
  --layout-gap-md: 1rem;
  --layout-gap-lg: 1.5rem;
  --layout-gap-xl: 2rem;
  --layout-card-pad: 1.25rem;
  --layout-card-pad-lg: 1.75rem;
  --layout-copy: 13px;
  --layout-copy-lh: 1.6;
}

html,
body {
  max-width: 100%;
  overflow-x: clip;
}

body {
  font-family: var(--font-display);
  line-height: var(--layout-copy-lh);
}

.site-header,
.site-footer,
.axes-bar,
.agora-strip,
.filter-bar,
.signals-grid,
.signal-map,
.support-band,
.breadcrumb,
.signal-hero,
.signal-body,
.manifesto-prose,
.sources-header,
.src-footer-note {
  max-width: 100%;
}

.site-header {
  min-height: 72px;
  height: auto;
  padding: 1rem var(--layout-page-x);
  gap: 1rem;
  align-items: start;
}

.header-left,
.site-nav,
.lang-selector {
  min-width: 0;
}

.header-bottom-line,
.header-live,
.site-nav,
.lang-selector,
.filter-left,
.view-toggle,
.footer-links {
  flex-wrap: wrap;
}

.header-tagline,
.support-body,
.signal-logline,
.analysis-text p,
.manifesto-prose p,
.quem-somos p,
.source-name,
.src-node-desc,
.tt-summary,
.card-desc,
.card-trigger,
.card-changed,
.card-insight,
.tl-text,
.connected-desc,
.conn-reason {
  font-size: var(--layout-copy);
  line-height: var(--layout-copy-lh);
}

.home-page .site-header,
.home-page .axes-bar,
.home-page .agora-strip,
.home-page .filter-bar,
.home-page .signals-grid,
.home-page .signal-map,
.home-page .support-band,
.site-footer,
.signal-hero,
.signal-body,
.breadcrumb {
  padding-left: var(--layout-page-x);
  padding-right: var(--layout-page-x);
}

.home-page .site-header {
  min-height: 94px;
  height: auto;
}

.home-page .axes-bar,
.home-page .agora-strip,
.home-page .filter-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 0.75rem;
}

.home-page .axes-bar {
  min-height: 0;
  padding-top: 0.9rem;
  padding-bottom: 0.9rem;
}

.home-page .axis-btn {
  min-width: 0;
}

.home-page .agora-items {
  display: flex;
  flex: 1 1 34rem;
  flex-wrap: wrap;
  gap: 0.75rem 1.5rem;
  overflow: visible;
}

.home-page .agora-item,
.home-page .agora-item a,
.home-page .agora-time {
  white-space: normal;
  overflow-wrap: anywhere;
}

.home-page .filter-bar {
  min-height: 0;
  align-items: start;
}

.home-page .filter-left {
  display: flex;
  flex: 1 1 42rem;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.home-page .view-toggle {
  display: flex;
  flex: 0 0 auto;
  justify-content: flex-end;
  gap: 0.5rem;
}

.home-page .filter-btn,
.home-page .view-btn {
  min-height: 58px;
  height: auto;
  min-width: 0;
  white-space: normal;
  line-height: 1.15;
}

.home-page .signals-grid {
  padding-top: 1rem;
  padding-bottom: 1.25rem;
}

.home-page .sg-row-hero,
.home-page .sg-row-mid,
.home-page .sg-row-low {
  align-items: stretch;
}

.home-page .sg-row-hero {
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
}

.home-page .sg-row-mid,
.home-page .sg-row-low {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.signal-card,
.home-page .signal-card {
  display: flex;
  flex-direction: column;
  height: auto;
  min-height: 0;
  overflow: visible;
  padding: var(--layout-card-pad-lg);
  gap: var(--layout-gap-md);
}

.home-page .hero-card,
.home-page .featured-secondary,
.home-page .signal-card.hero-card,
.home-page .signal-card.featured-secondary {
  min-height: 0;
  height: auto;
}

.card-header,
.home-page .card-header {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--layout-gap-sm);
}

.card-meta-top {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.card-status,
.territory-tag,
.connection-tag,
.connection-type,
.metric-inline,
.agora-label,
.map-legend,
.map-ax,
.sidebar-heading,
.analysis-heading,
.sig-id,
.sig-detected,
.sig-detected-date {
  overflow-wrap: anywhere;
}

.card-title,
.home-page .card-title {
  margin: 0;
  max-width: none;
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.home-page .hero-card .card-title,
.home-page .featured-secondary .card-title {
  max-width: none;
}

.card-connections,
.home-page .card-connections {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.55rem;
  max-width: none;
  padding-top: 0;
  border-top: none;
}

.connection-pair {
  display: inline-flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.25rem;
  max-width: 100%;
}

.connection-tag,
.home-page .connection-tag {
  max-width: none;
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}

.card-desc,
.home-page .card-desc,
.card-trigger,
.home-page .card-trigger,
.card-changed,
.home-page .card-changed,
.card-insight,
.home-page .card-insight {
  max-width: none;
  min-height: 0;
  overflow: visible;
}

.card-desc {
  display: block;
  -webkit-line-clamp: unset;
  -webkit-box-orient: initial;
  flex: 0 0 auto;
}

.card-insight,
.home-page .card-insight {
  display: none;
  max-height: none;
  opacity: 1;
  padding: 0.6rem 0.75rem;
}

.hero-card:hover .card-insight,
.featured-secondary:hover .card-insight,
.home-page .hero-card:hover .card-insight,
.home-page .featured-secondary:hover .card-insight {
  display: block;
}

.hero-card:hover .card-changed,
.featured-secondary:hover .card-changed,
.home-page .hero-card:hover .card-changed,
.home-page .featured-secondary:hover .card-changed {
  display: none;
}

.card-divider {
  margin: 0;
}

.card-footer {
  margin-top: auto;
  gap: 0.5rem;
}

.card-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.9rem;
}

.accel-flag,
.home-page .accel-flag {
  position: static;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  margin-left: auto;
  white-space: normal;
  text-align: right;
}

.signal-card .card-link {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.signal-card > *:not(.card-link) {
  position: relative;
  z-index: 2;
}

.signal-map {
  padding-top: 1rem;
  padding-bottom: 1.5rem;
}

.map-container {
  position: relative;
  height: auto;
  min-height: 420px;
  aspect-ratio: 16 / 9;
  overflow: clip;
}

.map-bubble {
  max-width: min(26vw, 140px);
  cursor: pointer;
}

.map-bubble.label-outside {
  overflow: visible;
}

.map-bubble.label-hidden {
  padding: 0;
}

.map-bubble.label-hidden::after {
  content: attr(data-strength);
  font-family: var(--font-mono);
  font-size: 0.52rem;
  opacity: 0.65;
}

.mb-name.is-outside {
  min-width: 8rem;
  max-width: 11rem;
  text-align: left;
}

.mb-name.is-hidden,
.map-bubble.label-outside .mb-pct,
.map-bubble.label-hidden .mb-pct {
  display: none;
}

.mb-name,
.mb-name.is-outside,
.tt-name,
.tt-status-row,
.tt-summary {
  overflow-wrap: anywhere;
}

.map-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.85rem;
}

.signal-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  min-height: 0;
}

.signal-hero-left,
.signal-hero-right,
.signal-analysis,
.signal-sidebar,
.sidebar-block {
  min-width: 0;
}

.signal-title {
  line-height: 1;
  overflow-wrap: anywhere;
}

.signal-body {
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 22rem);
}

.analysis-text p,
.manifest-item p,
.source-name,
.conn-reason,
.obs-context,
.sig-next-movement,
.sig-watch-list li {
  max-width: none;
}

.timeline-item {
  grid-template-columns: 4.5rem 12px minmax(0, 1fr);
}

.manifestations {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.manifesto-prose {
  max-width: 68rem;
  margin: 0 auto;
  padding-top: 4rem;
  padding-bottom: 6rem;
  padding-left: max(2.5rem, 18vw);
  padding-right: 2.5rem;
  gap: 2.25rem;
}

.manifesto-prose p,
.quem-somos p {
  max-width: 40rem;
}

.sources-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.src-node,
.src-node * {
  min-width: 0;
}

.src-node-desc,
.src-node-name {
  overflow-wrap: anywhere;
}

@media (max-width: 1180px) {
  :root {
    --layout-page-x: 1.5rem;
  }

  .home-page .sg-row-hero,
  .signal-hero,
  .signal-body {
    grid-template-columns: 1fr;
  }

  .signal-analysis {
    border-right: none;
    border-bottom: var(--border);
  }
}

@media (max-width: 920px) {
  .home-page .sg-row-mid,
  .home-page .sg-row-low,
  .sources-grid,
  .manifestations {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .map-container {
    min-height: 360px;
  }
}

@media (max-width: 700px) {
  :root {
    --layout-page-x: 1rem;
    --layout-card-pad: 1rem;
    --layout-card-pad-lg: 1rem;
  }

  .home-page .sg-row-mid,
  .home-page .sg-row-low,
  .sources-grid,
  .manifestations,
  .signal-nav-between {
    grid-template-columns: 1fr;
  }

  .site-header,
  .home-page .site-header {
    grid-template-columns: 1fr;
    min-height: 0;
  }

  .site-nav,
  .lang-selector,
  .home-page .site-nav,
  .home-page .lang-selector {
    justify-content: flex-start;
  }

  .map-container {
    min-height: 300px;
    aspect-ratio: auto;
  }
}

/* ── Internal Page Unity Layer ── */
body:not(.home-page) .signal-hero,
body:not(.home-page) .signal-body,
body:not(.home-page) .signal-nav-between,
body:not(.home-page) .manifesto-prose,
body:not(.home-page) .sources-grid,
body:not(.home-page) .sources-header,
body:not(.home-page) .src-footer-note {
  max-width: 96rem;
  margin-left: auto;
  margin-right: auto;
}

body:not(.home-page) .signal-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(18rem, 24rem);
  gap: 1px;
  padding-top: 1rem;
  padding-bottom: 0;
  background: rgba(10,10,10,0.06);
}

body:not(.home-page) .signal-hero > * {
  background: #fbf8f2;
}

body:not(.home-page) .signal-hero-body {
  grid-template-columns: minmax(0, 1fr) minmax(16rem, 20rem);
  align-items: start;
}

body:not(.home-page) .signal-body {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(18rem, 24rem);
  gap: 1px;
  background: rgba(10,10,10,0.06);
  border-bottom: none;
}

body:not(.home-page) .signal-analysis,
body:not(.home-page) .signal-sidebar {
  background: #fbf8f2;
  border-right: none;
}

body:not(.home-page) .signal-analysis {
  padding: 0;
}

body:not(.home-page) .signal-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: rgba(10,10,10,0.06);
}

body:not(.home-page) .sidebar-block {
  background: #fbf8f2;
  padding: 1.4rem 1.5rem;
  border-bottom: none;
}

body:not(.home-page) .sig-block,
body:not(.home-page) .analysis-section,
body:not(.home-page) .signal-analytical,
body:not(.home-page) .signal-observation,
body:not(.home-page) .signal-cta {
  background: #fbf8f2;
}

body:not(.home-page) .sig-block,
body:not(.home-page) .analysis-section,
body:not(.home-page) .signal-cta {
  padding-left: 2rem;
  padding-right: 2rem;
}

body:not(.home-page) .analysis-section {
  margin: 0;
  padding-top: 1.4rem;
  padding-bottom: 1.4rem;
}

body:not(.home-page) .signal-analytical {
  padding: 0.6rem 2rem 1.4rem;
  border-bottom: var(--border);
}

body:not(.home-page) .analytical-block {
  padding: 0.75rem 0 0.4rem;
  border-bottom: var(--border);
}

body:not(.home-page) .analytical-block:last-child {
  border-bottom: none;
}

body:not(.home-page) .signal-observation {
  padding: 0.35rem 2rem 1.4rem;
  border-bottom: var(--border);
}

body:not(.home-page) .obs-block {
  padding: 0.95rem 0 0.25rem;
  border-bottom: var(--border);
}

body:not(.home-page) .obs-block:last-child {
  border-bottom: none;
}

body:not(.home-page) .signal-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  border-bottom: var(--border);
}

body:not(.home-page) .signal-cta-link,
body:not(.home-page) .manifesto-cta,
body:not(.home-page) .support-cta {
  border: var(--border-strong);
  background: transparent;
}

body:not(.home-page) .connected-item,
body:not(.home-page) .timeline-item {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

body:not(.home-page) .signal-nav-between {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 1px;
  background: rgba(10,10,10,0.06);
  border-bottom: none;
}

body:not(.home-page) .sig-nav-item,
body:not(.home-page) .sig-nav-center {
  background: #fbf8f2;
}

body:not(.home-page) .sig-nav-item {
  padding: 1.35rem 1.5rem;
  border: none;
}

body:not(.home-page) .sig-nav-center {
  justify-content: center;
  padding: 0 1.25rem;
}

body:not(.home-page) .manifesto-prose {
  background: #fbf8f2;
}

body:not(.home-page) .sources-grid {
  gap: 1px;
  background: rgba(10,10,10,0.06);
}

body:not(.home-page) .src-node {
  background: #fbf8f2;
}

body:not(.home-page) .src-node:hover {
  background: #f8f4ec;
}

@media (max-width: 1180px) {
  body:not(.home-page) .signal-hero,
  body:not(.home-page) .signal-body {
    grid-template-columns: 1fr;
  }

  body:not(.home-page) .signal-hero-body {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  body:not(.home-page) .sig-block,
  body:not(.home-page) .analysis-section,
  body:not(.home-page) .signal-analytical,
  body:not(.home-page) .signal-observation,
  body:not(.home-page) .signal-cta {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  body:not(.home-page) .signal-cta {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* ══════════════════════════════════════════════
   DESIGN SYSTEM v2 — complete spec application
   2026-04-20
══════════════════════════════════════════════ */

/* ── Global: zero border-radius (only where needed) ── */
.signal-card,
.badge,
.conn-tag,
.filter-tab,
.filter-btn,
.view-btn,
.lang-btn,
.card-link,
.site-header,
.site-footer,
.axes-bar,
.filters-bar,
.now-bar { border-radius: 0; }
.live-dot,
.src-dot,
.tl-dot { border-radius: 50% !important; }

/* ── Body ── */
body { background: var(--bg-page); font-family: var(--f-edit); color: var(--ink-1); }
body.home-page { background: var(--bg-page); }

/* ── Header ── */
.site-header,
.home-page .site-header {
  display: flex !important;
  align-items: flex-start;
  justify-content: space-between;
  padding: 14px 24px 12px !important;
  height: auto !important;
  min-height: 0 !important;
  background: var(--bg-page);
  border-bottom: 0.5px solid var(--b-light);
  position: sticky;
  top: 0;
  z-index: 100;
}

.header-left,
.home-page .header-left,
.home-page .site-nav,
.home-page .lang-selector {
  padding-top: 0 !important;
}

.header-logo {
  font-family: var(--f-edit);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--ink-1);
  line-height: 1;
}

.header-bottom-line { margin-top: 3px; gap: 6px; }

.header-tagline,
.home-page .header-tagline {
  font-family: var(--f-edit);
  font-size: 10px;
  font-weight: 300;
  color: var(--ink-3);
  letter-spacing: 0.03em;
  text-transform: lowercase;
  margin-top: 0;
}

.site-nav { gap: 20px; }

.site-nav a,
.home-page .site-nav a {
  font-size: 11px;
  color: var(--ink-2);
  font-weight: 400;
  letter-spacing: 0;
}

.site-nav a:hover,
.home-page .site-nav a:hover { color: var(--ink-1); }

.lang-selector,
.home-page .lang-selector { gap: 8px; }

.lang-btn,
.home-page .lang-btn {
  font-family: var(--f-edit);
  font-size: 10px;
  letter-spacing: 0.07em;
  color: var(--ink-3);
}

.lang-btn.active,
.home-page .lang-btn.active { color: var(--ink-1); font-weight: 600; }

.live-label,
.home-page .live-label {
  font-family: var(--f-data);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--ink-3);
}

/* ── Axes bar ── */
.axes-bar,
.home-page .axes-bar {
  background: var(--bg-dark) !important;
  padding: 0 24px !important;
  gap: 0 !important;
  min-height: 0 !important;
}

.axis-btn,
.home-page .axis-btn {
  display: inline-flex;
  align-items: center;
  gap: 0;
  padding: 10px 20px 10px 0 !important;
  margin-right: 20px;
  border-bottom: 2px solid transparent;
  min-width: 0;
}

.axis-a,
.home-page .axis-a {
  font-family: var(--f-data) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  color: #E8E4DC !important;
}

.axis-sep,
.home-page .axis-sep {
  font-family: var(--f-data) !important;
  font-size: 9px !important;
  color: #555 !important;
  margin: 0 6px;
  font-weight: 400 !important;
}

.axis-b,
.home-page .axis-b {
  font-family: var(--f-data) !important;
  font-size: 10px !important;
  color: #666 !important;
  letter-spacing: 0.07em !important;
  font-weight: 400 !important;
}

.axis-delta,
.home-page .axis-delta {
  font-family: var(--f-data) !important;
  font-size: 9px !important;
  margin-left: 5px !important;
  color: #6BAF47 !important;
  font-weight: 400 !important;
}

.axis-delta.down,
.home-page .axis-delta.down {
  color: #C05A4A !important;
}

.axis-btn.active,
.home-page .axis-btn.active { border-bottom-color: var(--amber); }

.axis-btn.active .axis-a,
.home-page .axis-btn.active .axis-a { color: #E8954A !important; }

.axis-btn.active .axis-delta,
.home-page .axis-btn.active .axis-delta { color: #E8954A !important; }

.axis-lens,
.home-page .axis-lens {
  font-family: var(--f-data) !important;
  font-size: 10px !important;
  color: #555;
  letter-spacing: 0.05em;
  padding: 10px 0;
}

.axis-lens em { color: #E8954A; font-style: normal; font-weight: 600; }

/* ── AGORA strip (NOW bar) ── */
.agora-strip,
.home-page .agora-strip {
  background: var(--bg-pulse) !important;
  padding: 8px 24px !important;
  gap: 12px !important;
  border-bottom: 0.5px solid var(--b-light) !important;
  display: flex;
  align-items: center;
  flex-wrap: nowrap !important;
  row-gap: 0 !important;
}

.agora-label,
.home-page .agora-label {
  font-family: var(--f-data) !important;
  font-size: 9px !important;
  color: #9A9790 !important;
  letter-spacing: 0.1em !important;
  font-weight: 400 !important;
}

.agora-items,
.home-page .agora-items {
  display: flex !important;
  gap: 22px !important;
  flex: none !important;
  flex-wrap: nowrap !important;
  overflow: hidden !important;
}

.agora-item,
.home-page .agora-item {
  font-family: var(--f-data) !important;
  font-size: 10px !important;
  color: #3A3730 !important;
  padding-right: 0 !important;
  white-space: nowrap;
  font-weight: 400 !important;
  position: relative;
}

.agora-item a,
.home-page .agora-item a {
  color: #8A4E10 !important;
  font-weight: 600 !important;
  font-family: var(--f-data) !important;
  font-size: 10px !important;
  text-decoration: none !important;
}

.agora-item a:hover,
.home-page .agora-item a:hover {
  color: #6A3A08 !important;
}

.agora-time,
.home-page .agora-time {
  font-family: var(--f-data) !important;
  font-size: 9px !important;
  color: #9A9790 !important;
  margin-left: 4px !important;
  font-weight: 400 !important;
}

/* ── Filter bar ── */
.filter-bar,
.home-page .filter-bar {
  padding: 9px 24px !important;
  background: var(--bg-page) !important;
  border-bottom: 0.5px solid var(--b-light) !important;
  height: auto !important;
  min-height: 0 !important;
  display: flex;
  align-items: center;
  flex-wrap: nowrap !important;
  row-gap: 0 !important;
}

.filter-left,
.home-page .filter-left {
  display: flex;
  gap: 2px !important;
  flex: none !important;
  flex-wrap: nowrap !important;
}

.filter-btn,
.home-page .filter-btn {
  padding: 5px 12px !important;
  font-size: 10px !important;
  font-weight: 500 !important;
  letter-spacing: 0.08em !important;
  border: 0.5px solid transparent !important;
  font-family: var(--f-edit) !important;
  color: var(--ink-2) !important;
  background: transparent !important;
  opacity: 1 !important;
  height: auto !important;
  min-height: 0 !important;
  white-space: nowrap;
  line-height: 1;
  text-transform: uppercase;
  position: relative !important;
  z-index: 5 !important;
  pointer-events: auto !important;
  cursor: pointer !important;
}

.filter-btn:hover,
.home-page .filter-btn:hover {
  border-color: var(--b-med) !important;
  background: transparent !important;
  color: var(--ink-1) !important;
}

.filter-btn.active,
.home-page .filter-btn.active {
  background: var(--ink-1) !important;
  color: var(--ink-inv) !important;
  border-color: var(--ink-1) !important;
}

.filter-btn:focus,
.home-page .filter-btn:focus {
  outline: none !important;
}

.view-btn:focus,
.home-page .view-btn:focus {
  outline: none !important;
}

.view-toggle,
.home-page .view-toggle {
  border: 0.5px solid var(--b-med) !important;
  overflow: hidden;
  gap: 0 !important;
  flex: none;
}

.view-btn,
.home-page .view-btn {
  padding: 5px 14px !important;
  font-size: 10px !important;
  font-weight: 500 !important;
  letter-spacing: 0.07em !important;
  font-family: var(--f-edit) !important;
  color: var(--ink-2) !important;
  background: transparent !important;
  border: none !important;
  border-right: 0.5px solid var(--b-light) !important;
  height: auto !important;
  min-height: 0 !important;
  white-space: nowrap;
  line-height: 1;
  text-transform: uppercase;
}

.view-btn:last-child,
.home-page .view-btn:last-child { border-right: none !important; }

.view-btn + .view-btn,
.home-page .view-btn + .view-btn { border-left: none !important; }

.view-btn.active,
.home-page .view-btn.active {
  background: var(--ink-1) !important;
  color: var(--ink-inv) !important;
}

/* ── Grid structure ── */
.home-page .signals-grid {
  padding: 0 !important;
  background: transparent;
}

.home-page .sg-row-hero {
  background: var(--b-light);
}

.home-page .sg-row-mid,
.home-page .sg-row-low {
  background: var(--b-light);
}

.home-page .sg-row-sep {
  background: var(--b-light);
}

/* ── Cards ── */
.home-page .signal-card {
  background: var(--bg-card) !important;
  padding: 20px 22px 18px !important;
  border: 0.5px solid var(--b-light) !important;
  gap: 10px !important;
  transform: none;
  box-shadow: none;
  transition: transform 0.18s cubic-bezier(0.2,0,0,1),
              box-shadow 0.18s cubic-bezier(0.2,0,0,1),
              background 0.12s ease;
}

.home-page .signal-card:hover {
  background: var(--bg-hero) !important;
  transform: translateY(-4px) !important;
  box-shadow: 0 10px 32px rgba(18,17,14,0.09), 0 2px 8px rgba(18,17,14,0.05) !important;
  border-color: var(--b-light) !important;
}

.home-page .signal-card.hero-card {
  padding: 30px 32px 28px !important;
  background: var(--bg-hero) !important;
}

.home-page .signal-card.featured-secondary {
  padding: 24px 26px 22px !important;
  background: var(--bg-sat) !important;
}

.home-page .signal-card.card-dim {
  opacity: 0.18 !important;
  transform: scale(0.988) !important;
}

/* ── Status badges with tinted bg ── */
.card-status,
.home-page .card-status {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px !important;
  border-width: 0.5px !important;
  border-style: solid;
  font-family: var(--f-edit) !important;
  font-size: 9px !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
}

.status--novo,
.home-page .status--novo {
  border-color: var(--new-c) !important;
  color: var(--new-c) !important;
  background: var(--new-bg) !important;
}

.status--emergindo,
.home-page .status--emergindo {
  border-color: var(--emg-c) !important;
  color: var(--emg-c) !important;
  background: var(--emg-bg) !important;
}

.status--crescendo,
.home-page .status--crescendo {
  border-color: var(--grw-c) !important;
  color: var(--grw-c) !important;
  background: var(--grw-bg) !important;
}

.status--saturando,
.home-page .status--saturando {
  border-color: var(--sat-c) !important;
  color: var(--sat-c) !important;
  background: var(--sat-bg) !important;
}

/* ── Card territories ── */
.home-page .territory-tag,
.home-page .card-territories {
  font-family: var(--f-edit) !important;
  font-size: 9px !important;
  font-weight: 400 !important;
  color: var(--ink-3) !important;
  letter-spacing: 0.04em;
}

/* ── Card title ── */
.home-page .card-title {
  font-family: var(--f-edit) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  line-height: 1.13 !important;
  color: var(--ink-1) !important;
}

.home-page .signal-card.hero-card .card-title {
  font-size: 28px !important;
  letter-spacing: -0.02em !important;
  line-height: 1.08 !important;
}

.home-page .signal-card.featured-secondary .card-title {
  font-size: 22px !important;
  letter-spacing: -0.015em !important;
}

/* ── Connections ── */
.home-page .connection-type {
  font-family: var(--f-edit) !important;
  font-size: 9px !important;
  color: var(--amber) !important;
  font-style: italic;
  font-weight: 500 !important;
  letter-spacing: 0.02em;
}

.home-page .connection-tag {
  font-family: var(--f-edit) !important;
  font-size: 9px !important;
  color: var(--amber) !important;
  border: 0.5px solid rgba(176,106,32,0.28) !important;
  background: rgba(176,106,32,0.06) !important;
  padding: 2px 8px !important;
  max-width: none !important;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}

.home-page .connection-tag:hover {
  background: rgba(176,106,32,0.13) !important;
}

/* ── Card desc ── */
.home-page .card-desc {
  font-family: var(--f-edit) !important;
  font-size: 12px !important;
  font-weight: 300 !important;
  color: var(--ink-2) !important;
  line-height: 1.65 !important;
}

.home-page .signal-card.hero-card .card-desc {
  font-size: 13px !important;
  line-height: 1.68 !important;
}

/* ── Card changed / insight / trigger ── */
.home-page .card-changed {
  font-family: var(--f-edit) !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  color: var(--ink-2) !important;
  line-height: 1.55 !important;
  border-left: 1.5px solid var(--grw-c) !important;
  padding-left: 10px !important;
}

.home-page .card-changed.stage-saturating {
  border-left-color: var(--sat-c) !important;
}

.home-page .card-trigger {
  font-family: var(--f-edit) !important;
  font-size: 10px !important;
  font-weight: 500 !important;
  color: #8A6435 !important;
  letter-spacing: 0.01em;
  line-height: 1.4 !important;
  min-height: 0 !important;
}

.home-page .card-trigger.stage-saturating { color: #7A3020 !important; }
.home-page .card-trigger.stage-new { color: #1A5070 !important; }

/* ── Card divider ── */
.home-page .card-divider {
  height: 0.5px;
  background: var(--b-light);
  margin: 0 !important;
}

/* ── Metrics ── */
.home-page .metric-inline {
  font-family: var(--f-data) !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  color: var(--ink-3) !important;
}

.home-page .metric-inline strong {
  font-family: var(--f-data) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--ink-1) !important;
}

.home-page .metric-inline .metric-up { color: var(--green) !important; }
.home-page .metric-inline .metric-flat { color: var(--ink-3) !important; }
.home-page .metric-inline .metric-down { color: var(--red) !important; }

/* ── Accel flag ── */
.accel-flag,
.home-page .accel-flag {
  font-family: var(--f-data) !important;
  font-size: 9px !important;
  color: var(--green) !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em;
}

/* ── Footer ── */
.site-footer {
  display: grid !important;
  grid-template-columns: 1fr auto 1fr !important;
  align-items: center !important;
  padding: 16px 24px !important;
  border-top: 0.5px solid var(--b-light);
  background: var(--bg-page);
}

.footer-logo {
  font-family: var(--f-edit) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  color: var(--ink-1) !important;
  opacity: 1 !important;
  justify-self: start;
}

.footer-links {
  display: flex !important;
  align-items: center;
  gap: 12px !important;
  justify-content: center;
  font-size: 11px !important;
  color: var(--ink-3);
  justify-self: center;
  flex-wrap: nowrap !important;
}

.footer-links a { color: var(--ink-3) !important; }
.footer-links a:hover { color: var(--ink-1) !important; }
.footer-sep { color: var(--ink-3); opacity: 0.5; font-size: 11px; }

.footer-brand {
  font-family: var(--f-edit) !important;
  font-size: 10px !important;
  color: var(--ink-3) !important;
  text-align: right;
  opacity: 1 !important;
  justify-self: end;
}

/* ── Signal page backgrounds ── */
body:not(.home-page) .signal-hero > *,
body:not(.home-page) .signal-analysis,
body:not(.home-page) .signal-sidebar,
body:not(.home-page) .sidebar-block,
body:not(.home-page) .sig-block,
body:not(.home-page) .analysis-section,
body:not(.home-page) .signal-analytical,
body:not(.home-page) .signal-observation,
body:not(.home-page) .signal-cta,
body:not(.home-page) .sig-nav-item,
body:not(.home-page) .sig-nav-center,
body:not(.home-page) .manifesto-prose,
body:not(.home-page) .src-node { background: var(--bg-card); }

body:not(.home-page) .src-node:hover { background: var(--bg-hero); }

/* ── Signal page: title ── */
.signal-title {
  font-size: clamp(48px, 7vw, 88px) !important;
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 0.95;
}

/* ── Signal page: body text 14px/300/1.7 ── */
.sig-definition,
.sig-why-matters,
.sig-next-movement,
.obs-context,
.obs-environments li,
.sig-watch-list li,
.analytical-happening,
.analytical-why,
.analytical-tension-text,
.tl-text,
.connected-desc,
.conn-reason,
.signal-cta-text {
  font-size: 14px !important;
  font-weight: 300 !important;
  line-height: 1.7 !important;
}

/* ── Signal page: label typography 10px/0.1em/500 ── */
.sidebar-heading,
.sig-block-label,
.analysis-label,
.analytical-label,
.obs-label,
.ter-section-label,
.gauge-label,
.analysis-heading,
.forecast-label {
  font-size: 10px !important;
  letter-spacing: 0.1em !important;
  font-weight: 500 !important;
  color: var(--ink-3) !important;
}

/* ── Signal page: mono data elements ── */
.sig-id,
.sig-detected,
.sig-detected-date,
.tl-date,
.bc-link,
.bc-current,
.bc-sep {
  font-family: var(--f-data) !important;
  font-size: 11px !important;
  letter-spacing: 0.04em;
}

/* ── Signal page: status badges ── */
body:not(.home-page) .status--novo { border-color: var(--new-c); color: var(--new-c); background: var(--new-bg); border-width: 0.5px; }
body:not(.home-page) .status--emergindo { border-color: var(--emg-c); color: var(--emg-c); background: var(--emg-bg); border-width: 0.5px; }
body:not(.home-page) .status--crescendo { border-color: var(--grw-c); color: var(--grw-c); background: var(--grw-bg); border-width: 0.5px; }
body:not(.home-page) .status--saturando { border-color: var(--sat-c); color: var(--sat-c); background: var(--sat-bg); border-width: 0.5px; }

/* ── Map container — SVG via createElementNS fills this ── */
.map-container {
  background: var(--bg-page);
  position: relative;
  width: 100%;
  overflow: hidden;
}

/* Remove static map elements now that renderMap() rebuilds everything */
#map-container > .map-svg,
#map-container > .map-ax,
#map-container > .map-conn-svg,
#map-container > #map-bubbles {
  display: none;
}

/* ── Support band ── */
.support-band { background: var(--bg-card); }

/* ── Manifesto page ── */
body:not(.home-page) .site-header { background: var(--bg-page); }
