/* ===========================================
   Exposomic - Map-Focused Design
   Following Google Environmental APIs Pattern
   =========================================== */

/* CSS Variables */
/* ═══════════════════════════════════════════════════
   WARM ORGANIC THEME — vasus.ai
   Brand guide: #BB4966 deep rose · #FF9D78 salmon · #E0726C mid rose
   ═══════════════════════════════════════════════════ */
:root {
  /* ── Brand palette ──────────────────────────── */
  --color-primary:        #BB4966;
  --color-primary-hover:  #A33D59;
  --color-primary-light:  #F9EFF3;
  --color-primary-dark:   #8B2D45;
  --color-accent:         #FF9D78;
  --color-accent-mid:     #E0726C;
  --color-deep:           #5C2D43;

  /* ── Surfaces ───────────────────────────────── */
  --color-bg:             #F8F2ED;
  --color-bg-surface:     #FDF8F4;
  --color-bg-elevated:    #FAF4EF;
  --color-bg-warm:        #F5EDE4;
  --color-white:          #FFFFFF;
  --color-surface-2:      #F8F2ED;

  /* ── Text ───────────────────────────────────── */
  --color-text:             #2D1F26;
  --color-text-primary:     #2D1F26;
  --color-text-secondary:   #5A3A48;
  --color-text-muted:       #7A4A5A;
  --color-text-light:       #B8909A;
  --color-text-on-primary:  #FFFFFF;

  /* ── Borders ────────────────────────────────── */
  --color-border:         #E8D8DC;
  --color-border-light:   #F2E8EC;
  --color-border-accent:  #D4A0AD;

  /* ── Risk semantic ──────────────────────────── */
  --color-risk-minimal:     #2D8A55;
  --color-risk-minimal-bg:  #EEF7F2;
  --color-risk-moderate:    #C8760A;
  --color-risk-moderate-bg: #FEF7EC;
  --color-risk-high:        #C53030;
  --color-risk-high-bg:     #FDF0F0;

  /* ── Legacy compat ──────────────────────────── */
  --color-warning: #C8760A;
  --color-danger:  #C53030;

  /* ── Data signal colours ────────────────────── */
  --color-pressure: #9B59B6;
  --color-temp:     #E07B54;
  --color-air:      #4A9B6F;

  /* ── Radius & shadow ────────────────────────── */
  --radius-sm:    10px;
  --radius-md:    16px;
  --radius-lg:    22px;
  --radius-xl:    28px;
  --shadow-sm:    0 1px 4px rgba(92,45,67,0.07);
  --shadow-md:    0 4px 16px rgba(92,45,67,0.10);
  --shadow-lg:    0 8px 32px rgba(92,45,67,0.13);
  --shadow-panel: 0 2px 12px rgba(92,45,67,0.09);
  --shadow-card:  0 2px 8px rgba(92,45,67,0.07), 0 0 0 1px rgba(232,216,220,0.6);

  /* ── Typography ─────────────────────────────── */
  --font-family:         'Plus Jakarta Sans', -apple-system, sans-serif;
  --font-family-display: 'Playfair Display', Georgia, serif;
  --font-family-mono:    'SF Mono', 'Fira Code', monospace;

  /* ── Panel dimensions ───────────────────────── */
  --panel-left-width:  420px;
  --panel-right-width: 420px;
  --panel-gap:         20px;
}

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

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

body {
  font-family: var(--font-family);
  background: var(--color-bg);
  color: var(--color-text);
  line-height: 1.5;
  min-height: 100vh;
}

/* App Container */
.app-container {
  min-height: 100vh;
}

/* ===========================================
   Animations
   =========================================== */

/* Panel fade-in animation */
@keyframes panelFadeIn {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Gentle pulse animation for trigger risk - with glowing outline */
/* Minimal risk (green glow) */
@keyframes gentlePulseMinimal {
  0%, 100% {
    box-shadow: var(--shadow-lg), 0 0 0 0 rgba(34, 197, 94, 0);
    transform: scale(1);
    outline: 2px solid transparent;
  }
  50% {
    box-shadow: 0 10px 40px rgba(0,0,0,0.18), 0 0 20px 4px rgba(34, 197, 94, 0.4);
    transform: scale(1.01);
    outline: 2px solid rgba(34, 197, 94, 0.6);
  }
}

/* Moderate risk (amber/orange glow) */
@keyframes gentlePulseModerate {
  0%, 100% {
    box-shadow: var(--shadow-lg), 0 0 0 0 rgba(245, 158, 11, 0);
    transform: scale(1);
    outline: 2px solid transparent;
  }
  50% {
    box-shadow: 0 10px 40px rgba(0,0,0,0.18), 0 0 20px 4px rgba(245, 158, 11, 0.4);
    transform: scale(1.01);
    outline: 2px solid rgba(245, 158, 11, 0.6);
  }
}

/* High risk (red glow) */
@keyframes gentlePulseHigh {
  0%, 100% {
    box-shadow: var(--shadow-lg), 0 0 0 0 rgba(239, 68, 68, 0);
    transform: scale(1);
    outline: 2px solid transparent;
  }
  50% {
    box-shadow: 0 10px 40px rgba(0,0,0,0.18), 0 0 20px 4px rgba(239, 68, 68, 0.4);
    transform: scale(1.01);
    outline: 2px solid rgba(239, 68, 68, 0.6);
  }
}

/* Panel hidden state (before animation) */
.panel-left,
.panel-right {
  opacity: 0;
  visibility: hidden;
}

/* Panel visible state (after animation triggers) */
.panel-left.panel-visible {
  visibility: visible;
  animation: panelFadeIn 0.5s ease-out forwards;
}

.panel-right.panel-visible {
  visibility: visible;
  animation: panelFadeIn 0.5s ease-out forwards;
  animation-delay: 1s; /* 1 second delay - waits for map to settle */
}

/* When right panel is marker-anchored (positioned by JS) */
.panel-right.marker-anchored {
  transition: top 0.3s ease-out, left 0.3s ease-out, right 0.3s ease-out;
}

/* Trigger risk pulse animation - continuous gentle pulse with risk-colored glow */
.trigger-risk-card[data-risk="minimal"].pulsing {
  animation: gentlePulseMinimal 2s ease-in-out infinite;
}

.trigger-risk-card[data-risk="moderate"].pulsing {
  animation: gentlePulseModerate 2s ease-in-out infinite;
}

.trigger-risk-card[data-risk="high"].pulsing {
  animation: gentlePulseHigh 2s ease-in-out infinite;
}

/* Fallback for any other risk level */
.trigger-risk-card.pulsing {
  animation: gentlePulseModerate 2s ease-in-out infinite;
}

/* ===========================================
   Input View (unchanged)
   =========================================== */

.input-content {
  max-width: 800px;
  margin: 0 auto;
  padding: 48px 24px;
}

/* Hero Section */
.hero {
  text-align: center;
  margin-bottom: 48px;
}

.hero-title {
  font-size: 28px;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 12px;
  line-height: 1.3;
}

.hero-subtitle {
  font-size: 16px;
  color: var(--color-text-muted);
  margin-bottom: 8px;
}

.hero-disclaimer {
  font-size: 13px;
  color: var(--color-text-light);
}

/* Section Labels */
.section-label {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-muted);
  margin-bottom: 16px;
  text-align: center;
}

/* Sensitivity Cards */
.sensitivity-section {
  margin-bottom: 32px;
}

.sensitivity-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.sensitivity-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 32px 24px;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: inherit;
}

.sensitivity-card:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-sm);
}

.sensitivity-card[data-selected="true"] {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
}

.card-icon {
  font-size: 32px;
}

.card-title {
  font-size: 15px;
  font-weight: 500;
  color: var(--color-text);
  text-align: center;
}

/* Context Section */
.context-section {
  margin-bottom: 32px;
}

.context-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
}

.context-group {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.context-label {
  font-size: 14px;
}

.location-input {
  border: none;
  background: transparent;
  font-size: 14px;
  font-family: inherit;
  color: var(--color-text);
  outline: none;
  width: 150px;
}

.location-input::placeholder {
  color: var(--color-text-light);
}

.pill-group {
  display: flex;
  gap: 4px;
}

.pill {
  padding: 6px 12px;
  font-size: 13px;
  font-family: inherit;
  color: var(--color-text-muted);
  background: transparent;
  border: 1px solid transparent;
  border-radius: 16px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.pill:hover {
  background: var(--color-border-light);
}

.pill[data-selected="true"] {
  background: var(--color-border-light);
  color: var(--color-text);
  font-weight: 500;
}

/* Submit Button */
.submit-section {
  text-align: center;
  margin-bottom: 48px;
}

.submit-btn {
  padding: 14px 40px;
  font-size: 15px;
  font-weight: 600;
  font-family: inherit;
  color: var(--color-white);
  background: var(--color-primary);
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 0.2s ease;
}

.submit-btn:hover:not(:disabled) {
  background: var(--color-primary-dark);
}

.submit-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Footer */
.footer-links {
  display: flex;
  justify-content: center;
  gap: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--color-border-light);
}

.footer-links a {
  font-size: 13px;
  color: var(--color-text-light);
  text-decoration: none;
}

.footer-links a:hover {
  color: var(--color-primary);
}

/* ===========================================
   Results View - Map Focused Layout
   =========================================== */

.results-view {
  position: relative;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
}

/* Full-screen Map */
.map-fullscreen {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 0;
}

/* Left Panel - Sidebar */
.panel-left {
  position: absolute;
  top: var(--panel-gap);
  left: var(--panel-gap);
  bottom: var(--panel-gap);
  width: var(--panel-left-width);
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: 10;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Back Button */
.back-btn {
  position: sticky;
  top: 0;
  left: 0;
  margin: 16px;
  padding: 8px 16px;
  font-size: 14px;
  font-family: inherit;
  color: var(--color-text-muted);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  z-index: 5;
  width: fit-content;
  transition: all 0.2s ease;
}

.back-btn:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

/* Panel Header */
.panel-header {
  padding: 0 20px 16px;
  border-bottom: 1px solid var(--color-border-light);
}

.panel-title {
  font-size: 22px;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 8px;
}

.panel-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--color-text-muted);
  flex-wrap: wrap;
}

.meta-divider {
  color: var(--color-text-light);
}

/* Panel Scrollable Content */
.panel-left .panel-section {
  padding: 16px 20px;
  border-bottom: 1px solid var(--color-border-light);
}

.panel-left .panel-section:last-child {
  border-bottom: none;
}

/* Make panel content scrollable */
.panel-left {
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--color-border) transparent;
}

.panel-left::-webkit-scrollbar {
  width: 6px;
}

.panel-left::-webkit-scrollbar-track {
  background: transparent;
}

.panel-left::-webkit-scrollbar-thumb {
  background: var(--color-border);
  border-radius: 3px;
}

/* Section Headers */
.section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.section-icon {
  font-size: 14px;
}

.section-header h3 {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

/* Relevance Card */
.relevance-card {
  background: var(--color-border-light);
  border-radius: var(--radius-sm);
  padding: 12px;
  border-left: 3px solid var(--color-primary);
}

.relevance-item {
  display: flex;
  gap: 10px;
}

.relevance-bullet {
  font-size: 14px;
  flex-shrink: 0;
}

.relevance-item p {
  font-size: 13px;
  color: var(--color-text-muted);
  line-height: 1.6;
}

/* Uncertainty Section */
.uncertainty-list {
  background: #fffbeb;
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  border-left: 3px solid var(--color-risk-moderate);
  list-style: none;
}

.uncertainty-item {
  display: flex;
  gap: 10px;
  padding: 6px 0;
  font-size: 13px;
  color: var(--color-text-muted);
}

.uncertainty-item::before {
  content: '•';
  color: var(--color-risk-moderate);
  font-weight: bold;
}

/* Evidence Section */
.evidence-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.evidence-item {
  display: flex;
  gap: 10px;
  padding: 10px;
  background: var(--color-border-light);
  border-radius: var(--radius-sm);
  transition: all 0.2s ease;
}

.evidence-item:hover {
  background: #e8e8e8;
}

.evidence-ref-num {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-primary);
  min-width: 24px;
}

.evidence-item-content {
  flex: 1;
  min-width: 0;
}

.evidence-item-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text);
  margin-bottom: 4px;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.evidence-item-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  flex-wrap: wrap;
}

.evidence-item-meta a {
  color: var(--color-primary);
  text-decoration: none;
}

.evidence-item-meta a:hover {
  text-decoration: underline;
}

.evidence-item-year {
  color: var(--color-text-light);
}

.evidence-fit {
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
}

.evidence-fit.fit-high {
  background: #dcfce7;
  color: #166534;
}

.evidence-fit.fit-moderate {
  background: #fef3c7;
  color: #92400e;
}

.evidence-fit.fit-low {
  background: #f3f4f6;
  color: #6b7280;
}

.no-evidence {
  font-size: 13px;
  color: var(--color-text-light);
  font-style: italic;
  padding: 12px;
  text-align: center;
}

/* Citation superscripts */
.citation-ref {
  color: var(--color-primary);
  cursor: pointer;
  font-weight: 600;
  margin: 0 1px;
  transition: color 0.2s ease;
}

.citation-ref:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

/* Feedback Section */
.feedback-section {
  text-align: center;
  padding: 20px !important;
}

.feedback-question {
  font-size: 13px;
  color: var(--color-text-muted);
  margin-bottom: 12px;
}

.feedback-buttons {
  display: flex;
  justify-content: center;
  gap: 16px;
}

.feedback-btn {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.2s ease;
}

.feedback-btn:hover {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
}

.feedback-btn[data-selected="true"] {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
}

.feedback-status {
  display: block;
  margin-top: 10px;
  font-size: 12px;
  color: var(--color-text-muted);
}

/* Compact feedback card for right panel */
.feedback-card {
  padding: 10px 14px !important;
}

.feedback-card .feedback-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.feedback-card .feedback-question {
  margin: 0;
  font-size: 13px;
  color: var(--color-text-muted);
  white-space: nowrap;
}

.feedback-card .feedback-btn {
  width: 36px;
  height: 36px;
  font-size: 18px;
  flex-shrink: 0;
}

.feedback-card .feedback-status {
  display: inline;
  margin: 0;
  margin-left: auto;
  font-size: 12px;
}

/* ===========================================
   Right Panel - Floating Cards (Anchored to Marker)
   =========================================== */

.panel-right {
  position: absolute;
  /* Will be dynamically positioned by JS to anchor near marker */
  top: var(--panel-gap);
  right: var(--panel-gap);
  width: var(--panel-right-width);
  z-index: 10;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: calc(100vh - 40px);
  overflow-y: auto;
  scrollbar-width: none;
}

.panel-right::-webkit-scrollbar {
  display: none;
}

/* Connector arrow pointing toward marker */
.panel-right::before {
  content: '';
  position: absolute;
  top: 60px;
  width: 0;
  height: 0;
  z-index: -1;
  transition: left 0.3s ease-out, right 0.3s ease-out, border 0.3s ease-out;
}

/* Default: arrow on left pointing left (panel is right of marker) */
.panel-right.connector-left::before,
.panel-right:not(.connector-right)::before {
  left: -12px;
  right: auto;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
  border-right: 12px solid var(--color-white);
  border-left: none;
  filter: drop-shadow(-3px 0 3px rgba(0,0,0,0.1));
}

/* Arrow on right pointing right (panel is left of marker) */
.panel-right.connector-right::before {
  right: -12px;
  left: auto;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
  border-left: 12px solid var(--color-white);
  border-right: none;
  filter: drop-shadow(3px 0 3px rgba(0,0,0,0.1));
}

/* Floating Cards */
.floating-card {
  background: var(--color-white);
  border-radius: var(--radius-md);
  padding: 16px;
  box-shadow: var(--shadow-lg);
}

/* Trigger Risk Card */
.trigger-risk-card {
  border-left: 4px solid;
  position: relative;
  overflow: hidden;
}

.trigger-risk-card[data-risk="minimal"] {
  background: var(--color-risk-minimal-bg);
  border-left-color: var(--color-risk-minimal);
}

.trigger-risk-card[data-risk="moderate"] {
  background: var(--color-risk-moderate-bg);
  border-left-color: var(--color-risk-moderate);
}

.trigger-risk-card[data-risk="high"] {
  background: var(--color-risk-high-bg);
  border-left-color: var(--color-risk-high);
}

.risk-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.risk-icon {
  font-size: 16px;
}

.risk-title {
  font-size: 14px;
  font-weight: 600;
}

.trigger-risk-card[data-risk="minimal"] .risk-title {
  color: var(--color-risk-minimal);
}

.trigger-risk-card[data-risk="moderate"] .risk-title {
  color: var(--color-risk-moderate);
}

.trigger-risk-card[data-risk="high"] .risk-title {
  color: var(--color-risk-high);
}

.risk-description {
  font-size: 13px;
  color: var(--color-text-muted);
  line-height: 1.5;
}

/* Recommendations Card */
.recommendations-card .section-header {
  margin-bottom: 8px;
}

.recommendations-card .section-header h3 {
  text-transform: none;
  font-size: 14px;
}

.recommendations-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.recommendation-item {
  display: flex;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--color-border-light);
}

.recommendation-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.recommendation-item:first-child {
  padding-top: 0;
}

.recommendation-icon {
  font-size: 14px;
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  background: #e8f5e9;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.recommendation-text {
  font-size: 13px;
  color: var(--color-text-muted);
  line-height: 1.5;
}

.no-recommendations {
  font-size: 13px;
  color: var(--color-text-light);
  font-style: italic;
}

/* Environment Card */
.env-card {
  background: var(--color-white);
}

.env-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.env-header h3 {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text);
  flex: 1;
}

.env-icon {
  font-size: 14px;
}

.env-badge {
  font-size: 16px;
}

.env-items {
  display: flex;
  flex-direction: column;
  gap: 8px;
  list-style: none;
}

.env-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  line-height: 1.5;
}

.env-item-icon {
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 11px;
  flex-shrink: 0;
  margin-top: 2px;
  font-weight: 600;
}

.env-item-icon.up {
  background: #fee2e2;
  color: #dc2626;
}

.env-item-icon.down {
  background: #dbeafe;
  color: #2563eb;
}

.env-item-icon.neutral {
  background: #f3f4f6;
  color: #6b7280;
}

.env-item-icon.pressure {
  background: #dbeafe;
  color: var(--color-pressure);
}

.env-item-icon.temp {
  background: #cffafe;
  color: var(--color-temp);
}

.env-item-icon.air {
  background: #dcfce7;
  color: var(--color-air);
}

.env-item-text {
  color: var(--color-text-muted);
}

.env-item-text strong,
.env-item strong {
  color: var(--color-text);
  font-weight: 600;
}

/* ===========================================
   Loading Overlay
   =========================================== */

.loading-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.9);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  z-index: 1000;
}

.loading-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.loading-overlay p {
  font-size: 14px;
  color: var(--color-text-muted);
}

/* ===========================================
   Responsive Design
   =========================================== */

/* Large screens - default layout */
@media (min-width: 1400px) {
  :root {
    --panel-left-width: 440px;
    --panel-right-width: 460px;
  }
}

/* Medium-large screens */
@media (max-width: 1200px) {
  :root {
    --panel-left-width: 380px;
    --panel-right-width: 400px;
  }
  
  .panel-right::before {
    display: none; /* Hide connector on smaller screens */
  }
}

/* Medium screens - stack right panel */
@media (max-width: 1024px) {
  :root {
    --panel-left-width: 360px;
    --panel-right-width: 360px;
    --panel-gap: 16px;
  }
  
  .panel-title {
    font-size: 20px;
  }
  
  .panel-right::before {
    display: none;
  }
}

/* Tablet - Overlay mode */
@media (max-width: 900px) {
  :root {
    --panel-left-width: 340px;
    --panel-right-width: 340px;
  }
  
  .panel-right {
    top: auto;
    bottom: var(--panel-gap);
    right: var(--panel-gap);
    left: calc(var(--panel-left-width) + var(--panel-gap) * 2);
    width: auto;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
    max-height: none;
    overflow: visible;
  }
  
  .panel-right::before {
    display: none;
  }
  
  .floating-card {
    flex: 1;
    min-width: 200px;
  }
}

/* Small tablet / Large mobile */
@media (max-width: 768px) {
  .results-view {
    display: flex;
    flex-direction: column;
    height: auto;
    min-height: 100vh;
  }
  
  .map-fullscreen {
    position: relative;
    height: 200px;
    flex-shrink: 0;
  }
  
  .panel-left {
    position: relative;
    top: 0;
    left: 0;
    bottom: auto;
    width: 100%;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    margin-top: -20px;
    max-height: none;
    flex: 1;
    /* Override animation for mobile - show immediately */
    opacity: 1;
    visibility: visible;
    animation: none;
  }
  
  .panel-right {
    position: relative;
    top: 0;
    right: 0;
    bottom: auto;
    left: 0;
    width: 100%;
    padding: 0 16px 16px;
    flex-direction: column;
    gap: 12px;
    /* Override animation for mobile - show immediately */
    opacity: 1;
    visibility: visible;
    animation: none;
  }
  
  .panel-right::before {
    display: none;
  }
  
  .floating-card {
    min-width: auto;
  }
  
  .back-btn {
    position: absolute;
    top: 12px;
    left: 12px;
    margin: 0;
    background: var(--color-white);
    box-shadow: var(--shadow-md);
    z-index: 20;
  }
  
  /* Input view responsive */
  .sensitivity-grid {
    grid-template-columns: 1fr;
  }
  
  .context-row {
    flex-direction: column;
    align-items: stretch;
  }
  
  .context-group {
    justify-content: center;
  }
}

/* Mobile */
@media (max-width: 480px) {
  .input-content {
    padding: 32px 16px;
  }
  
  .hero-title {
    font-size: 24px;
  }
  
  .panel-title {
    font-size: 18px;
  }
  
  .panel-meta {
    flex-direction: column;
    gap: 4px;
    align-items: flex-start;
  }
  
  .meta-divider {
    display: none;
  }
  
  .map-fullscreen {
    height: 180px;
  }
  
  .floating-card {
    padding: 14px;
  }
  
  .recommendation-item {
    padding: 8px 0;
  }
}

/* ===========================================
   STYLE.CSS - ADDITIONS FOR EXPOSURE WINDOW
   ===========================================
   
   Add these styles to your existing style.css file.
   They handle the new past/future pill groupings.
*/

/* Wider context group for exposure windows */
.context-group-wide {
  flex: 2;
}

/* Wrapper for past/future pill groups */
.pill-group-wrapper {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Individual pill group (past or future) */
.pill-group-past,
.pill-group-future {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* Label above each pill group */
.pill-group-label {
  font-size: 11px;
  color: var(--color-text-secondary, #666);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Row of pills */
.pill-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

/* Past pills - subtle blue tint */
.pill.pill-past {
  background-color: #f0f4ff;
  border-color: #c7d4f0;
}

.pill.pill-past:hover {
  background-color: #e0e8ff;
  border-color: #a8b8e0;
}

.pill.pill-past[data-selected="true"] {
  background-color: #4a6fa5;
  border-color: #4a6fa5;
  color: white;
}

/* Future pills - subtle green tint */
.pill.pill-future {
  background-color: #f0fff4;
  border-color: #c7f0d4;
}

.pill.pill-future:hover {
  background-color: #e0ffe8;
  border-color: #a8e0b8;
}

.pill.pill-future[data-selected="true"] {
  background-color: #4aa56f;
  border-color: #4aa56f;
  color: white;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .pill-group-wrapper {
    gap: 12px;
  }
  
  .pill-row {
    flex-wrap: wrap;
  }
  
  .context-group-wide {
    flex: 1 1 100%;
  }
}

/* Environment card title update for past context */
.env-card[data-direction="past"] .env-header h3::before {
  content: "What was in your environment";
}
/* ===========================================
   Window Summary Grid (Left Panel — NEW)
   Shows 6/24/72h exposure metrics as a card grid
   =========================================== */

.window-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 8px;
}

.window-metric {
  background: var(--color-bg);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  text-align: center;
  border-left: 3px solid transparent;
  transition: border-color 0.2s ease;
}

.window-metric-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.2;
}

.window-metric-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.window-metric-sublabel {
  font-size: 11px;
  color: var(--color-text-light);
  margin-top: 2px;
}

/* Metric severity colors */
.window-metric.metric-good {
  border-left-color: var(--color-risk-minimal);
}
.window-metric.metric-good .window-metric-value {
  color: #15803d;
}

.window-metric.metric-ok {
  border-left-color: #60a5fa;
}
.window-metric.metric-ok .window-metric-value {
  color: #2563eb;
}

.window-metric.metric-warn {
  border-left-color: var(--color-risk-moderate);
  background: #fffbeb;
}
.window-metric.metric-warn .window-metric-value {
  color: #b45309;
}

.window-metric.metric-bad {
  border-left-color: var(--color-risk-high);
  background: #fef2f2;
}
.window-metric.metric-bad .window-metric-value {
  color: #dc2626;
}

/* Evidence matched factor tags */
.evidence-factors {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 6px;
}

.factor-tag {
  display: inline-block;
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  font-weight: 500;
}

/* Responsive: window summary on small screens */
@media (max-width: 600px) {
  .window-summary-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
/* ===========================================
   REQ-03-C: Pollutant Detail Expandable Section
   =========================================== */

.pollutant-detail-toggle {
  margin-top: 8px;
  border-top: 1px solid var(--color-border);
  padding-top: 8px;
}

.pollutant-toggle-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 0.8rem;
  color: var(--color-text-secondary);
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
  width: 100%;
  text-align: left;
  font-family: var(--font-family);
}

.pollutant-toggle-btn:hover {
  color: var(--color-primary);
}

.toggle-chevron {
  font-size: 0.65rem;
  transition: transform 0.2s;
}

.pollutant-detail-table {
  margin-top: 8px;
}

.pdt-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 3px 6px;
  border-radius: 4px;
  font-size: 0.8rem;
}

.pdt-row:nth-child(even) {
  background: var(--color-surface-2, #f8f8f8);
}

.pdt-label {
  color: var(--color-text-secondary);
}

.pdt-value {
  font-weight: 500;
  color: var(--color-text-primary);
}

.pdt-warn .pdt-value {
  color: var(--color-warning, #c55a11);
}

.pdt-bad .pdt-value {
  color: var(--color-danger, #c00000);
  font-weight: 600;
}

.pdt-footer {
  margin-top: 6px;
  padding: 4px 6px;
  font-size: 0.72rem;
  color: var(--color-text-light);
  font-style: italic;
  border-top: 1px solid var(--color-border-light);
}

/* ===========================================
   EHSPI — Location Health Index Section
   =========================================== */

/* ── EHSPI badge in section header ── */
.ehspi-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 10px;
  background: var(--color-primary);
  color: #fff;
  vertical-align: middle;
  margin-left: 6px;
  line-height: 1.6;
}

/* ── Intro line ── */
.ehspi-intro {
  font-size: 12px;
  color: var(--color-text-muted);
  margin: 0 0 12px;
  line-height: 1.55;
}

/* ── Each chart block ── */
.ehspi-chart-wrap {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: 12px 12px 10px;
  margin-bottom: 10px;
}

.ehspi-chart-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 10px;
}

.ehspi-chart-label span {
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}

/* ── Rank row ── */
.ehspi-rank-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: var(--color-primary-light);
  border-radius: var(--radius-sm);
  margin-bottom: 10px;
}

.ehspi-rank-label {
  font-size: 11px;
  color: var(--color-text-muted);
}

.ehspi-rank-value {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-primary);
}

/* ── Confidence chip ── */
.ehspi-confidence {
  display: inline-block;
  font-size: 11px;
  padding: 4px 10px;
  border-radius: 12px;
  margin-top: 6px;
  background: var(--color-border-light);
  color: var(--color-text-muted);
}
.ehspi-confidence[data-confidence='high'] {
  background: #f0fdf4;
  color: var(--color-risk-minimal);
}
.ehspi-confidence[data-confidence='moderate'] {
  background: #fffbeb;
  color: var(--color-risk-moderate);
}

/* ── Loading / error states ── */
.ehspi-loading {
  font-size: 12px;
  color: var(--color-text-light);
  padding: 10px 0 4px;
  text-align: center;
}

.ehspi-error {
  font-size: 12px;
  color: var(--color-text-muted);
  padding: 8px 12px;
  background: var(--color-border-light);
  border-radius: var(--radius-sm);
  line-height: 1.5;
}

/* ── Null-dimension footnote ── */
.ehspi-null-note {
  font-size: 10px;
  color: var(--color-text-light);
  font-style: italic;
  margin-top: 6px;
  line-height: 1.4;
}

/* ── Week-on-week annotation ── */
.ehspi-wow-annotation {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-top: 8px;
  padding: 4px 10px;
  background: var(--color-border-light);
  border-radius: var(--radius-sm);
  display: inline-block;
}

/* ===========================================
   REQ-EHSPI-UX-01 v1.2: Score bar chart, narrative, scale key
   ISS-C (backend), ISS-A, ISS-B, ISS-D, ISS-E, ISS-F, ISS-G
   =========================================== */

/* ISS-F: Score framing key */
.ehspi-scale-key {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  font-weight: 700;
  color: var(--rose, #BB4966);
  letter-spacing: 0.01em;
}

/* ISS-G: Narrative callout */
.ehspi-narrative {
  background: var(--rose-light, #fdf2f5);
  border: 1px solid var(--border, #e8ddd5);
  border-radius: 12px;
  padding: 14px 16px;
  margin-bottom: 16px;
}
.ehspi-narrative-text {
  font-size: 13.5px;
  color: var(--deep, #2C1810);
  line-height: 1.65;
  margin: 0;
}
.ehspi-narrative-loading {
  font-size: 13px;
  color: var(--muted, #9A8070);
  font-style: italic;
  margin: 0;
  animation: ehspi-pulse 1.2s ease-in-out infinite;
}
@keyframes ehspi-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.5; }
}

/* ISS-E: Score bar chart wrapper */
.ehspi-score-bar-wrap { padding: 4px 0; }

/* Composite headline row */
.ehspi-composite-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border, #e8ddd5);
}
.ehspi-composite-score {
  font-size: 42px;
  font-weight: 700;
  color: var(--deep, #2C1810);
  line-height: 1;
  flex-shrink: 0;
}
.ehspi-composite-score.score-favourable  { color: #1A6B3A; }
.ehspi-composite-score.score-moderate    { color: var(--rose, #BB4966); }
.ehspi-composite-score.score-challenging { color: #8B1A1A; }
.ehspi-composite-meta  { flex: 1; min-width: 0; }
.ehspi-composite-label { font-size: 13px; font-weight: 700; color: var(--deep, #2C1810); }
.ehspi-composite-subtext { font-size: 11px; color: var(--muted, #9A8070); margin-top: 2px; }

/* Scale header 0–100 */
.ehspi-scale-header {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: var(--muted, #9A8070);
  margin-bottom: 10px;
}
.ehspi-scale-header span       { text-align: center; }
.ehspi-scale-header span span  { display: block; font-weight: 700; }

/* Individual bar rows */
.ehspi-bar-row {
  margin-bottom: 10px;
  opacity: 0.7;
  transition: opacity 0.2s;
}
.ehspi-bar-row-active { opacity: 1; }
.ehspi-bar-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 4px;
}
.ehspi-bar-icon       { font-size: 13px; flex-shrink: 0; }
.ehspi-bar-label      { font-size: 12px; color: var(--deep, #2C1810); flex: 1; }
.ehspi-bar-score      { font-size: 12px; font-weight: 700; color: var(--deep, #2C1810); flex-shrink: 0; }
.ehspi-bar-score-null { color: var(--muted, #9A8070); font-weight: 400; }

/* Bar track + fill */
.ehspi-bar-track {
  height: 8px;
  background: #eee;
  border-radius: 100px;
  position: relative;
  overflow: visible;
}
.ehspi-bar-fill {
  height: 100%;
  border-radius: 100px;
  background: var(--muted, #9A8070);
  transition: width 0.4s ease;
}
.ehspi-bar-fill-active { background: var(--rose, #BB4966); }
.ehspi-bar-fill-null   { background: #ddd; width: 100% !important; opacity: 0.3; }

/* Median tick mark */
.ehspi-bar-median {
  position: absolute;
  top: -3px;
  bottom: -3px;
  width: 2px;
  background: var(--deep, #2C1810);
  opacity: 0.35;
  border-radius: 1px;
  transform: translateX(-50%);
  cursor: help;
}

/* Legend */
.ehspi-bar-legend {
  display: flex;
  gap: 16px;
  margin-top: 12px;
  font-size: 11px;
  color: var(--muted, #9A8070);
}
.ehspi-legend-item { display: flex; align-items: center; gap: 5px; }
.ehspi-legend-dot  {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--muted, #9A8070);
}
.ehspi-legend-dot-active { background: var(--rose, #BB4966); }
.ehspi-legend-line {
  width: 14px; height: 2px;
  background: var(--deep, #2C1810);
  opacity: 0.35;
  border-radius: 1px;
}

/* ISS-A: rank row note and sensitivity label */
.ehspi-rank-note        { font-size: 10px; color: var(--muted, #9A8070); font-style: italic; margin-left: 4px; }
.ehspi-rank-sensitivity { color: var(--rose, #BB4966); font-weight: 600; }


/* ===========================================
   REQ-07-A: Enrichment Input Panel
   =========================================== */

.enrichment-section {
  width: 100%;
  margin-bottom: 24px;
}

.enrichment-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  color: var(--color-primary);
  padding: 8px 0;
  width: 100%;
  text-align: left;
}

.enrichment-toggle:hover { opacity: 0.8; }

.enrichment-toggle-icon {
  font-size: 16px;
  font-weight: 700;
  transition: transform 0.2s;
  line-height: 1;
}

.enrichment-toggle[aria-expanded='true'] .enrichment-toggle-icon {
  transform: rotate(45deg);
}

.enrichment-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.enrichment-panel[aria-hidden='false'] {
  max-height: 600px;
}

.enrichment-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 16px;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-top: 8px;
}

.enrichment-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.enrichment-field-full {
  grid-column: 1 / -1;
}

.enrichment-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
}

.enrichment-input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 6px 10px;
  font-size: 13px;
  font-family: inherit;
  color: var(--color-text);
  background: var(--color-bg);
  outline: none;
  transition: border-color 0.2s;
}

.enrichment-input:focus { border-color: var(--color-primary); }

/* REQ-07-E: select inherits .enrichment-input sizing/colours; this adds dropdown chrome */
.enrichment-select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
  cursor: pointer;
}
.enrichment-select:focus { border-color: var(--color-primary); outline: none; }

.enrichment-number { width: 100px; }

.enrichment-free { margin-top: 8px; }

.enrichment-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 28px;
}

.enrichment-chip {
  padding: 5px 12px;
  font-size: 12px;
  font-family: inherit;
  border: 1px solid var(--color-border);
  border-radius: 16px;
  cursor: pointer;
  background: var(--color-white);
  color: var(--color-text-muted);
  transition: all 0.15s;
  line-height: 1.3;
}

.enrichment-chip:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.enrichment-chip[data-selected='true'] {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: white;
  font-weight: 500;
}

/* ===========================================
   REQ-07-B: Enrichment active badge (results)
   =========================================== */

.enrichment-active-badge {
  font-size: 11px;
  color: var(--color-primary);
  font-weight: 600;
  padding: 2px 0;
  margin-top: 4px;
  display: none;
}

/* ===========================================
   REQ-07-C: Extended relevance paragraphs
   =========================================== */

.relevance-para {
  font-size: 13px;
  color: var(--color-text-muted);
  line-height: 1.65;
  margin-bottom: 10px;
}

.relevance-para:last-child { margin-bottom: 0; }

/* Para 1: mechanism — no additional style, inherits base */
.relevance-para-mechanism { }

/* Para 2: window-specific risk — visually separated */
.relevance-para-window {
  border-top: 1px solid var(--color-border-light);
  padding-top: 10px;
  margin-top: 2px;
}

/* Citation superscripts inside relevance paragraphs */
.citation-ref {
  font-size: 11px;
  color: var(--color-primary);
  cursor: pointer;
  font-weight: 600;
  text-decoration: none;
  vertical-align: super;
  line-height: 0;
}

.citation-ref:hover { text-decoration: underline; }

/* ===========================================
   REQ-07-D: Numeric metric strip (risk card)
   =========================================== */

.risk-metric-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.risk-metric-chip {
  font-size: 11px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 10px;
  background: rgba(0,0,0,0.06);
  color: var(--color-text-muted);
  white-space: nowrap;
}

/* ================================================================
   REQ-12-B: Alert UI components
   All scoped to .alert-* classes — zero impact on core app styles
   ================================================================ */

/* ── Alert bar (Option A — post-result trigger) ───────────────── */
.alert-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: var(--color-bg-elevated, #f0f4ff);
  border-top: 1px solid var(--color-border, #e2e8f0);
  font-size: 14px;
  /* Fix: stick to bottom of panel-left so it's visible regardless of scroll position */
  position: sticky;
  bottom: 0;
  z-index: 10;
  margin-top: auto;
}

.alert-bar-icon { font-size: 18px; flex-shrink: 0; }

.alert-bar-text {
  flex: 1;
  color: var(--color-text);
  font-size: 13px;
  line-height: 1.4;
}

.alert-bar-btn {
  background: var(--color-primary, #1F4E79);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}

.alert-bar-btn:hover { opacity: 0.88; }

.alert-bar-dismiss {
  background: none;
  border: none;
  font-size: 18px;
  color: var(--color-text-muted);
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
  flex-shrink: 0;
}

.alert-bar-state {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

/* Active dot indicator when subscribed */
.alert-bar-active-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #0D9488;
  flex-shrink: 0;
  animation: alertDotPulse 2s ease-in-out infinite;
}

@keyframes alertDotPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

/* Turn off button variant — outlined style */
.alert-bar-btn-unsub {
  background: transparent;
  color: var(--color-text-muted, #64748b);
  border: 1px solid var(--color-border, #e2e8f0);
}

.alert-bar-btn-unsub:hover {
  border-color: var(--color-risk-high, #dc2626);
  color: var(--color-risk-high, #dc2626);
  opacity: 1;
}

.alert-bar-enter {
  animation: alertSlideUp 0.3s ease;
}

@keyframes alertSlideUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Subscribe modal ──────────────────────────────────────────── */
.alert-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.alert-modal {
  background: var(--color-bg, #fff);
  border-radius: 12px;
  padding: 24px;
  max-width: 380px;
  width: 90%;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

.alert-modal-title {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 16px;
}

.alert-modal-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
  font-size: 14px;
  flex-wrap: wrap;
}

.alert-modal-label {
  color: var(--color-text-muted);
  width: 110px;
  flex-shrink: 0;
  font-size: 13px;
}

.alert-modal-value { font-weight: 600; }

.alert-modal-radio {
  font-size: 13px;
  cursor: pointer;
  margin-left: 4px;
  display: flex;
  align-items: center;
  gap: 4px;
}

.alert-modal-privacy {
  font-size: 11px;
  color: var(--color-text-muted);
  margin: 16px 0;
  padding: 10px;
  background: var(--color-bg-subtle, #f8fafc);
  border-radius: 6px;
  line-height: 1.5;
}

.alert-modal-enable {
  width: 100%;
  padding: 12px;
  background: var(--color-primary, #1F4E79);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  margin-bottom: 8px;
}

.alert-modal-enable:hover { opacity: 0.88; }

.alert-modal-cancel {
  width: 100%;
  padding: 10px;
  background: none;
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: 8px;
  font-size: 14px;
  cursor: pointer;
  color: var(--color-text-muted);
}

.alert-modal-blocked {
  font-size: 12px;
  color: var(--color-risk-high, #dc2626);
  margin-top: 10px;
  line-height: 1.4;
}

/* ── Bell icon (Option B management) ─────────────────────────── */
.alert-bell-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  margin-left: auto;
  font-size: 20px;
  line-height: 1;
  flex-shrink: 0;
}

.alert-bell-inactive { opacity: 0.35; filter: grayscale(1); }
.alert-bell-active   { opacity: 1;    filter: none; }

/* panel-header needs flex to accommodate bell */
.panel-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 4px;
}

/* ── Bell status panel ─────────────────────────────────────────── */
.alert-status-panel {
  background: var(--color-bg-elevated, #f8fafc);
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 12px;
}

.alert-status-title {
  font-size: 11px;
  font-weight: 700;
  margin: 0 0 10px;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.alert-status-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 0;
  border-bottom: 1px solid var(--color-border-light, #e2e8f0);
  font-size: 13px;
}

.alert-status-row:last-child { border-bottom: none; }

.alert-status-name      { font-weight: 600; flex: 1; }
.alert-status-threshold { color: var(--color-text-muted); font-size: 12px; }

.alert-status-off {
  background: none;
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: 5px;
  padding: 3px 10px;
  font-size: 12px;
  cursor: pointer;
  color: var(--color-text-muted);
  white-space: nowrap;
}

.alert-status-off:hover { border-color: var(--color-risk-high, #dc2626); color: var(--color-risk-high, #dc2626); }

.alert-status-close {
  width: 100%;
  margin-top: 10px;
  background: none;
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: 6px;
  padding: 7px;
  font-size: 13px;
  cursor: pointer;
  color: var(--color-text-muted);
}

.alert-status-empty {
  font-size: 13px;
  color: var(--color-text-muted);
  margin: 0;
  padding: 4px 0;
}

/* ================================================================
   REQ-EHSPI-CRC: City Ranking Chart + Tab control
   ================================================================ */

/* ── Tab control ──────────────────────────────────────────────── */
.ehspi-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--color-border-tertiary, #e2e8f0);
}

.ehspi-tab {
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 400;
  color: var(--color-text-secondary, #64748b);
  border: none;
  background: transparent;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  margin-bottom: -1px;
}

.ehspi-tab:hover {
  color: var(--color-text-primary, #1e293b);
}

.ehspi-tab.active {
  font-weight: 500;
  color: var(--color-text-primary, #1e293b);
  border-bottom-color: #0D9488;
}

/* ── CRC block ────────────────────────────────────────────────── */
.crc-block {
  margin-bottom: 32px;
}

.crc-block-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: var(--color-background-secondary, #f8fafc);
  border-radius: 8px;
  margin-bottom: 12px;
  position: sticky;
  top: 0;
  z-index: 2;
}

.crc-icon  { font-size: 16px; flex-shrink: 0; }
.crc-title { font-weight: 500; font-size: 14px; color: var(--color-text-primary, #1e293b); }
.crc-subtitle {
  font-size: 12px;
  color: var(--color-text-secondary, #64748b);
  margin-left: 4px;
}

/* Canvas: allow dynamic height set via JS */
.crc-canvas {
  width: 100% !important;
  display: block;
}

/* ── ISS-58: Tooltip cursor for window-metric tiles with title attribute ── */
.window-metric[title] {
  cursor: help;
}

/* ═══════════════════════════════════════════════════════════════════
   WARM ORGANIC THEME — Component Overrides + Extensions
   vasus.ai brand redesign — appended below existing structural CSS
   ═══════════════════════════════════════════════════════════════════ */

/* ── Global body ────────────────────────────────────────────────── */
body {
  font-family: var(--font-family);
  background: var(--color-bg);
  color: var(--color-text);
}

/* ── Input view: hero ───────────────────────────────────────────── */
.input-content {
  background: linear-gradient(160deg, #F8F2ED 0%, #FDF8F4 60%, #F5EDE4 100%);
  min-height: 100vh;
}

.hero {
  padding: 48px 32px 32px;
  text-align: center;
}

.hero-logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 28px;
  gap: 6px;
}

.logo-img {
  width: auto;
  height: 52px;
  object-fit: contain;
}

.hero-tagline {
  font-size: 0.78rem;
  color: var(--color-text-light);
  font-style: italic;
  font-family: var(--font-family);
  margin: 0;
  letter-spacing: 0.02em;
}

.hero-title {
  font-family: var(--font-family-display);
  font-size: 2.4rem;
  font-weight: 600;
  color: var(--color-deep);
  line-height: 1.25;
  max-width: 600px;
  margin: 0 auto 14px;
  letter-spacing: -0.01em;
}

.hero-subtitle {
  font-size: 1rem;
  color: var(--color-text-muted);
  font-weight: 400;
  margin-bottom: 6px;
  font-family: var(--font-family);
}

.hero-disclaimer {
  font-size: 0.78rem;
  color: var(--color-text-light);
  font-style: italic;
  font-family: var(--font-family);
}

/* ── Sensitivity cards ──────────────────────────────────────────── */
.section-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: 16px;
  text-align: center;
}

.sensitivity-card {
  background: var(--color-bg-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 22px 16px;
  cursor: pointer;
  transition: border-color 0.18s, background 0.18s, transform 0.15s, box-shadow 0.18s;
  box-shadow: var(--shadow-card);
  text-align: center;
}

.sensitivity-card:hover {
  background: var(--color-bg-warm);
  border-color: var(--color-border-accent);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.sensitivity-card[data-selected="true"] {
  background: var(--color-primary-light);
  border-color: var(--color-primary);
  border-width: 2px;
  box-shadow: 0 0 0 3px rgba(187,73,102,0.12), var(--shadow-md);
}

.card-icon {
  display: block;
  font-size: 2rem;
  margin-bottom: 10px;
  transition: transform 0.18s;
}

.sensitivity-card:hover .card-icon {
  transform: scale(1.12);
}

.card-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
  font-family: var(--font-family);
}

.sensitivity-card[data-selected="true"] .card-title {
  color: var(--color-primary);
}

/* ── Submit / CTA button ────────────────────────────────────────── */
.submit-btn, .btn-primary {
  background: var(--color-primary);
  color: var(--color-text-on-primary);
  border: none;
  border-radius: var(--radius-sm);
  font-family: var(--font-family);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 14px 32px;
  cursor: pointer;
  transition: background 0.18s, transform 0.12s, box-shadow 0.18s;
  box-shadow: 0 4px 14px rgba(187,73,102,0.28);
}

.submit-btn:hover, .btn-primary:hover {
  background: var(--color-primary-hover);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(187,73,102,0.36);
}

.submit-btn:disabled {
  background: var(--color-border-accent);
  box-shadow: none;
  transform: none;
  cursor: not-allowed;
}

/* ── Results panels ─────────────────────────────────────────────── */
.panel-left {
  background: var(--color-bg-surface);
  border-right: 1px solid var(--color-border);
}

.panel-right {
  background: rgba(253,248,244,0.95);
}

.panel-header {
  border-bottom: 1px solid var(--color-border-light);
  padding-bottom: 14px;
  margin-bottom: 16px;
}

.panel-title {
  font-family: var(--font-family-display);
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--color-deep);
  line-height: 1.2;
}

.panel-meta {
  font-size: 0.78rem;
  color: var(--color-text-muted);
  margin-top: 6px;
  font-family: var(--font-family);
}

/* ── Section headers ────────────────────────────────────────────── */
.section-header h3 {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0;
  font-family: var(--font-family);
}

/* ── Back button ────────────────────────────────────────────────── */
.back-btn {
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-text-muted);
  font-size: 0.8rem;
  font-family: var(--font-family);
  padding: 6px 14px;
  cursor: pointer;
  margin-bottom: 16px;
  transition: border-color 0.15s, color 0.15s;
}

.back-btn:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

/* ── Floating cards ─────────────────────────────────────────────── */
.panel-section > div,
.relevance-card,
.trigger-risk-card {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
}

.trigger-risk-card[data-risk="minimal"] {
  border-left: 4px solid var(--color-risk-minimal);
  background: var(--color-risk-minimal-bg);
}

.trigger-risk-card[data-risk="moderate"] {
  border-left: 4px solid var(--color-risk-moderate);
  background: var(--color-risk-moderate-bg);
}

.trigger-risk-card[data-risk="high"] {
  border-left: 4px solid var(--color-risk-high);
  background: var(--color-risk-high-bg);
}

/* ── Window metric tiles ────────────────────────────────────────── */
.window-metric {
  background: var(--color-bg-elevated);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-light);
  border-left: 3px solid transparent;
  transition: border-color 0.2s;
}

.window-metric-value {
  font-family: var(--font-family);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-text);
}

.window-metric-label {
  font-size: 0.67rem;
  font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-family: var(--font-family);
}

.window-metric-sublabel {
  font-size: 0.7rem;
  color: var(--color-text-light);
  font-family: var(--font-family);
}

/* ── Evidence / citation cards ──────────────────────────────────── */
.evidence-card {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-sm);
}

.evidence-card:hover {
  border-color: var(--color-border-accent);
  background: var(--color-bg-warm);
}

.evidence-citation, .citation-ref {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--color-primary);
  background: var(--color-primary-light);
  border-radius: 4px;
  padding: 1px 6px;
}

/* ── Relevance paragraphs ───────────────────────────────────────── */
.relevance-para-mechanism,
.relevance-para-window {
  font-family: var(--font-family);
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.6;
}

/* ── EHSPI section ──────────────────────────────────────────────── */
.ehspi-score-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--color-primary-light);
  border: 1px solid var(--color-border-accent);
  border-radius: var(--radius-sm);
  padding: 6px 14px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-primary);
  font-family: var(--font-family);
}

/* ── EHSPI tabs ─────────────────────────────────────────────────── */
.ehspi-tab {
  font-family: var(--font-family);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.ehspi-tab.active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}

/* ── Alert bar warm organic ─────────────────────────────────────── */
.alert-bar {
  background: var(--color-bg-warm);
  border-top: 1px solid var(--color-border);
}

.alert-bar-btn {
  background: var(--color-primary);
  box-shadow: 0 2px 8px rgba(187,73,102,0.25);
  font-family: var(--font-family);
}

.alert-bar-btn:hover {
  background: var(--color-primary-hover);
}

.alert-bell-active, .alert-bell-icon.alert-bell-active {
  color: var(--color-primary);
}

.alert-bar-active-dot {
  background: var(--color-primary);
}

/* ── Enrichment panel ───────────────────────────────────────────── */
.enrichment-section {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.enrichment-toggle {
  background: transparent;
  border: none;
  font-family: var(--font-family);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text-muted);
}

.enrichment-toggle:hover {
  background: var(--color-bg-warm);
}

.enrichment-toggle-icon {
  color: var(--color-primary);
}

/* ── Loading overlay ────────────────────────────────────────────── */
#loading-overlay {
  background: var(--color-bg);
}

.loading-spinner {
  border-color: var(--color-border);
  border-top-color: var(--color-primary);
}

.loading-text {
  color: var(--color-text-muted);
  font-family: var(--font-family);
}

/* ── Warm scrollbars ────────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--color-bg); }
::-webkit-scrollbar-thumb {
  background: var(--color-border-accent);
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover { background: var(--color-primary); }

/* ── Pollutant detail ───────────────────────────────────────────── */
.pdt-value {
  font-family: var(--font-family-mono);
  font-weight: 700;
  color: var(--color-text);
}

/* ── Risk metric strip chips ────────────────────────────────────── */
.risk-chip {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  font-family: var(--font-family);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-text-muted);
}

/* ── Environment signal list ────────────────────────────────────── */
.env-signal-icon.up    { color: var(--color-risk-high); }
.env-signal-icon.down  { color: var(--color-risk-moderate); }
.env-signal-icon.neutral { color: var(--color-text-muted); }

/* ── Alert modal ────────────────────────────────────────────────── */
.alert-modal {
  background: var(--color-bg-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
  font-family: var(--font-family);
}

.alert-modal-title {
  font-family: var(--font-family-display);
  color: var(--color-deep);
}

/* ── Typography: font-loaded class ─────────────────────────────── */
body.font-loaded .hero-title,
body.font-loaded .panel-title,
body.font-loaded .alert-modal-title {
  font-family: var(--font-family-display);
}

/* ── Input fields warm organic ──────────────────────────────────── */
input[type="text"],
input[type="number"],
select,
textarea {
  font-family: var(--font-family);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  border-radius: var(--radius-sm);
}

input[type="text"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(187,73,102,0.12);
}

/* ── Location search input ──────────────────────────────────────── */
.location-input,
#location-input {
  background: var(--color-bg-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-family);
  color: var(--color-text);
}

.location-input:focus,
#location-input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(187,73,102,0.10);
}

/* ── Autocomplete dropdown ──────────────────────────────────────── */
.autocomplete-dropdown,
.suggestions-list {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md);
}

.autocomplete-item:hover,
.suggestion-item:hover {
  background: var(--color-bg-warm);
  color: var(--color-primary);
}


/* ═══════════════════════════════════════════════════════════════════
   WARM ORGANIC — Results Layout Overrides
   Replaces floating-on-fullscreen-map with card-based 2-column layout
   ═══════════════════════════════════════════════════════════════════ */

[data-theme="warm-organic"] .results-view {
  position: static !important;
  width: 100% !important;
  height: auto !important;
  min-height: 100vh;
  overflow: visible !important;
  overflow-y: auto !important;
  background: var(--color-bg);
  padding: 16px 20px 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-sizing: border-box;
}

/* ── Top bar: logo left, back button right ──────────────────────── */
[data-theme="warm-organic"] .results-top-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 0 8px;
  border-bottom: 1px solid var(--color-border-light);
  margin-bottom: 2px;
}

[data-theme="warm-organic"] .results-logo {
  display: flex;
  align-items: center;
}

[data-theme="warm-organic"] .logo-img-sm {
  height: 36px;
  width: auto;
}

/* ── Two-column wrapper ─────────────────────────────────────────── */
[data-theme="warm-organic"] .results-columns {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  flex: 1;
}

/* ── Panel-left: LEFT column (wider — title, risk, map, metrics) ── */
[data-theme="warm-organic"] .panel-left {
  position: static !important;
  top: auto !important;
  left: auto !important;
  bottom: auto !important;
  flex: 0 0 56%;
  width: 56% !important;
  max-height: none !important;
  height: auto !important;
  border-radius: var(--radius-lg);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-card);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: visible !important;
  opacity: 1 !important;
  visibility: visible !important;
  animation: none !important;
}

/* ── Panel-right: RIGHT column (evidence + relevance) ───────────── */
[data-theme="warm-organic"] .panel-right {
  position: static !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  flex: 0 0 calc(44% - 16px);
  width: calc(44% - 16px) !important;
  max-height: none !important;
  height: auto !important;
  border-radius: var(--radius-lg);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-card);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: visible !important;
  opacity: 1 !important;
  visibility: visible !important;
  animation: none !important;
}

/* Hide connector arrow — not needed in card layout */
[data-theme="warm-organic"] .panel-right::before {
  display: none !important;
}

/* ── Map: contained block, not fullscreen ───────────────────────── */
[data-theme="warm-organic"] #map,
[data-theme="warm-organic"] .map-contained {
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  z-index: 1 !important;
  height: 260px !important;
  width: 100% !important;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: #2a2a2a;
  flex-shrink: 0;
}

/* ── Panel sections in new layout: no extra padding/border ──────── */
[data-theme="warm-organic"] .panel-left .panel-section,
[data-theme="warm-organic"] .panel-right .panel-section {
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  box-shadow: none;
}

[data-theme="warm-organic"] .panel-left .panel-section + .panel-section,
[data-theme="warm-organic"] .panel-right .panel-section + .panel-section {
  border-top: 1px solid var(--color-border-light);
  padding-top: 12px;
  margin-top: 4px;
}

/* ── Risk + recommendations cards: warm organic surface ─────────── */
[data-theme="warm-organic"] .trigger-risk-card,
[data-theme="warm-organic"] .recommendations-card,
[data-theme="warm-organic"] .env-card,
[data-theme="warm-organic"] .feedback-card {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  box-shadow: none;
}

[data-theme="warm-organic"] .trigger-risk-card[data-risk="moderate"] {
  border-left: 4px solid var(--color-risk-moderate);
  background: var(--color-risk-moderate-bg);
}
[data-theme="warm-organic"] .trigger-risk-card[data-risk="high"] {
  border-left: 4px solid var(--color-risk-high);
  background: var(--color-risk-high-bg);
}
[data-theme="warm-organic"] .trigger-risk-card[data-risk="minimal"] {
  border-left: 4px solid var(--color-risk-minimal);
  background: var(--color-risk-minimal-bg);
}

/* ── Pulse animations: use warm rose glows ──────────────────────── */
[data-theme="warm-organic"] .trigger-risk-card[data-risk="minimal"].pulsing {
  animation: warmPulseMinimal 2.5s ease-in-out infinite;
}
[data-theme="warm-organic"] .trigger-risk-card[data-risk="moderate"].pulsing {
  animation: warmPulseModerate 2.5s ease-in-out infinite;
}
[data-theme="warm-organic"] .trigger-risk-card[data-risk="high"].pulsing {
  animation: warmPulseHigh 2.5s ease-in-out infinite;
}

@keyframes warmPulseMinimal {
  0%, 100% { box-shadow: 0 0 0 0 rgba(45,138,85,0); }
  50% { box-shadow: 0 0 12px 3px rgba(45,138,85,0.2); }
}
@keyframes warmPulseModerate {
  0%, 100% { box-shadow: 0 0 0 0 rgba(200,118,10,0); }
  50% { box-shadow: 0 0 12px 3px rgba(200,118,10,0.2); }
}
@keyframes warmPulseHigh {
  0%, 100% { box-shadow: 0 0 0 0 rgba(197,48,48,0); }
  50% { box-shadow: 0 0 12px 3px rgba(197,48,48,0.2); }
}

/* ── Panel header in new layout ─────────────────────────────────── */
[data-theme="warm-organic"] .panel-header {
  margin: 0;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--color-border-light);
}

/* ── Relevance card in right panel ─────────────────────────────── */
[data-theme="warm-organic"] .relevance-card {
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
}

/* ── Alert bar within card layout: inline, not sticky ───────────── */
[data-theme="warm-organic"] .alert-bar {
  position: static !important;
  bottom: auto !important;
  z-index: auto !important;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  flex-shrink: 0;
  margin-top: 0;
}

/* ── Responsive: stack columns below 900px ──────────────────────── */
@media (max-width: 900px) {
  [data-theme="warm-organic"] .results-columns {
    flex-direction: column;
  }
  [data-theme="warm-organic"] .panel-left,
  [data-theme="warm-organic"] .panel-right {
    flex: none;
    width: 100% !important;
  }
}


/* ═══════════════════════════════════════════════════════════════════
   WARM ORGANIC — Full Layout Redesign (screenshot 1/2/3/5 target)
   ═══════════════════════════════════════════════════════════════════ */

/* ── Results view: full parchment canvas ────────────────────────── */
[data-theme="warm-organic"] .results-view {
  position: static !important;
  width: 100%; height: auto !important; min-height: 100vh;
  overflow: visible !important; overflow-y: auto !important;
  background: var(--color-bg);
  padding: 0 0 32px;
  display: flex; flex-direction: column; gap: 0;
  box-sizing: border-box;
}

/* ── Top bar ────────────────────────────────────────────────────── */
[data-theme="warm-organic"] .results-top-bar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 24px;
  background: var(--color-bg-surface);
  border-bottom: 1px solid var(--color-border);
}
[data-theme="warm-organic"] .results-logo { display: flex; align-items: center; }
[data-theme="warm-organic"] .logo-img-sm { height: 32px; width: auto; }

/* ── Full-width title row ───────────────────────────────────────── */
[data-theme="warm-organic"] .results-title-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 24px 12px;
  background: var(--color-bg-surface);
  border-bottom: 1px solid var(--color-border-light);
  gap: 16px;
}
[data-theme="warm-organic"] .results-title-left { flex: 1; }
[data-theme="warm-organic"] .results-title-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
[data-theme="warm-organic"] .panel-title {
  font-family: var(--font-family-display);
  font-size: 1.5rem; font-weight: 600;
  color: var(--color-deep); margin: 0 0 6px;
}
[data-theme="warm-organic"] .panel-meta {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
[data-theme="warm-organic"] .meta-pill {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: 20px;
  padding: 3px 10px;
  font-size: 0.78rem; color: var(--color-text-muted);
  font-family: var(--font-family);
}

/* ── Alert status panel (full width under title row) ────────────── */
[data-theme="warm-organic"] .alert-status-panel {
  margin: 0 24px 0; border-radius: var(--radius-sm);
}

/* ── Two-column wrapper ─────────────────────────────────────────── */
[data-theme="warm-organic"] .results-columns {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 16px 24px 0; flex: 1;
}

/* ── Panel-left: LEFT column ───────────────────────────────────── */
[data-theme="warm-organic"] .panel-left {
  position: static !important; top: auto !important;
  left: auto !important; bottom: auto !important;
  flex: 0 0 60%; width: 60% !important;
  max-height: none !important; height: auto !important;
  background: transparent; border: none; box-shadow: none; padding: 0;
  display: flex; flex-direction: column; gap: 12px;
  overflow: visible !important;
  opacity: 1 !important; visibility: visible !important; animation: none !important;
}

/* ── Panel-right: RIGHT column ─────────────────────────────────── */
[data-theme="warm-organic"] .panel-right {
  position: static !important; top: auto !important;
  left: auto !important; right: auto !important;
  flex: 0 0 calc(40% - 16px); width: calc(40% - 16px) !important;
  max-height: none !important; height: auto !important;
  background: transparent; border: none; box-shadow: none; padding: 0;
  display: flex; flex-direction: column; gap: 12px;
  overflow: visible !important;
  opacity: 1 !important; visibility: visible !important; animation: none !important;
}
[data-theme="warm-organic"] .panel-right::before { display: none !important; }

/* ── Sections in right panel ────────────────────────────────────── */
[data-theme="warm-organic"] .rp-section {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 16px;
  box-shadow: var(--shadow-card);
  margin: 0;
}
[data-theme="warm-organic"] .rp-section .section-header { margin-bottom: 10px; }
[data-theme="warm-organic"] .rp-section .relevance-card {
  background: transparent; border: none; box-shadow: none; padding: 0;
}

/* ── Risk + Recommendations: side by side ────────────────────────── */
[data-theme="warm-organic"] .risk-recs-row {
  display: flex; gap: 12px; align-items: stretch;
}
[data-theme="warm-organic"] .risk-recs-row .trigger-risk-card { flex: 0 0 45%; }
[data-theme="warm-organic"] .risk-recs-row .recommendations-card { flex: 1; }
[data-theme="warm-organic"] .trigger-risk-card,
[data-theme="warm-organic"] .recommendations-card {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  box-shadow: var(--shadow-card);
  margin: 0;
}
[data-theme="warm-organic"] .trigger-risk-card[data-risk="moderate"] {
  border-left: 4px solid var(--color-risk-moderate);
  background: var(--color-risk-moderate-bg);
}
[data-theme="warm-organic"] .trigger-risk-card[data-risk="high"] {
  border-left: 4px solid var(--color-risk-high); background: var(--color-risk-high-bg);
}
[data-theme="warm-organic"] .trigger-risk-card[data-risk="minimal"] {
  border-left: 4px solid var(--color-risk-minimal); background: var(--color-risk-minimal-bg);
}
[data-theme="warm-organic"] .trigger-risk-card[data-risk="moderate"].pulsing {
  animation: warmPulseModerate 2.5s ease-in-out infinite;
}
[data-theme="warm-organic"] .trigger-risk-card[data-risk="high"].pulsing {
  animation: warmPulseHigh 2.5s ease-in-out infinite;
}
[data-theme="warm-organic"] .trigger-risk-card[data-risk="minimal"].pulsing {
  animation: warmPulseMinimal 2.5s ease-in-out infinite;
}

/* ── Map wrapper + B&W satellite + exposure overlay ──────────────── */
[data-theme="warm-organic"] .map-wrapper {
  position: relative; border-radius: var(--radius-md);
  overflow: hidden; flex-shrink: 0;
}
[data-theme="warm-organic"] #map,
[data-theme="warm-organic"] .map-contained {
  position: relative !important; top: auto !important;
  left: auto !important; right: auto !important; bottom: auto !important;
  z-index: 1 !important;
  height: 280px !important; width: 100% !important;
  border-radius: 0; background: #2a2a2a;
  /* B&W satellite effect */
  filter: grayscale(1) contrast(1.05);
}
[data-theme="warm-organic"] .map-overlay-summary {
  position: absolute !important; bottom: 12px; left: 12px;
  z-index: 20; margin: 0 !important; padding: 0 !important;
  background: rgba(253,248,244,0.92);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  backdrop-filter: blur(4px);
  max-width: 280px;
}
[data-theme="warm-organic"] .map-overlay-label {
  font-size: 0.6rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--color-text-muted);
  padding: 6px 10px 2px; font-family: var(--font-family);
}
[data-theme="warm-organic"] .map-overlay-summary .window-summary-grid {
  padding: 4px 8px 8px; display: flex; flex-wrap: wrap; gap: 6px;
}
[data-theme="warm-organic"] .map-overlay-summary .window-metric {
  min-width: 80px; padding: 6px 8px; font-size: 0.75rem;
  border-radius: 6px; background: var(--color-bg-elevated);
}
[data-theme="warm-organic"] .map-overlay-summary .window-metric-value {
  font-size: 0.95rem; font-weight: 700;
}
[data-theme="warm-organic"] .map-overlay-summary .window-metric-label {
  font-size: 0.58rem;
}

/* ── Environment card ────────────────────────────────────────────── */
[data-theme="warm-organic"] .env-card {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  box-shadow: var(--shadow-card);
  margin: 0;
}
[data-theme="warm-organic"] #pollutant-detail-toggle { display: none !important; }

/* ── Alert bar: inline, not sticky ─────────────────────────────── */
[data-theme="warm-organic"] .alert-bar {
  position: static !important; bottom: auto !important;
  background: var(--color-bg-warm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}

/* ── Pollutant tiles grid ────────────────────────────────────────── */
[data-theme="warm-organic"] .pollutant-tiles-section {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  box-shadow: var(--shadow-card);
}
[data-theme="warm-organic"] .pollutant-tiles-section .section-header { margin-bottom: 12px; }
[data-theme="warm-organic"] .pollutant-tiles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
[data-theme="warm-organic"] .pdc-tile {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  display: flex; flex-direction: column; gap: 3px;
}
[data-theme="warm-organic"] .pdc-name {
  font-size: 0.82rem; font-weight: 700; color: var(--color-text);
  font-family: var(--font-family);
}
[data-theme="warm-organic"] .pdc-sub {
  font-size: 0.68rem; color: var(--color-text-light);
  font-family: var(--font-family); line-height: 1.2;
}
[data-theme="warm-organic"] .pdc-value-row {
  display: flex; align-items: baseline; gap: 4px; margin-top: 4px;
}
[data-theme="warm-organic"] .pdc-value {
  font-size: 1.2rem; font-weight: 700; color: var(--color-text);
  font-family: var(--font-family);
}
[data-theme="warm-organic"] .pdc-unit {
  font-size: 0.68rem; color: var(--color-text-muted);
  font-family: var(--font-family);
}
[data-theme="warm-organic"] .pdc-tile.pdc-warn .pdc-value { color: var(--color-risk-moderate); }
[data-theme="warm-organic"] .pdc-tile.pdc-bad .pdc-value { color: var(--color-risk-high); }
[data-theme="warm-organic"] .pdc-tile.pdc-ok .pdc-value { color: var(--color-risk-minimal); }
[data-theme="warm-organic"] .pdc-bar {
  height: 3px; background: var(--color-border-light);
  border-radius: 2px; margin-top: 6px; overflow: hidden;
}
[data-theme="warm-organic"] .pdc-bar-fill {
  height: 100%; border-radius: 2px; transition: width 0.4s ease;
}

/* ── EHSPI: side by side mini cards ─────────────────────────────── */
[data-theme="warm-organic"] .ehspi-section {
  background: transparent; border: none; padding: 0; box-shadow: none;
}
[data-theme="warm-organic"] .ehspi-section .section-header { margin-bottom: 4px; }
[data-theme="warm-organic"] .ehspi-intro {
  font-size: 0.75rem; color: var(--color-text-muted);
  margin-bottom: 10px; line-height: 1.4;
}
[data-theme="warm-organic"] .ehspi-side-row {
  display: flex; gap: 12px; align-items: flex-start;
}
[data-theme="warm-organic"] .ehspi-mini-card {
  flex: 1; background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  box-shadow: var(--shadow-card);
  display: block !important; /* always visible */
  overflow: hidden;
}
[data-theme="warm-organic"] .ehspi-mini-label {
  font-size: 0.62rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--color-text-muted);
  margin-bottom: 8px; font-family: var(--font-family);
}
/* Override JS display:none on ehspi wraps */
[data-theme="warm-organic"] #ehspi-radar-wrap { display: block !important; }
[data-theme="warm-organic"] #ehspi-crc-wrap   { display: block !important; }
/* CRC canvas fits within its mini-card */
[data-theme="warm-organic"] .crc-canvas { max-width: 100%; }
[data-theme="warm-organic"] .crc-block-header { margin-bottom: 4px; }
[data-theme="warm-organic"] .crc-title { font-size: 0.65rem; }
[data-theme="warm-organic"] .crc-subtitle { font-size: 0.62rem; display: none; }

/* ── Uncertainty / caveats chips ─────────────────────────────────── */
[data-theme="warm-organic"] .uncertainty-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 8px;
}
[data-theme="warm-organic"] .uncertainty-list li {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
  font-size: 0.8rem; color: var(--color-text);
  line-height: 1.4;
  flex: 0 0 calc(50% - 4px);
}
@media (max-width: 1100px) {
  [data-theme="warm-organic"] .uncertainty-list li { flex: 0 0 100%; }
}

/* ── Evidence cards: full list visible ──────────────────────────── */
[data-theme="warm-organic"] .evidence-list { display: flex; flex-direction: column; gap: 8px; }
[data-theme="warm-organic"] #evidence-more-cards { display: block !important; }
[data-theme="warm-organic"] #evidence-toggle-btn { display: none !important; }

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 960px) {
  [data-theme="warm-organic"] .results-columns { flex-direction: column; padding: 12px 16px 0; }
  [data-theme="warm-organic"] .panel-left,
  [data-theme="warm-organic"] .panel-right { flex: none; width: 100% !important; }
  [data-theme="warm-organic"] .risk-recs-row { flex-direction: column; }
  [data-theme="warm-organic"] .ehspi-side-row { flex-direction: column; }
  [data-theme="warm-organic"] .pollutant-tiles-grid { grid-template-columns: repeat(2, 1fr); }
  [data-theme="warm-organic"] .results-top-bar,
  [data-theme="warm-organic"] .results-title-row { padding: 10px 16px; }
}
@media (max-width: 480px) {
  [data-theme="warm-organic"] .pollutant-tiles-grid { grid-template-columns: 1fr 1fr; }
  [data-theme="warm-organic"] .panel-title { font-size: 1.2rem; }
}


/* ═══════════════════════════════════════════════════════════════════
   LAYOUT FIXES — Below-map columns + Map height + EHSPI rendering
   ═══════════════════════════════════════════════════════════════════ */

/* ── Map height: 330px (+50px) ──────────────────────────────────── */
[data-theme="warm-organic"] #map,
[data-theme="warm-organic"] .map-contained {
  height: 330px !important;
}

/* ── Below-map row: env+AQ left | EHSPI right ───────────────────── */
[data-theme="warm-organic"] .below-map-row {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
[data-theme="warm-organic"] .below-map-right {
  width: 100% !important;
  flex: none !important;
  order: 1;
}
[data-theme="warm-organic"] .below-map-left {
  width: 100% !important;
  flex: none !important;
  order: 2;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* ── Env card in below-map-left: full width ─────────────────────── */
[data-theme="warm-organic"] .below-map-left .env-card {
  width: 100%;
}

/* ── Pollutant tiles in narrower left column: 2-col grid ────────── */
[data-theme="warm-organic"] .below-map-left .pollutant-tiles-grid {
  grid-template-columns: repeat(2, 1fr);
}

/* ── EHSPI in below-map-right ───────────────────────────────────── */
[data-theme="warm-organic"] .below-map-right .ehspi-section {
  height: 100%;
}

/* ── EHSPI mini-cards: fix overflow clipping the charts ─────────── */
[data-theme="warm-organic"] .ehspi-mini-card {
  overflow: visible !important; /* was hidden — was clipping radar + CRC */
  min-height: 200px;
}
/* CRC wrap: scrollable since it can be tall (22 cities × 34px) */
[data-theme="warm-organic"] #ehspi-crc-wrap.ehspi-mini-card {
  overflow-y: auto !important;
  max-height: 600px;
}

/* ── EHSPI side-row: full height within below-map-right ─────────── */
[data-theme="warm-organic"] .ehspi-side-row {
  align-items: flex-start;
}

/* ── Score bar chart: responsive in warm-organic layout ─────────── */
[data-theme="warm-organic"] #ehspi-score-bar-wrap {
  max-width: 100%;
}
[data-theme="warm-organic"] .ehspi-bar-track {
  height: 8px;
}

/* ── CRC canvas: constrain width, allow height ──────────────────── */
[data-theme="warm-organic"] .crc-canvas {
  width: 100% !important;
  height: auto !important;
}
[data-theme="warm-organic"] .crc-block {
  margin-bottom: 12px;
}

/* ── Responsive: stack below-map-row on smaller screens ─────────── */
@media (max-width: 1100px) {
  [data-theme="warm-organic"] .below-map-row {
    flex-direction: column;
  }
  [data-theme="warm-organic"] .below-map-left,
  [data-theme="warm-organic"] .below-map-right {
    flex: none;
    width: 100%;
  }
  [data-theme="warm-organic"] .below-map-left .pollutant-tiles-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  [data-theme="warm-organic"] .ehspi-side-row {
    flex-direction: row; /* keep side by side even stacked */
  }
}
@media (max-width: 700px) {
  [data-theme="warm-organic"] .below-map-left .pollutant-tiles-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  [data-theme="warm-organic"] .ehspi-side-row {
    flex-direction: column;
  }
}


/* ═══════════════════════════════════════════════════════════════════
   ITERATION FIXES: title inline · map height · 3×3 grid ·
   combined metrics · EHSPI height match
   ═══════════════════════════════════════════════════════════════════ */

/* ── 1. Title row: title + meta on same single line ─────────────── */
[data-theme="warm-organic"] .results-title-row {
  padding: 10px 24px !important;
}
[data-theme="warm-organic"] .results-title-left {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 14px;
  flex-wrap: wrap;
}
[data-theme="warm-organic"] .panel-title {
  font-size: 1.3rem !important;
  margin: 0 !important;
  white-space: nowrap;
}
[data-theme="warm-organic"] .panel-meta {
  margin: 0 !important;
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}

/* ── 2. Map height: 420px (was 330px) ───────────────────────────── */
[data-theme="warm-organic"] #map,
[data-theme="warm-organic"] .map-contained {
  height: 420px !important;
}

/* ── 2b. Exposure overlay: strict 3-col grid, wider, compact tiles ─ */
[data-theme="warm-organic"] .map-overlay-summary {
  max-width: 400px !important;
  left: 10px; bottom: 10px;
}
[data-theme="warm-organic"] .map-overlay-summary .window-summary-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 5px !important;
  padding: 4px 8px 8px !important;
}
[data-theme="warm-organic"] .map-overlay-summary .window-metric {
  min-width: 0 !important;
  padding: 5px 7px !important;
}
[data-theme="warm-organic"] .map-overlay-summary .window-metric-value {
  font-size: 0.88rem !important;
}
[data-theme="warm-organic"] .map-overlay-summary .window-metric-label {
  font-size: 0.56rem !important;
  letter-spacing: 0.04em;
}
[data-theme="warm-organic"] .map-overlay-summary .window-metric-sublabel {
  font-size: 0.6rem !important;
}

/* ── 3 & 4. Combined env + AQ section: one unified card ─────────── */
[data-theme="warm-organic"] .combined-env-metrics {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

/* Env card: remove its own card styling — it's now part of combined */
[data-theme="warm-organic"] .combined-env-metrics .env-card {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 14px 16px 10px !important;
  margin: 0 !important;
}

/* Divider between env signals and AQ tiles */
[data-theme="warm-organic"] .combined-env-metrics .pollutant-tiles-section {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 16px 14px !important;
  margin: 0 !important;
  border-top: 1px solid var(--color-border-light) !important;
}
[data-theme="warm-organic"] .combined-env-metrics .pollutant-tiles-section .section-header {
  padding: 10px 0 8px;
  margin-bottom: 8px !important;
}

/* ── Env signal items: tile style, NO icons ──────────────────────── */
[data-theme="warm-organic"] .env-signal-icon { display: none !important; }

[data-theme="warm-organic"] .env-items {
  list-style: none !important;
  padding: 0 !important; margin: 0 !important;
  display: flex; flex-direction: column; gap: 6px;
}

[data-theme="warm-organic"] .env-signal-item {
  display: block !important;
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-light) !important;
  border-radius: var(--radius-sm) !important;
  padding: 8px 12px !important;
  font-size: 0.82rem !important;
  color: var(--color-text) !important;
  line-height: 1.4;
  gap: 0 !important;
}
[data-theme="warm-organic"] .env-signal-item:last-child { border-bottom: 1px solid var(--color-border-light) !important; }

[data-theme="warm-organic"] .env-signal-text { font-size: 0.82rem; }
[data-theme="warm-organic"] .env-signal-text strong {
  font-weight: 600;
  color: var(--color-text);
}

/* ── AQ tiles: single column (matching env item width) ───────────── */
[data-theme="warm-organic"] .combined-env-metrics .pollutant-tiles-grid {
  grid-template-columns: 1fr 1fr !important; /* 2 cols like screenshot 5 */
  gap: 8px !important;
}

/* Keep AQ tile style from screenshot 5 */
[data-theme="warm-organic"] .combined-env-metrics .pdc-tile {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-sm);
}

/* ── Env card header: keep it clean ─────────────────────────────── */
[data-theme="warm-organic"] .combined-env-metrics .env-header h3 {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
[data-theme="warm-organic"] .combined-env-metrics .env-icon { font-size: 0.9rem; }

/* ── 5. EHSPI height matches combined metrics column ────────────── */
[data-theme="warm-organic"] .below-map-row {
  align-items: stretch !important; /* both columns same height */
}
[data-theme="warm-organic"] .below-map-left {
  display: flex; flex-direction: column;
}
[data-theme="warm-organic"] .combined-env-metrics {
  flex: 1; /* fill available height */
  display: flex; flex-direction: column;
}
[data-theme="warm-organic"] .combined-env-metrics .env-card {
  flex-shrink: 0;
}
[data-theme="warm-organic"] .combined-env-metrics .pollutant-tiles-section {
  flex: 1;
}
[data-theme="warm-organic"] .below-map-right {
  display: flex; flex-direction: column;
}
[data-theme="warm-organic"] .below-map-right .ehspi-section {
  flex: 1;
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  padding: 16px;
  display: flex; flex-direction: column;
}
[data-theme="warm-organic"] .below-map-right .ehspi-section .ehspi-side-row {
  flex: 1; align-items: stretch;
}
[data-theme="warm-organic"] .below-map-right .ehspi-mini-card {
  display: flex !important;
  flex-direction: column;
}
[data-theme="warm-organic"] .below-map-right #ehspi-radar-wrap { flex: 0 0 40%; }
[data-theme="warm-organic"] .below-map-right #ehspi-crc-wrap {
  flex: 1;
  overflow-y: auto !important;
}

/* Remove any duplicate gap between env-card and pollutant section */
[data-theme="warm-organic"] .below-map-left { gap: 12px; }

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  [data-theme="warm-organic"] .combined-env-metrics .pollutant-tiles-grid {
    grid-template-columns: 1fr 1fr !important;
  }
}
@media (max-width: 700px) {
  [data-theme="warm-organic"] .results-title-left { flex-direction: column !important; gap: 4px; }
  [data-theme="warm-organic"] .panel-title { white-space: normal; }
}


/* ═══════════════════════════════════════════════════════════════════
   FIX: CRC bars · combined env tile rendering · section header
   ═══════════════════════════════════════════════════════════════════ */

/* ── CRC canvas: NEVER override JS-set height ───────────────────── */
[data-theme="warm-organic"] .crc-canvas {
  width: 100% !important;
  height: auto;       /* no !important — lets JS ctx.height take effect */
  display: block;
}

/* ── Widen below-map columns: more room for EHSPI charts ─────────── */
[data-theme="warm-organic"] .below-map-left  { flex: 0 0 38% !important; }
[data-theme="warm-organic"] .below-map-right { flex: 0 0 calc(62% - 12px) !important; }

/* ── Env tiles grid: 2-col layout matching AQ tiles ─────────────── */
[data-theme="warm-organic"] .env-tiles-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* ── Each env tile: identical look to pdc-tile ──────────────────── */
[data-theme="warm-organic"] .env-signal-item {
  display: block !important;
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-light) !important;
  border-radius: var(--radius-sm) !important;
  padding: 10px 12px !important;
  gap: 0 !important;
}

[data-theme="warm-organic"] .env-tile-name {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-text);
  font-family: var(--font-family);
  margin-bottom: 3px;
  line-height: 1.2;
}

[data-theme="warm-organic"] .env-tile-desc {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  font-family: var(--font-family);
  line-height: 1.35;
}

/* ── Hide "Air quality details" section header — seamless flow ───── */
[data-theme="warm-organic"] .combined-env-metrics .pollutant-tiles-section .section-header {
  display: none !important;
}

/* Remove border-top between env and AQ when both use tile style */
[data-theme="warm-organic"] .combined-env-metrics .pollutant-tiles-section {
  border-top: none !important;
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Small gap between env tiles and AQ tiles (natural section break) */
[data-theme="warm-organic"] .combined-env-metrics .env-card {
  padding-bottom: 14px !important;
}
[data-theme="warm-organic"] .combined-env-metrics .pollutant-tiles-section {
  padding-top: 8px !important;
}
/* Thin divider between env signals and AQ tiles */
[data-theme="warm-organic"] .combined-env-metrics .env-card {
  border-bottom: 1px solid var(--color-border-light) !important;
}

/* ── Ensure AQ tiles match env tile height/style ────────────────── */
[data-theme="warm-organic"] .combined-env-metrics .pdc-tile {
  min-height: 72px;
}

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  [data-theme="warm-organic"] .env-tiles-grid {
    grid-template-columns: 1fr 1fr !important;
  }
  [data-theme="warm-organic"] .below-map-left  { flex: 0 0 45% !important; }
  [data-theme="warm-organic"] .below-map-right { flex: 0 0 calc(55% - 12px) !important; }
}
@media (max-width: 700px) {
  [data-theme="warm-organic"] .env-tiles-grid  { grid-template-columns: 1fr !important; }
  [data-theme="warm-organic"] .below-map-left,
  [data-theme="warm-organic"] .below-map-right { flex: none !important; width: 100% !important; }
}


/* ═══════════════════════════════════════════════════════════════════
   CRC CHART FINAL FIX — all cities in one view, no scroll, clean bars
   ═══════════════════════════════════════════════════════════════════ */

/* Override ALL previous overflow settings on CRC wrap */
[data-theme="warm-organic"] #ehspi-crc-wrap,
[data-theme="warm-organic"] #ehspi-crc-wrap.ehspi-mini-card,
[data-theme="warm-organic"] .below-map-right #ehspi-crc-wrap {
  overflow: hidden !important;         /* no scroll — chart fills the card */
  overflow-y: hidden !important;
  display: flex !important;
  flex-direction: column;
  flex: 1;
}

/* CRC block: fill available space, give canvas the height */
[data-theme="warm-organic"] #ehspi-crc-wrap .crc-block {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  margin-bottom: 0;
}

/* Canvas fills the crc-block — Chart.js will then scale all 22 cities into it */
[data-theme="warm-organic"] #ehspi-crc-wrap .crc-canvas {
  flex: 1;
  width: 100% !important;
  height: 100% !important;   /* fill available — Chart.js respects this with responsive:true */
  display: block;
  min-height: 300px;          /* minimum so chart is readable */
}

/* The EHSPI right mini-card must grow to fill below-map-right */
[data-theme="warm-organic"] .below-map-right {
  display: flex;
  flex-direction: column;
  min-height: 0;
}
[data-theme="warm-organic"] .below-map-right .ehspi-section {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
[data-theme="warm-organic"] .ehspi-side-row {
  flex: 1;
  min-height: 0;
  align-items: stretch;
}
[data-theme="warm-organic"] .ehspi-mini-card {
  min-height: 0;
}

/* Ensure radar mini-card doesn't fight for all the height */
[data-theme="warm-organic"] #ehspi-radar-wrap {
  flex: 0 0 42%;
  overflow: hidden;
}


/* Radar restored — both mini-cards visible ④ */
[data-theme="warm-organic"] #ehspi-radar-wrap {
  display: block !important;
  flex: 0 0 38% !important;
}
[data-theme="warm-organic"] #ehspi-crc-wrap {
  flex: 1 1 0% !important;
  width: auto !important;
}


/* ═══════════════════════════════════════════════════════════════════
   REQ-15: Feedback bar + modal — bolt-on block
   Remove this entire section to disable the feedback feature
   ═══════════════════════════════════════════════════════════════════ */

/* ── Feedback bar (in panel-right) ──────────────────────────────── */
.feedback-bar-section { padding: 12px 16px !important; }
.feedback-bar-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.feedback-question {
  font-size: 0.82rem;
  color: var(--color-text-muted, #888);
  font-family: var(--font-family, sans-serif);
  flex-shrink: 0;
}
.feedback-thumbs { display: flex; gap: 6px; }
.feedback-thumb-btn {
  background: var(--color-bg-elevated, #F4EDE7);
  border: 1px solid var(--color-border, #ddd);
  border-radius: 8px;
  padding: 4px 10px;
  font-size: 1rem;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  line-height: 1.5;
}
.feedback-thumb-btn:hover { border-color: var(--color-primary, #BB4966); }
.feedback-thumb-btn[data-selected="true"] {
  background: var(--color-primary, #BB4966);
  border-color: var(--color-primary, #BB4966);
  filter: brightness(1.05);
}
.feedback-bar-status {
  font-size: 0.75rem;
  color: var(--color-text-muted, #888);
  font-family: var(--font-family, sans-serif);
  flex: 1;
  text-align: right;
}

/* ── Modal overlay ───────────────────────────────────────────────── */
.feedback-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  backdrop-filter: blur(2px);
}

/* ── Modal card ──────────────────────────────────────────────────── */
.feedback-modal-card {
  background: var(--color-bg-surface, #FDFAF7);
  border: 1px solid var(--color-border, #ddd);
  border-radius: 16px;
  padding: 28px 28px 20px;
  width: 100%;
  max-width: 480px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.18);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.feedback-modal-close {
  position: absolute;
  top: 14px; right: 16px;
  background: none; border: none;
  font-size: 1.3rem; color: var(--color-text-muted, #888);
  cursor: pointer; line-height: 1;
}
.feedback-modal-close:hover { color: var(--color-text, #333); }

.feedback-modal-title {
  font-family: var(--font-family-display, serif);
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--color-deep, #3D1A24);
  margin: 0;
  padding-right: 24px;
}
.feedback-modal-subtitle {
  font-size: 0.8rem;
  color: var(--color-text-muted, #888);
  margin: -8px 0 0;
  font-family: var(--font-family, sans-serif);
}

/* ── Section labels ──────────────────────────────────────────────── */
.feedback-section-label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--color-text, #333);
  font-family: var(--font-family, sans-serif);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.feedback-section-hint {
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  color: var(--color-text-muted, #888);
}

/* ── Chip rows ───────────────────────────────────────────────────── */
.feedback-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.feedback-chip {
  padding: 5px 12px;
  border-radius: 20px;
  border: 1px solid var(--color-border, #ddd);
  background: var(--color-bg-elevated, #F4EDE7);
  font-size: 0.78rem;
  font-family: var(--font-family, sans-serif);
  color: var(--color-text, #333);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  line-height: 1.5;
}
.feedback-chip:hover { border-color: var(--color-primary, #BB4966); }

/* Issue chips: rose selected state */
.feedback-chip--issue[data-selected="true"] {
  background: var(--color-primary, #BB4966);
  border-color: var(--color-primary, #BB4966);
  color: #fff;
}

/* Positive chips: green selected state */
.feedback-chip--positive[data-selected="true"] {
  background: #2d7a4f;
  border-color: #2d7a4f;
  color: #fff;
}

/* ── Risk accuracy pill row ─────────────────────────────────────── */
.feedback-risk-row {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.feedback-risk-chip {
  padding: 5px 14px;
  border-radius: 20px;
  border: 1px solid var(--color-border, #ddd);
  background: var(--color-bg-elevated, #F4EDE7);
  font-size: 0.78rem;
  font-family: var(--font-family, sans-serif);
  color: var(--color-text, #333);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  line-height: 1.5;
}
.feedback-risk-chip:hover { border-color: var(--color-primary, #BB4966); }
.feedback-risk-chip[data-selected="true"] {
  background: var(--color-primary, #BB4966);
  border-color: var(--color-primary, #BB4966);
  color: #fff;
}

/* ── Divider ─────────────────────────────────────────────────────── */
.feedback-divider {
  border: none;
  border-top: 1px solid var(--color-border-light, #e8e0db);
  margin: 0;
}

/* ── Textarea + counter ─────────────────────────────────────────── */
.feedback-textarea-wrap { position: relative; }
.feedback-textarea {
  width: 100%;
  box-sizing: border-box;
  min-height: 64px;
  padding: 8px 10px;
  border: 1px solid var(--color-border, #ddd);
  border-radius: 8px;
  font-size: 0.82rem;
  font-family: var(--font-family, sans-serif);
  color: var(--color-text, #333);
  background: var(--color-bg, #F8F2ED);
  resize: vertical;
  outline: none;
  transition: border-color 0.2s;
}
.feedback-textarea:focus { border-color: var(--color-primary, #BB4966); }
.feedback-char-counter {
  position: absolute;
  bottom: 6px; right: 8px;
  font-size: 0.68rem;
  color: var(--color-text-muted, #aaa);
  pointer-events: none;
  font-family: var(--font-family, sans-serif);
}

/* ── Actions ─────────────────────────────────────────────────────── */
.feedback-actions {
  display: flex;
  gap: 10px;
}
.feedback-submit-btn {
  flex: 1;
  padding: 10px;
  background: var(--color-primary, #BB4966);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  font-family: var(--font-family, sans-serif);
  cursor: pointer;
  transition: opacity 0.15s;
}
.feedback-submit-btn:hover { opacity: 0.88; }
.feedback-skip-btn {
  padding: 10px 18px;
  background: transparent;
  color: var(--color-text-muted, #888);
  border: 1px solid var(--color-border, #ddd);
  border-radius: 8px;
  font-size: 0.85rem;
  font-family: var(--font-family, sans-serif);
  cursor: pointer;
  transition: border-color 0.15s;
}
.feedback-skip-btn:hover { border-color: var(--color-primary, #BB4966); }

/* ── Privacy note ────────────────────────────────────────────────── */
.feedback-privacy {
  font-size: 0.68rem;
  color: var(--color-text-muted, #aaa);
  text-align: center;
  margin: -4px 0 0;
  font-family: var(--font-family, sans-serif);
}

/* /REQ-15 feedback styles */

/* REQ-15: referral source row */
.feedback-referral-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.feedback-referral-chips { display: flex; gap: 7px; }
.feedback-referral-chip {
  padding: 5px 14px;
  border-radius: 20px;
  border: 1px solid var(--color-border, #ddd);
  background: var(--color-bg-elevated, #F4EDE7);
  font-size: 0.78rem;
  font-family: var(--font-family, sans-serif);
  color: var(--color-text, #333);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  line-height: 1.5;
}
.feedback-referral-chip:hover { border-color: var(--color-primary, #BB4966); }
.feedback-referral-chip[data-selected="true"] {
  background: var(--color-primary, #BB4966);
  border-color: var(--color-primary, #BB4966);
  color: #fff;
}

/* ── Change 5: Env metrics as horizontal tile grid ──────────────── */
[data-theme="warm-organic"] .env-items.env-tiles-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 6px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
[data-theme="warm-organic"] .env-signal-item {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-light) !important;
  border-radius: var(--radius-sm) !important;
  padding: 7px 9px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
}
[data-theme="warm-organic"] .env-tile-name {
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  color: var(--color-text) !important;
  font-family: var(--font-family) !important;
  line-height: 1.2 !important;
}
[data-theme="warm-organic"] .env-tile-desc {
  font-size: 0.63rem !important;
  color: var(--color-text-muted) !important;
  font-family: var(--font-family) !important;
  line-height: 1.3 !important;
}

/* ── Change 6: Logo icon in section headers ──────────────────────── */
.section-icon-logo {
  width: 20px !important;
  height: 20px !important;
  object-fit: contain !important;
  flex-shrink: 0 !important;
  display: inline-block !important;
  vertical-align: middle !important;
}

/* ── Change 2: Alert bar inline in title row ─────────────────────── */
[data-theme="warm-organic"] .alert-bar-inline {
  position: static !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 4px 10px !important;
  border-radius: 20px !important;
  font-size: 0.7rem !important;
  white-space: nowrap !important;
  border: 1px solid var(--color-border) !important;
  background: var(--color-bg-elevated) !important;
  max-width: 260px !important;
}
[data-theme="warm-organic"] .alert-bar-inline .alert-bar-icon { font-size: 12px !important; }
[data-theme="warm-organic"] .alert-bar-inline .alert-bar-text { font-size: 0.68rem !important; }
[data-theme="warm-organic"] .alert-bar-inline .alert-bar-btn {
  font-size: 0.65rem !important;
  padding: 2px 8px !important;
  border-radius: 10px !important;
}
[data-theme="warm-organic"] .alert-bar-inline .alert-bar-dismiss {
  font-size: 12px !important;
}

/* ── Change 3: Feedback bar in panel-left ────────────────────────── */
[data-theme="warm-organic"] .feedback-bar-section {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  padding: 8px 12px !important;
  margin: 0 !important;
}

/* ── Change 1: Global scale — reduce all sizing ──────────────────── */
[data-theme="warm-organic"] .results-top-bar {
  padding: 5px 14px !important;
}
[data-theme="warm-organic"] .logo-img-sm {
  height: 20px !important;
}
[data-theme="warm-organic"] .results-title-row {
  padding: 5px 14px !important;
  gap: 8px !important;
}
[data-theme="warm-organic"] .panel-title {
  font-size: 0.88rem !important;
  margin: 0 !important;
}
[data-theme="warm-organic"] .meta-pill {
  font-size: 0.62rem !important;
  padding: 1px 7px !important;
}
[data-theme="warm-organic"] .results-columns {
  padding: 8px 14px 0 !important;
  gap: 10px !important;
}
[data-theme="warm-organic"] .panel-left {
  gap: 7px !important;
}
[data-theme="warm-organic"] .panel-right {
  gap: 7px !important;
}
[data-theme="warm-organic"] #map,
[data-theme="warm-organic"] .map-contained {
  height: 240px !important;
}
[data-theme="warm-organic"] .trigger-risk-card,
[data-theme="warm-organic"] .recommendations-card {
  padding: 8px 10px !important;
}
[data-theme="warm-organic"] .risk-title { font-size: 0.78rem !important; }
[data-theme="warm-organic"] .risk-description { font-size: 0.7rem !important; margin: 4px 0 0 !important; }
[data-theme="warm-organic"] .rp-section { padding: 10px 12px !important; }
[data-theme="warm-organic"] .section-header { gap: 6px !important; margin-bottom: 6px !important; }
[data-theme="warm-organic"] .section-header h3 { font-size: 0.72rem !important; }
[data-theme="warm-organic"] .recommendations-card .recommendations-list { font-size: 0.7rem !important; }
[data-theme="warm-organic"] .recommendations-card .recommendations-list li { padding: 2px 0 !important; }
[data-theme="warm-organic"] .risk-recs-row { gap: 8px !important; }
[data-theme="warm-organic"] .below-map-row { gap: 8px !important; }
[data-theme="warm-organic"] .ehspi-intro { font-size: 0.64rem !important; margin-bottom: 6px !important; }
[data-theme="warm-organic"] .ehspi-mini-card { padding: 8px 10px !important; }
[data-theme="warm-organic"] .ehspi-mini-label { font-size: 0.54rem !important; margin-bottom: 5px !important; }
[data-theme="warm-organic"] .crc-block { margin-bottom: 6px !important; }
[data-theme="warm-organic"] .crc-block-header { margin-bottom: 2px !important; }
[data-theme="warm-organic"] .combined-env-metrics .env-card { padding: 8px 10px 6px !important; }
[data-theme="warm-organic"] .env-card .env-header h3 { font-size: 0.72rem !important; }
[data-theme="warm-organic"] .combined-env-metrics .pollutant-tiles-section { padding: 0 10px 8px !important; }
[data-theme="warm-organic"] .map-overlay-summary { max-width: 320px !important; }
[data-theme="warm-organic"] .map-overlay-summary .window-metric-value { font-size: 0.78rem !important; }
[data-theme="warm-organic"] .uncertainty-list li { padding: 5px 9px !important; font-size: 0.7rem !important; }
[data-theme="warm-organic"] .results-view { padding: 0 0 16px !important; }
[data-theme="warm-organic"] .alert-status-panel { margin: 0 14px 0 !important; }


/* ═══════════════════════════════════════════════════════════════════
   UI FIXES: alert pill · logos · env unified tiles · typography
   ═══════════════════════════════════════════════════════════════════ */

/* ── FIX ①: Alert bar as inline meta pill ───────────────────────── */
[data-theme="warm-organic"] .alert-bar-meta {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 2px 8px !important;
  border-radius: 20px !important;
  border: 1px solid var(--color-border) !important;
  background: var(--color-bg-elevated) !important;
  position: static !important;
  bottom: auto !important;
  z-index: auto !important;
  font-size: 0.62rem !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}
[data-theme="warm-organic"] .alert-bar-meta .alert-bar-icon { font-size: 10px !important; }
[data-theme="warm-organic"] .alert-bar-meta .alert-bar-text { font-size: 0.6rem !important; font-weight: 400 !important; }
[data-theme="warm-organic"] .alert-bar-meta strong { font-weight: 600 !important; color: var(--color-primary); }
[data-theme="warm-organic"] .alert-bar-meta .alert-bar-btn {
  font-size: 0.58rem !important;
  padding: 1px 7px !important;
  border-radius: 10px !important;
  font-weight: 500 !important;
}
[data-theme="warm-organic"] .alert-bar-meta .alert-bar-dismiss {
  font-size: 10px !important;
  width: 14px !important; height: 14px !important;
}
[data-theme="warm-organic"] .alert-bar-meta .alert-bar-active-dot {
  width: 6px !important; height: 6px !important;
}

/* Hide the old results-title-right (bell removed, alert moved to meta) */
[data-theme="warm-organic"] .results-title-right { display: none !important; }

/* ── FIX ②: Logo icon sizing ────────────────────────────────────── */
[data-theme="warm-organic"] .section-icon-logo {
  width: 20px !important; height: 20px !important;
  object-fit: contain !important; flex-shrink: 0 !important;
  display: inline-block !important; vertical-align: middle !important;
}

/* ── FIX ③: Unified env metrics — pdc-tile style ───────────────── */
[data-theme="warm-organic"] .env-items.env-tiles-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 6px !important;
  list-style: none !important; padding: 0 !important; margin: 0 !important;
}
[data-theme="warm-organic"] .env-signal-item {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-light) !important;
  border-radius: var(--radius-sm) !important;
  padding: 7px 9px !important;
  display: flex !important; flex-direction: column !important; gap: 2px !important;
}
[data-theme="warm-organic"] .env-tile-name {
  font-size: 0.68rem !important; font-weight: 700 !important;
  color: var(--color-text) !important; font-family: var(--font-family) !important;
  line-height: 1.2 !important;
}
[data-theme="warm-organic"] .env-tile-sub {
  font-size: 0.6rem !important; color: var(--color-text-muted) !important;
  font-family: var(--font-family) !important; line-height: 1.2 !important;
  font-weight: 400 !important;
}
[data-theme="warm-organic"] .env-tile-val {
  font-size: 0.9rem !important; font-weight: 700 !important;
  font-family: var(--font-family) !important;
  margin-top: 2px !important; line-height: 1.1 !important;
}
/* Old env-tile-desc (fallback) */
[data-theme="warm-organic"] .env-tile-desc {
  font-size: 0.6rem !important; color: var(--color-text-muted) !important;
  font-weight: 400 !important;
}

/* ── FIX ④: CRC header inline ───────────────────────────────────── */
[data-theme="warm-organic"] .ehspi-crc-mini-label {
  font-size: 0.6rem !important; font-weight: 700 !important;
  letter-spacing: 0.08em !important; text-transform: uppercase !important;
  color: var(--color-text-muted) !important; margin-bottom: 6px !important;
  display: block !important; white-space: nowrap !important;
}
[data-theme="warm-organic"] .crc-sens-inline {
  color: var(--color-primary) !important; font-weight: 500 !important;
  text-transform: none !important; letter-spacing: 0 !important;
  margin-left: 2px !important;
}
/* Hide per-block header since sensitivity is now in mini-label */
[data-theme="warm-organic"] .crc-block-header { display: none !important; }

/* ── FIX ④: Global typography — 10px base, no bold body ─────────── */
[data-theme="warm-organic"] .results-view {
  font-size: 10px !important;
}
/* Section + card headers keep bold */
[data-theme="warm-organic"] .section-header h3,
[data-theme="warm-organic"] .ehspi-mini-label,
[data-theme="warm-organic"] .crc-sens-inline,
[data-theme="warm-organic"] .env-tile-name,
[data-theme="warm-organic"] .pdc-name,
[data-theme="warm-organic"] .risk-title,
[data-theme="warm-organic"] .panel-title { font-weight: 700 !important; }

/* Body text — no bold */
[data-theme="warm-organic"] .risk-description,
[data-theme="warm-organic"] .recommendations-list li,
[data-theme="warm-organic"] .relevance-card p,
[data-theme="warm-organic"] #relevance-extended,
[data-theme="warm-organic"] .uncertainty-list li,
[data-theme="warm-organic"] .evidence-item,
[data-theme="warm-organic"] .evidence-title,
[data-theme="warm-organic"] .env-tile-sub,
[data-theme="warm-organic"] .env-tile-desc,
[data-theme="warm-organic"] .pdc-sub,
[data-theme="warm-organic"] .ehspi-intro,
[data-theme="warm-organic"] .meta-pill { font-weight: 400 !important; }

/* Evidence items: compact */
[data-theme="warm-organic"] .evidence-item { font-size: 0.75rem !important; }
[data-theme="warm-organic"] .evidence-meta { font-size: 0.65rem !important; }

/* Risk + recs: compact text */
[data-theme="warm-organic"] .risk-title { font-size: 0.75rem !important; }
[data-theme="warm-organic"] .risk-description { font-size: 0.68rem !important; }
[data-theme="warm-organic"] .recommendations-list li { font-size: 0.68rem !important; padding: 1px 0 !important; }
[data-theme="warm-organic"] .recommendations-list li::before { font-size: 0.68rem !important; }

/* Relevance: readable but compact */
[data-theme="warm-organic"] #relevance-extended,
[data-theme="warm-organic"] #relevance-extended p { font-size: 0.72rem !important; line-height: 1.5 !important; }

/* Caveats: compact chips */
[data-theme="warm-organic"] .uncertainty-list li { font-size: 0.68rem !important; padding: 4px 8px !important; }


/* Remove progress bars from pollutant tiles — name/sub/number only */
[data-theme="warm-organic"] .pdc-bar { display: none !important; }


/* ═══════════════════════════════════════════════════════════════════
   RATIONAL TYPE SCALE — single body size, 3 weights, 5 levels
   Base: 13px on .results-view
   Scale: 9 / 10 / 11 / 13(body) / 14(metric val) / 15(title)
   ═══════════════════════════════════════════════════════════════════ */

/* ── Base ────────────────────────────────────────────────────────── */
[data-theme="warm-organic"] .results-view {
  font-size: 13px !important;
  line-height: 1.5 !important;
}

/* ── Level 1: Panel title (15px / 600) ──────────────────────────── */
[data-theme="warm-organic"] .panel-title {
  font-size: 15px !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
}

/* ── Level 2: Section headers (11px / 700) ───────────────────────── */
[data-theme="warm-organic"] .section-header h3,
[data-theme="warm-organic"] .env-card .env-header h3,
[data-theme="warm-organic"] .combined-env-metrics .env-header h3,
[data-theme="warm-organic"] .ehspi-mini-label,
[data-theme="warm-organic"] .ehspi-crc-mini-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
}

/* ── Level 3: Body text — ONE SIZE for everything (13px / 400) ───── */
[data-theme="warm-organic"] .risk-description,
[data-theme="warm-organic"] .recommendations-list li,
[data-theme="warm-organic"] .recommendations-list li::before,
[data-theme="warm-organic"] #relevance-extended,
[data-theme="warm-organic"] #relevance-extended p,
[data-theme="warm-organic"] .uncertainty-list li,
[data-theme="warm-organic"] .evidence-item,
[data-theme="warm-organic"] .evidence-title,
[data-theme="warm-organic"] .ehspi-intro,
[data-theme="warm-organic"] .env-tile-sub,
[data-theme="warm-organic"] .env-tile-desc,
[data-theme="warm-organic"] .pdc-sub,
[data-theme="warm-organic"] .crc-title {
  font-size: 13px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
}

/* ── Level 4: Risk title + metric names (11px / 700) ─────────────── */
[data-theme="warm-organic"] .risk-title,
[data-theme="warm-organic"] .env-tile-name,
[data-theme="warm-organic"] .pdc-name {
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
}

/* ── Level 5: Metric values (14px / 700, coloured) ───────────────── */
[data-theme="warm-organic"] .env-tile-val,
[data-theme="warm-organic"] .pdc-value {
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
}
[data-theme="warm-organic"] .pdc-unit {
  font-size: 10px !important;
  font-weight: 400 !important;
}

/* ── Micro labels (9-10px / 400) ─────────────────────────────────── */
[data-theme="warm-organic"] .evidence-meta,
[data-theme="warm-organic"] .evidence-badge,
[data-theme="warm-organic"] .ehspi-confidence,
[data-theme="warm-organic"] .map-overlay-label,
[data-theme="warm-organic"] .window-metric-label,
[data-theme="warm-organic"] .window-metric-sublabel,
[data-theme="warm-organic"] .feedback-question,
[data-theme="warm-organic"] .feedback-bar-status,
[data-theme="warm-organic"] .crc-subtitle {
  font-size: 10px !important;
  font-weight: 400 !important;
}

/* ── Meta pills (10px) ───────────────────────────────────────────── */
[data-theme="warm-organic"] .meta-pill {
  font-size: 10px !important;
  font-weight: 400 !important;
}

/* ── Map overlay metric values (12px) ────────────────────────────── */
[data-theme="warm-organic"] .map-overlay-summary .window-metric-value,
[data-theme="warm-organic"] .window-metric-value {
  font-size: 12px !important;
  font-weight: 700 !important;
}

/* ── Alert bar meta pill text (10px) ─────────────────────────────── */
[data-theme="warm-organic"] .alert-bar-meta,
[data-theme="warm-organic"] .alert-bar-meta .alert-bar-text {
  font-size: 10px !important;
}
[data-theme="warm-organic"] .alert-bar-meta .alert-bar-btn {
  font-size: 10px !important;
  font-weight: 600 !important;
}

/* ── Feedback bar compact text ───────────────────────────────────── */
[data-theme="warm-organic"] .feedback-bar-section .feedback-question {
  font-size: 11px !important;
}



/* ═══════════════════════════════════════════════════════════════════
   6-FIX SPRINT: header · section bars · map · thumbs · AQ tiles
   ═══════════════════════════════════════════════════════════════════ */

/* ── FIX ①: Unified single header bar ───────────────────────────── */
[data-theme="warm-organic"] .results-top-bar { display: none !important; }

[data-theme="warm-organic"] .results-title-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 5px 16px !important;
  background: var(--color-bg-surface) !important;
  border-bottom: 1px solid var(--color-border) !important;
  flex-wrap: nowrap !important;
}
[data-theme="warm-organic"] .results-header-logo {
  height: 15px !important;
  width: auto !important;
  flex-shrink: 0 !important;
  display: block !important;
}
[data-theme="warm-organic"] .results-title-divider {
  width: 1px !important;
  height: 18px !important;
  background: var(--color-border) !important;
  flex-shrink: 0 !important;
}
[data-theme="warm-organic"] .results-title-left {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 8px !important;
  flex: 1 !important;
  min-width: 0 !important;
  flex-wrap: wrap !important;
}
[data-theme="warm-organic"] .panel-title {
  font-size: 13px !important;
  font-weight: 600 !important;
  white-space: nowrap !important;
  margin: 0 !important;
}
[data-theme="warm-organic"] .panel-meta {
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  flex-wrap: wrap !important;
  margin: 0 !important;
}
[data-theme="warm-organic"] .results-title-right { display: none !important; }
[data-theme="warm-organic"] .results-header-back {
  flex-shrink: 0 !important;
  margin-left: auto !important;
  font-size: 10px !important;
  padding: 3px 8px !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 4px !important;
  background: transparent !important;
  cursor: pointer !important;
  color: var(--color-text-muted) !important;
  font-family: var(--font-family) !important;
}
[data-theme="warm-organic"] .results-header-back:hover {
  background: var(--color-bg-elevated) !important;
  color: var(--color-text) !important;
}

/* ── FIX ②: Section header bars — all sections except risk ──────── */
[data-theme="warm-organic"] .section-header,
[data-theme="warm-organic"] .env-header {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 7px 10px 7px !important;
  margin: -10px -10px 10px !important;
  background: var(--color-bg-elevated) !important;
  border-bottom: 1px solid var(--color-border-light) !important;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0 !important;
}
/* env-card header lives inside combined-env — tighter pull */
[data-theme="warm-organic"] .combined-env-metrics .env-header {
  margin: -14px -16px 10px !important;
  padding: 7px 16px !important;
  border-radius: var(--radius-md) var(--radius-md) 0 0 !important;
}
/* rp-section headers */
[data-theme="warm-organic"] .rp-section .section-header {
  margin: -10px -12px 10px !important;
  padding: 7px 12px !important;
  border-radius: var(--radius-md) var(--radius-md) 0 0 !important;
}
/* floating card headers (risk-recs row) */
[data-theme="warm-organic"] .floating-card .section-header {
  margin: -14px -16px 10px !important;
  padding: 7px 16px !important;
  border-radius: var(--radius-md) var(--radius-md) 0 0 !important;
}
[data-theme="warm-organic"] .section-header h3,
[data-theme="warm-organic"] .env-header h3 {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.03em !important;
  margin: 0 !important;
  line-height: 1 !important;
}
/* Risk header stays exactly as-is — no bar */
[data-theme="warm-organic"] .risk-header {
  background: none !important;
  border-bottom: none !important;
  margin: 0 !important;
  padding: 0 0 6px !important;
}

/* ── FIX ③: Map height 320px ────────────────────────────────────── */
[data-theme="warm-organic"] #map,
[data-theme="warm-organic"] .map-contained {
  height: 380px !important;
}

/* ── FIX ④: Per-section thumbs ──────────────────────────────────── */
.section-thumb {
  display: flex !important;
  justify-content: flex-end !important;
  gap: 4px !important;
  margin-top: 8px !important;
  padding-top: 6px !important;
  border-top: 1px solid var(--color-border-light, #eee) !important;
}
.st-btn {
  background: none !important;
  border: 1px solid var(--color-border-light, #eee) !important;
  border-radius: 6px !important;
  padding: 2px 6px !important;
  font-size: 11px !important;
  cursor: pointer !important;
  line-height: 1 !important;
  transition: background 0.15s, border-color 0.15s !important;
  color: var(--color-text-muted, #999) !important;
}
.st-btn:hover { background: var(--color-bg-elevated, #f5f0eb) !important; }
.st-btn.st-yes { background: #e6f4ec !important; border-color: #2d7a4f !important; }
.st-btn.st-no  { background: #fde8e8 !important; border-color: #c53030 !important; }
.st-btn:disabled { cursor: default !important; opacity: 0.7 !important; }

/* ── FIX ⑤: Feedback bar hidden ────────────────────────────────── */
[data-theme="warm-organic"] .feedback-bar-section { display: none !important; }
#feedback-bar-section { display: none !important; }

/* ── FIX ⑥: AQ/pollutant tiles → 4-col, same as env tiles ──────── */
[data-theme="warm-organic"] .pollutant-tiles-section {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}
/* Hide the "Air quality details" sub-header — section header above covers it */
[data-theme="warm-organic"] .pollutant-tiles-section > .section-header {
  display: none !important;
}
[data-theme="warm-organic"] .pollutant-tiles-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 6px !important;
}
/* pdc-tile → identical to env-signal-item */
[data-theme="warm-organic"] .pdc-tile {
  background: var(--color-bg-elevated) !important;
  border: 1px solid var(--color-border-light) !important;
  border-radius: var(--radius-sm) !important;
  padding: 7px 9px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  box-shadow: none !important;
}
[data-theme="warm-organic"] .pdc-name {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--color-text) !important;
  line-height: 1.2 !important;
}
[data-theme="warm-organic"] .pdc-sub {
  font-size: 10px !important;
  color: var(--color-text-muted) !important;
  font-weight: 400 !important;
  line-height: 1.2 !important;
}
[data-theme="warm-organic"] .pdc-value {
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  margin-top: 2px !important;
}
[data-theme="warm-organic"] .pdc-unit {
  font-size: 10px !important;
  font-weight: 400 !important;
  color: var(--color-text-muted) !important;
}
[data-theme="warm-organic"] .pdc-value-row {
  display: flex !important;
  align-items: baseline !important;
  gap: 2px !important;
  margin-top: 2px !important;
}
/* dashed separator between env and pollutant tile grids */
[data-theme="warm-organic"] .combined-env-metrics .pollutant-tiles-section {
  border-top: 1px dashed var(--color-border-light) !important;
  padding-top: 8px !important;
  margin-top: 4px !important;
}


/* ═══ SPRINT FIX: logo 30px · thumb bars · exposure thumb ════════ */

/* ① Logo 30px */
[data-theme="warm-organic"] .results-header-logo {
  height: 30px !important;
  width: auto !important;
}

/* ④ Remove bar background from section-thumb in all contexts —
      plain border-top line + thumbs only, matching risk card */
[data-theme="warm-organic"] .section-thumb {
  background: none !important;
  border-radius: 0 !important;
  padding: 6px 0 0 !important;
  margin-top: 8px !important;
  border-top: 1px solid var(--color-border-light, #e8e0db) !important;
  display: flex !important;
  justify-content: flex-end !important;
  gap: 4px !important;
}

/* ③ Exposure summary thumb — no line, floating corner */
[data-theme="warm-organic"] .section-thumb.st-overlay {
  border-top: none !important;
  margin-top: 4px !important;
  padding-top: 0 !important;
  position: absolute !important;
  bottom: 6px !important;
  right: 6px !important;
  z-index: 25 !important;
}
/* Make map-overlay-summary position:relative so thumb anchors to it */
[data-theme="warm-organic"] .map-overlay-summary {
  position: absolute !important;
  bottom: 12px !important;
  left: 12px !important;
  z-index: 20 !important;
}


/* Overlay card: tighter width + 2-col grid to prevent right-edge cut-off */
[data-theme="warm-organic"] .map-overlay-summary {
  max-width: 230px !important;
}
[data-theme="warm-organic"] .map-overlay-summary .window-summary-grid {
  grid-template-columns: repeat(2, 1fr) !important;
}

/* Overlay: 360px max-width, 3-col grid restored */
[data-theme="warm-organic"] .map-overlay-summary {
  max-width: 360px !important;
}
[data-theme="warm-organic"] .map-overlay-summary .window-summary-grid {
  grid-template-columns: repeat(3, 1fr) !important;
}


/* ═══════════════════════════════════════════════════════════════════
   REQ-17: Two-screen input flow
   ═══════════════════════════════════════════════════════════════════ */

/* ── Screen system ──────────────────────────────────────────────── */
.input-screen {
  position: absolute; inset: 0;
  padding: 0 24px 32px;
  display: flex; flex-direction: column;
  overflow-y: auto;
  transition: opacity 0.42s cubic-bezier(.4,0,.2,1),
              transform 0.42s cubic-bezier(.4,0,.2,1);
  background: var(--color-bg, #F8F2ED);
  min-height: 100vh;
}
.input-screen::-webkit-scrollbar { display: none; }
.input-screen.active  { opacity:1; transform:translateX(0); position:relative; }
.input-screen.hidden  { opacity:0; transform:translateX(52px); pointer-events:none; }
.input-screen.exiting { opacity:0; transform:translateX(-52px); pointer-events:none; }

/* ── Progress dots ───────────────────────────────────────────────── */
.s1-progress-row {
  display: flex; justify-content: center; gap: 8px;
  margin: 14px 0 20px;
}
.s1-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--color-border, #E8D8DC);
  transition: all 0.3s cubic-bezier(.4,0,.2,1);
  flex-shrink: 0;
}
.s1-dot.s1-dot-active {
  background: var(--color-primary, #BB4966);
  width: 24px; border-radius: 4px;
}

/* ── Screen 1: Next step button ──────────────────────────────────── */
.s1-next-btn {
  width: 100%; padding: 16px; background: var(--color-primary, #BB4966);
  color: #fff; border: none; border-radius: 14px;
  font-size: 16px; font-weight: 700; cursor: pointer;
  font-family: var(--font-family, inherit);
  box-shadow: 0 4px 18px rgba(187,73,102,0.28);
  transition: all 0.2s; letter-spacing: -0.2px;
}
.s1-next-btn:hover:not(:disabled) { background:#A33D59; transform:translateY(-1px); }
.s1-next-btn:active:not(:disabled) { transform: scale(0.98); }
.s1-next-btn:disabled {
  background: var(--color-border, #E8D8DC);
  color: var(--color-text-muted, #B8909A);
  box-shadow: none; transform: none; cursor: default;
}
.s1-hint {
  text-align: center; margin-top: 8px;
  font-size: 11px; color: var(--color-text-muted, #B8909A);
  transition: opacity 0.4s;
}
/* 5th sensitivity card spans full width */
.sensitivity-grid .s1-card-full { grid-column: 1 / -1; }

/* ── Screen 2: layout elements ───────────────────────────────────── */
.s2-back-btn {
  display: flex; align-items: center; gap: 5px;
  background: none; border: none;
  color: var(--color-primary, #BB4966);
  font-size: 14px; font-weight: 600;
  cursor: pointer; padding: 20px 0 4px;
  font-family: var(--font-family, inherit);
}
.s2-field-label {
  font-size: 10px; font-weight: 700;
  color: var(--color-text-muted, #B8909A);
  letter-spacing: 0.09em; margin: 16px 0 9px;
}
.s2-pill-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 2px; }
.s2-divider {
  border: none; border-top: 1px solid var(--color-border-light, #F2E8EC);
  margin: 22px 0 0;
}
.s2-location {
  width: 100%; padding: 14px 15px;
  border: 1.5px solid var(--color-border, #E8D8DC);
  border-radius: 12px; background: #fff;
  font-size: 15px; color: var(--color-text, #2D1F26);
  font-family: var(--font-family, inherit);
  outline: none; transition: border 0.2s;
}
.s2-location:focus {
  border-color: var(--color-primary, #BB4966);
  box-shadow: 0 0 0 3px rgba(187,73,102,0.1);
}

/* ── Gate block ──────────────────────────────────────────────────── */
.gate-block {
  opacity: 0; transform: translateY(16px); pointer-events: none;
  transition: opacity 0.48s cubic-bezier(.4,0,.2,1),
              transform 0.48s cubic-bezier(.4,0,.2,1);
  margin-top: 24px;
}
.gate-block.visible { opacity:1; transform:translateY(0); pointer-events:auto; }
.gate-question {
  font-size: 17px; font-weight: 700;
  color: var(--color-text, #2D1F26);
  text-align: center; margin-bottom: 5px; line-height: 1.3;
}
.gate-sub {
  font-size: 12px; color: var(--color-text-muted, #B8909A);
  text-align: center; margin-bottom: 18px; line-height: 1.5;
}
.gate-row { display: flex; gap: 10px; }
.gate-btn {
  flex: 1; padding: 15px; border-radius: 13px;
  font-size: 15px; font-weight: 700; cursor: pointer;
  transition: all 0.18s; font-family: var(--font-family, inherit);
  border: 1.5px solid var(--color-border, #E8D8DC);
  background: #fff; color: var(--color-text-secondary, #5A3A48);
}
.gate-btn-yes {
  background: var(--color-primary, #BB4966);
  border-color: var(--color-primary, #BB4966); color: #fff;
  box-shadow: 0 4px 14px rgba(187,73,102,0.25);
}
.gate-btn-yes:hover { background: #A33D59; }
.gate-btn-no:hover  { border-color: var(--color-primary, #BB4966); }
.gate-btn-active-no {
  background: var(--color-bg-elevated, #FAF4EF) !important;
  border-color: var(--color-primary, #BB4966) !important;
  color: var(--color-primary, #BB4966) !important;
}

/* ── Personalisation fields ──────────────────────────────────────── */
.personal-fields {
  opacity: 0; max-height: 0; overflow: hidden;
  transition: opacity 0.52s cubic-bezier(.4,0,.2,1),
              max-height 0.65s cubic-bezier(.4,0,.2,1);
}
.personal-fields.open { opacity: 1; max-height: 3200px; }

/* ── Chip system ─────────────────────────────────────────────────── */
.s2-chip-group {
  display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 2px;
}
.s2-chip {
  padding: 8px 14px; border: 1.5px solid var(--color-border, #E8D8DC);
  border-radius: 100px; background: #fff;
  font-size: 12px; color: var(--color-text-secondary, #5A3A48);
  cursor: pointer; transition: all 0.15s;
  font-family: var(--font-family, inherit); white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
}
.s2-chip:active { transform: scale(0.95); }
.s2-chip:hover  { border-color: var(--color-accent, #E0726C); }
.s2-chip.sel-single,
.s2-chip.sel-multi {
  background: var(--color-bg-elevated, #FAF4EF);
  border-color: var(--color-primary, #BB4966);
  color: #8B2D45; font-weight: 700;
}
.s2-chip.other-chip { border-style: dashed; color: var(--color-text-muted, #B8909A); }
.s2-chip.other-chip.sel-single { border-style: solid; }
.s2-other-input {
  width: 100%; margin-top: 8px; padding: 10px 13px;
  border: 1.5px solid var(--color-primary, #BB4966);
  border-radius: 10px; font-size: 13px;
  font-family: var(--font-family, inherit);
  color: var(--color-text, #2D1F26);
  background: var(--color-bg-elevated, #FAF4EF); outline: none;
  animation: s2FadeSlide 0.3s ease forwards;
}
@keyframes s2FadeSlide {
  from { opacity:0; transform:translateY(-5px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── CTA wrapper ─────────────────────────────────────────────────── */
.cta-wrap {
  opacity: 0; transform: translateY(12px); pointer-events: none;
  transition: opacity 0.45s cubic-bezier(.4,0,.2,1),
              transform 0.45s cubic-bezier(.4,0,.2,1);
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.cta-wrap.visible { opacity:1; transform:translateY(0); pointer-events:auto; }




/* ═══════════════════════════════════════════════════════════════════
   REQ-17: Input screen centring — definitive rule set (1200px column)
   Full-width background; .screen-inner carries the max-width.
   ═══════════════════════════════════════════════════════════════════ */

/* Screen: zero padding — .screen-inner handles centering */
.input-screen {
  padding-left:  0 !important;
  padding-right: 0 !important;
  padding-top:   0 !important;
  align-items: stretch !important;
}

/* Children flow naturally inside screen-inner */
.input-screen > *,
.input-screen .sensitivity-grid,
.input-screen .hero-logo,
.input-screen h1,
.input-screen p,
.input-screen h2 {
  max-width: 100% !important;
  width: 100% !important;
}

/* Rose pills: hardcoded, max specificity */
body #input-screen-2 .pill[data-selected="true"] {
  background-color: #BB4966 !important;
  background: #BB4966 !important;
  border-color: #BB4966 !important;
  color: #ffffff !important;
  font-weight: 600 !important;
}
body #input-screen-2 .pill {
  border: 1.5px solid #E8D8DC !important;
  background: #ffffff !important;
  color: #5A3A48 !important;
  border-radius: 100px !important;
  padding: 10px 18px !important;
  font-size: 14px !important;
}
body #input-screen-2 .pill:hover:not([data-selected="true"]) {
  border-color: #E0726C !important;
  background: #FAF4EF !important;
}

/* Card selected state */
.sensitivity-card[data-selected="true"] {
  border-color: #BB4966 !important;
  background: #FAF4EF !important;
}
.sensitivity-card[data-selected="true"] .card-title {
  color: #BB4966 !important;
}


/* ═══════════════════════════════════════════════════════════════════
   REQ-17: Apple-pattern layout — full-width, large-scale, edge-to-edge
   .input-screen = full viewport, no padding constraints
   .screen-inner  = max-width 1200px, generous gutters, Apple rhythm
   ═══════════════════════════════════════════════════════════════════ */

/* Screen: full-width container, no horizontal padding constraints */
.input-screen {
  padding: 0 !important;
  align-items: stretch !important;
  display: block !important;
}
.input-screen.active {
  display: block !important;
}

/* Apple-pattern inner column: max-width 1200px, generous gutters */
.screen-inner {
  width: 100% !important;
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 56px 48px 64px !important;
  box-sizing: border-box !important;
}

/* ── Hero: Apple-scale typography ───────────────────────────────── */
.hero-logo {
  padding: 36px 0 10px !important;
}
.logo-img {
  height: 44px !important;
}
.hero-tagline {
  font-size: 13px !important;
  margin-top: 6px !important;
}
.hero-title {
  font-size: clamp(36px, 5.5vw, 68px) !important;
  line-height: 1.06 !important;
  letter-spacing: -0.03em !important;
  margin: 0 0 20px !important;
  text-align: center !important;
}
.hero-subtitle {
  font-size: clamp(17px, 2.2vw, 22px) !important;
  line-height: 1.5 !important;
  margin-bottom: 6px !important;
  text-align: center !important;
}
.hero-disclaimer {
  font-size: 13px !important;
  text-align: center !important;
  color: var(--color-text-light, #B8909A) !important;
  margin-bottom: 4px !important;
}

/* ── Section label ──────────────────────────────────────────────── */
.section-label {
  font-size: clamp(12px, 1.2vw, 14px) !important;
  letter-spacing: 0.1em !important;
  margin: 0 0 20px !important;
}

/* ── Sensitivity grid: taller, fuller, more impactful ───────────── */
.sensitivity-grid {
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 16px !important;
  margin-bottom: 4px !important;
}
.sensitivity-card {
  padding: 40px 24px !important;
  border-radius: 20px !important;
  min-height: 140px !important;
}
.sensitivity-card .card-icon {
  font-size: 44px !important;
  margin-bottom: 16px !important;
}
.sensitivity-card .card-title {
  font-size: 17px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
}

/* ── CTA button: Apple-width, large ────────────────────────────── */
.s1-next-btn {
  font-size: 19px !important;
  padding: 22px !important;
  border-radius: 16px !important;
  letter-spacing: -0.01em !important;
  margin-top: 8px !important;
}

/* ── Progress dots: a bit more air ─────────────────────────────── */
.s1-progress-row {
  margin: 20px 0 28px !important;
}

/* ── Screen 2: comfortable sizing ──────────────────────────────── */
.s2-field-label {
  font-size: 11px !important;
  margin: 18px 0 10px !important;
}
.s2-location {
  font-size: 16px !important;
  padding: 15px !important;
}
.s2-pill-row {
  gap: 10px !important;
}
.s2-back-btn {
  font-size: 15px !important;
  padding: 16px 0 8px !important;
}
.gate-question {
  font-size: 20px !important;
}
.gate-sub {
  font-size: 14px !important;
}
.gate-btn {
  font-size: 16px !important;
  padding: 16px !important;
}
.s2-chip {
  font-size: 13px !important;
  padding: 9px 16px !important;
}

/* ── Rose pills — hardcoded, max specificity ────────────────────── */
body #input-screen-2 .pill[data-selected="true"] {
  background: #BB4966 !important;
  border-color: #BB4966 !important;
  color: #ffffff !important;
  font-weight: 600 !important;
}
body #input-screen-2 .pill {
  border: 1.5px solid #E8D8DC !important;
  background: #ffffff !important;
  color: #5A3A48 !important;
  border-radius: 100px !important;
  padding: 11px 20px !important;
  font-size: 14px !important;
}
body #input-screen-2 .pill:hover:not([data-selected="true"]) {
  border-color: #E0726C !important;
  background: #FAF4EF !important;
}

/* ── Card selected state ────────────────────────────────────────── */
.sensitivity-card[data-selected="true"] {
  border-color: #BB4966 !important;
  background: #FAF4EF !important;
}
.sensitivity-card[data-selected="true"] .card-title {
  color: #BB4966 !important;
}

/* ── Responsive: tablet / mobile ───────────────────────────────── */
@media (max-width: 768px) {
  .screen-inner {
    padding: 36px 24px 48px !important;
  }
  .sensitivity-card {
    padding: 28px 16px !important;
    min-height: 110px !important;
  }
  .sensitivity-card .card-icon {
    font-size: 36px !important;
  }
  .sensitivity-card .card-title {
    font-size: 15px !important;
  }
  .s1-next-btn {
    font-size: 17px !important;
    padding: 18px !important;
  }
}
@media (max-width: 480px) {
  .screen-inner {
    padding: 28px 16px 40px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   SEC-01 v1.2 — REQ-UX-01: Wait screen two-column layout
   ═══════════════════════════════════════════════════════════════════ */

.loading-overlay {
  overflow-y: auto;
  justify-content: flex-start;
  padding-top: 40px;
  max-width: 100vw;
}
.loading-overlay .loading-spinner { flex-shrink: 0; margin: 0 auto 12px; }
.loading-overlay > p { text-align: center; margin: 0 auto 24px; }

.wait-content {
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 400ms ease, transform 400ms ease;
  max-width: 860px;
  width: 100%;
  margin: 0 auto;
  padding-bottom: 32px;
  pointer-events: none;
}
.wait-content.visible { opacity: 1; transform: translateY(0); pointer-events: auto; }

.wait-section-label {
  font-size: 10px; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--color-primary, #BB4966);
  margin-bottom: 16px; text-align: center;
}

.wait-two-col { display: flex; align-items: flex-start; gap: 0; }

.wait-feedback-block {
  flex: 1; min-width: 0;
  background: #FAF4EF; border: 1px solid #E8D8DC;
  border-radius: 14px 0 0 14px; border-right: none;
  padding: 18px 20px;
}

.wait-col-divider {
  width: 1px; background: var(--color-border, #E8D8DC);
  align-self: stretch; flex-shrink: 0;
}

.wait-feature-col {
  flex: 1; min-width: 0;
  background: #FAF4EF; border: 1px solid #E8D8DC;
  border-radius: 0 14px 14px 0; padding: 18px 20px;
}

.wait-heading {
  font-size: 16px; font-weight: 700; color: var(--color-text, #2D1F26);
  margin-bottom: 10px; line-height: 1.3;
}
.wait-body {
  font-size: 13.5px; color: var(--color-text-muted, #B8909A);
  line-height: 1.65; margin-bottom: 14px;
}
.wait-thumb-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.wait-thumb-item {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 12px; color: var(--color-text-muted, #B8909A); line-height: 1.5;
}
.wait-accuracy-note {
  font-size: 12px; color: var(--color-text-muted, #B8909A);
  line-height: 1.55; margin: 0; font-style: italic;
}

.wait-feature-label {
  font-size: 10px; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--color-text-muted, #B8909A);
  margin-bottom: 14px;
}
.wait-feature-list { list-style: none; padding: 0; margin: 0; }
.wait-feature-item { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; }
.wait-feature-icon { font-size: 20px; flex-shrink: 0; line-height: 1.3; width: 24px; text-align: center; }
.wait-feature-name { font-size: 13px; font-weight: 700; color: var(--color-text, #2D1F26); margin-bottom: 2px; }
.wait-feature-desc { font-size: 12px; color: var(--color-text-muted, #B8909A); line-height: 1.55; }

@media (max-width: 600px) {
  .wait-two-col { flex-direction: column; gap: 12px; }
  .wait-feedback-block { border-radius: 14px; border-right: 1px solid #E8D8DC; }
  .wait-feature-col { border-radius: 14px; }
  .wait-col-divider { display: none; }
}
@media (max-height: 480px) {
  .loading-overlay { justify-content: flex-start; padding-top: 20px; }
}

/* ═══════════════════════════════════════════════════════════════════
   SEC-01 v1.2 — REQ-UX-02: EHSPI coverage strip
   ═══════════════════════════════════════════════════════════════════ */

.ehspi-coverage-strip {
  background: var(--color-bg-warm, #FAF4EF);
  border: 1px solid var(--color-border, #E8D8DC);
  border-radius: 12px; padding: 16px 18px; margin: 12px 0 8px;
  display: flex; align-items: flex-start; gap: 12px;
}
.ehspi-strip-icon { font-size: 18px; flex-shrink: 0; color: var(--color-primary, #BB4966); line-height: 1.4; }
.ehspi-strip-body { flex: 1; }
.ehspi-strip-msg { font-size: 13px; color: var(--color-text-muted, #B8909A); line-height: 1.6; margin: 0 0 10px; }
.ehspi-strip-cta {
  font-size: 12.5px; font-weight: 700; color: var(--color-primary, #BB4966);
  background: transparent; border: 1px solid var(--color-primary, #BB4966);
  border-radius: 100px; padding: 6px 14px; cursor: pointer;
  transition: background 0.2s, color 0.2s; font-family: var(--font-family, inherit);
}
.ehspi-strip-cta:hover { background: var(--color-primary, #BB4966); color: #fff; }

/* ═══════════════════════════════════════════════════════════════════
   SEC-01 v1.2 — REQ-UX-03A: Location coverage notice (screen 1)
   ═══════════════════════════════════════════════════════════════════ */

.location-coverage-notice {
  background: #FEF7EC; border: 1px solid #C8760A;
  border-radius: 12px; padding: 14px 16px; margin: 0 0 16px;
}
.lcn-heading { font-size: 13.5px; font-weight: 700; color: var(--color-text, #2D1F26); margin-bottom: 6px; }
.lcn-body { font-size: 13px; color: var(--color-text-muted, #B8909A); line-height: 1.6; margin: 0 0 8px; }
.lcn-link { font-size: 12.5px; color: var(--color-primary, #BB4966); text-decoration: underline; display: inline-block; margin-bottom: 8px; }
.lcn-caveat { font-size: 12px; color: var(--color-text-muted, #B8909A); font-style: italic; line-height: 1.5; margin: 0 0 8px; }
.lcn-retry { font-size: 13px; color: var(--color-text-muted, #B8909A); margin: 0; }
.lcn-try-again { color: var(--color-primary, #BB4966); font-weight: 700; text-decoration: underline; cursor: pointer; }

/* ═══════════════════════════════════════════════════════════════════
   SEC-01 v1.2 — REQ-UX-03B: Blocked territory message (screen 2)
   ═══════════════════════════════════════════════════════════════════ */

.location-blocked-msg {
  background: #FDF0F0; border: 1px solid #C53030;
  border-radius: 8px; padding: 10px 12px; margin-top: 6px;
  font-size: 12.5px; color: var(--color-text-muted, #B8909A); line-height: 1.55;
}
.location-blocked-msg a { color: var(--color-primary, #BB4966); text-decoration: underline; margin-left: 4px; }

/* Google Places autocomplete dropdown */
.pac-container {
  border-radius: 10px; border: 1px solid var(--color-border, #E8D8DC);
  box-shadow: 0 4px 16px rgba(45,31,38,0.1);
  font-family: var(--font-family, inherit); margin-top: 4px;
}
.pac-item { font-size: 13.5px; padding: 8px 14px; color: var(--color-text, #2D1F26); cursor: pointer; }
.pac-item:hover, .pac-item-selected { background: var(--color-bg-warm, #FAF4EF); }
.pac-item-query { font-weight: 700; color: var(--color-text, #2D1F26); }
.pac-matched { color: var(--color-primary, #BB4966); }

/* ═══════════════════════════════════════════════════════════════════
   REQ-RL-01 — Daily rate limit notice (screen 1, amber)
   ═══════════════════════════════════════════════════════════════════ */

.daily-limit-notice {
  background: #FEF7EC;
  border: 1px solid #C8760A;
  border-radius: 14px;
  padding: 16px 18px;
  margin: 0 0 16px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.dl-icon {
  font-size: 22px;
  flex-shrink: 0;
  line-height: 1.3;
}

.dl-body {
  flex: 1;
  min-width: 0;
}

.dl-heading {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text, #2D1F26);
  margin-bottom: 6px;
  line-height: 1.35;
}

.dl-text {
  font-size: 13px;
  color: var(--color-text-muted, #B8909A);
  line-height: 1.6;
  margin-bottom: 12px;
}

.dl-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.dl-cta-primary {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  background: var(--color-primary, #BB4966);
  border-radius: 100px;
  padding: 8px 18px;
  text-decoration: none;
  transition: opacity 0.2s;
}

.dl-cta-primary:hover {
  opacity: 0.88;
}

.dl-reset {
  font-size: 11px;
  color: var(--color-text-muted, #B8909A);
}

/* Subtle quota indicator — only shown when close to daily limit */
.rate-limit-indicator {
  display: none;
  font-size: 11px;
  color: var(--color-text-muted, #B8909A);
  text-align: center;
  margin-top: 8px;
  padding: 4px 0;
}

/* ═══════════════════════════════════════════════════════════════════
   REQ-CHAT-01 — Conversational Chat Layer
   ═══════════════════════════════════════════════════════════════════ */

/* ── Panel container ──────────────────────────────────────────────── */
.chat-panel {
  background: var(--color-bg-surface, #FAF5F0);
  border-top: 2px solid var(--color-border, #E8D5C4);
  border-radius: 0 0 20px 20px;
  padding: 24px;
  margin-top: 24px;
  max-width: 100%;
}

/* ── Header ───────────────────────────────────────────────────────── */
.chat-panel-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--color-text-muted, #B8909A);
  text-transform: uppercase;
  margin-bottom: 6px;
}

.chat-panel-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 16px;
  font-weight: 600;
  color: var(--color-text, #2D1F26);
  margin-bottom: 14px;
}

.chat-header-logo {
  height: 22px;
  width: auto;
}

/* ── Educational disclaimer ───────────────────────────────────────── */
.chat-disclaimer {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: #FEF7EC;
  border: 1px solid #C8760A;
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 18px;
  font-size: 12.5px;
  color: var(--color-text, #2D1F26);
  line-height: 1.55;
}

.chat-disclaimer-icon {
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── Message list ─────────────────────────────────────────────────── */
.chat-messages {
  max-height: 480px;
  overflow-y: auto;
  padding: 4px 0 12px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.chat-bubble-wrap {
  display: flex;
  flex-direction: column;
  max-width: 82%;
}

.chat-bubble-wrap--user {
  align-self: flex-end;
  align-items: flex-end;
}

.chat-bubble-wrap--assistant {
  align-self: flex-start;
  align-items: flex-start;
}

/* User bubble */
.chat-bubble-user {
  background: var(--color-primary-light, #F9ECF0);
  border: 1px solid var(--color-border-accent, #E8C0CC);
  border-radius: 14px 14px 4px 14px;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--color-text, #2D1F26);
  line-height: 1.55;
  word-break: break-word;
}

/* Assistant bubble */
.chat-bubble-assistant {
  background: #fff;
  border: 1px solid var(--color-border, #E8D5C4);
  border-radius: 14px 14px 14px 4px;
  padding: 12px 16px;
  font-size: 14px;
  color: var(--color-text, #2D1F26);
  line-height: 1.65;
  word-break: break-word;
}

.chat-bubble-assistant p {
  margin: 0 0 8px;
}

.chat-bubble-assistant p:last-child {
  margin-bottom: 0;
}

/* Citation reference */
.chat-citation {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  color: var(--color-primary, #BB4966);
  background: var(--color-primary-light, #F9ECF0);
  border-radius: 4px;
  padding: 0 4px;
  margin: 0 1px;
}

/* Typing indicator (three dots animation) */
.chat-typing::after {
  content: '●●●';
  font-size: 18px;
  letter-spacing: 4px;
  color: var(--color-text-muted, #B8909A);
  animation: chat-blink 1.2s infinite;
}

@keyframes chat-blink {
  0%, 80%, 100% { opacity: 0.2; }
  40%           { opacity: 1; }
}

/* ── Feedback row per assistant turn ──────────────────────────────── */
.chat-feedback-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
  padding-left: 4px;
}

.chat-feedback-label {
  font-size: 11px;
  color: var(--color-text-muted, #B8909A);
}

.chat-feedback-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 14px;
  padding: 2px 4px;
  border-radius: 4px;
  transition: background 0.15s;
  line-height: 1;
}

.chat-feedback-btn:hover {
  background: var(--color-bg-warm, #F5EDE6);
}

/* ── Suggested question pills ──────────────────────────────────────── */
.chat-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
}

.chat-suggestion-pill {
  background: var(--color-bg-warm, #F5EDE6);
  border: 1px solid var(--color-border-accent, #E8C0CC);
  border-radius: 100px;
  padding: 7px 14px;
  font-size: 13px;
  color: var(--color-primary, #BB4966);
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s;
  text-align: left;
  line-height: 1.4;
}

.chat-suggestion-pill:hover {
  background: var(--color-primary-light, #F9ECF0);
  border-color: var(--color-primary, #BB4966);
}

/* ── Input row ─────────────────────────────────────────────────────── */
.chat-input-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  position: relative;
}

.chat-input {
  flex: 1;
  border: 1.5px solid var(--color-border, #E8D5C4);
  border-radius: 12px;
  padding: 12px 16px;
  font-size: 14px;
  font-family: var(--font-family, sans-serif);
  color: var(--color-text, #2D1F26);
  background: #fff;
  outline: none;
  transition: border-color 0.18s;
}

.chat-input:focus {
  border-color: var(--color-primary, #BB4966);
}

.chat-input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.chat-input::placeholder {
  color: var(--color-text-muted, #B8909A);
}

.chat-char-count {
  position: absolute;
  right: 56px;
  bottom: 14px;
  font-size: 11px;
  color: var(--color-text-muted, #B8909A);
  pointer-events: none;
}

.chat-send-btn {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: var(--color-primary, #BB4966);
  color: #fff;
  border: none;
  font-size: 18px;
  cursor: pointer;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.18s;
}

.chat-send-btn:hover {
  opacity: 0.88;
}

.chat-send-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* ── Turn limit message ────────────────────────────────────────────── */
.chat-turn-limit-msg {
  font-size: 12px;
  color: var(--color-text-muted, #B8909A);
  text-align: center;
  margin-top: 10px;
  font-style: italic;
}

/* ── Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 600px) {
  .chat-panel {
    padding: 16px;
    border-radius: 0;
  }
  .chat-bubble-wrap {
    max-width: 94%;
  }
  .chat-messages {
    max-height: 360px;
  }
}


/* ═══════════════════════════════════════════════════════════════════
   REQ-CHAT-01 v1.1 — Header-anchored chat panel + sticky header
   ═══════════════════════════════════════════════════════════════════ */

/* ── 1. Make results-view scrollable so sticky works ────────────── */
[data-theme="warm-organic"] .results-view {
  overflow-y: auto !important;
  overflow-x: hidden !important;
  height: 100vh !important;
}

/* ── 2. Sticky header ───────────────────────────────────────────── */
[data-theme="warm-organic"] .results-title-row {
  position: sticky !important;
  top: 0 !important;
  z-index: 200 !important;
  background: var(--color-bg-surface) !important;
  border-bottom: 1px solid var(--color-border) !important;
}

/* ── 3. Chat trigger button in header ───────────────────────────── */
.chat-header-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--color-bg-elevated, #F0E6DE);
  border: 1px solid var(--color-border-accent, #E8C0CC);
  border-radius: 100px;
  padding: 3px 12px 3px 8px;
  cursor: pointer;
  font-family: var(--font-family, sans-serif);
  font-size: 10px;
  font-weight: 600;
  color: var(--color-primary, #BB4966);
  flex-shrink: 0;
  transition: background 0.18s, border-color 0.18s;
  white-space: nowrap;
  max-width: 320px;
}

.chat-header-btn:hover {
  background: var(--color-primary-light, #F9ECF0);
  border-color: var(--color-primary, #BB4966);
}

.chat-header-btn[aria-expanded="true"] {
  background: var(--color-primary, #BB4966);
  color: #fff;
  border-color: var(--color-primary, #BB4966);
}

.chat-header-btn-icon {
  font-size: 13px;
  line-height: 1;
}

.chat-header-btn-label {
  line-height: 1;
}

/* ── 4. Chat panel — header dropdown, left-column width ─────────── */
.chat-panel-header-drop {
  /* Positioned relative to results-view, not the viewport */
  position: sticky !important;
  top: 32px !important; /* just below the sticky header (~32px tall) */
  z-index: 190 !important;
  /* Width matches panel-left = 60% of results-columns minus its padding */
  width: calc(60% - 7px) !important;
  margin: 0 14px 8px !important;
  /* Override full-width panel styles */
  border-radius: 0 0 16px 16px !important;
  border-top: none !important;
  box-shadow: 0 8px 24px rgba(45, 31, 38, 0.12) !important;
  background: var(--color-bg-surface, #FAF5F0) !important;
  border: 1px solid var(--color-border, #E8D5C4) !important;
  border-top: none !important;
  padding: 0 !important;
  /* Animate open */
  animation: chat-drop-in 0.22s ease forwards;
  max-height: 520px;
  display: flex;
  flex-direction: column;
}

@keyframes chat-drop-in {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Inner padding on the drop panel */
.chat-panel-header-drop .chat-panel-header {
  padding: 10px 14px 8px;
  border-bottom: 1px solid var(--color-border-light, #F0E0D8);
  display: flex;
  align-items: center;
  gap: 8px;
}

.chat-panel-header-drop .chat-panel-title {
  flex: 1;
  font-size: 12px;
  gap: 6px;
}

.chat-panel-header-drop .chat-header-logo {
  height: 14px !important;
}

.chat-panel-header-drop .chat-panel-label {
  font-size: 9px;
  display: none; /* hidden in compact drop mode — title line is enough */
}

/* Close button inside panel header */
.chat-panel-close {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 16px;
  color: var(--color-text-muted, #B8909A);
  padding: 2px 4px;
  line-height: 1;
  border-radius: 4px;
  transition: background 0.15s;
  flex-shrink: 0;
}

.chat-panel-close:hover {
  background: var(--color-bg-warm, #F5EDE6);
  color: var(--color-text, #2D1F26);
}

.chat-panel-header-drop .chat-disclaimer {
  margin: 8px 14px;
  font-size: 11px;
  padding: 8px 12px;
}

.chat-panel-header-drop .chat-messages {
  flex: 1;
  max-height: 280px;
  padding: 8px 14px 4px;
}

.chat-panel-header-drop .chat-suggestions {
  padding: 0 14px;
  margin-bottom: 8px;
}

.chat-panel-header-drop .chat-input-row {
  padding: 0 14px 12px;
  margin-top: 8px;
}

.chat-panel-header-drop .chat-turn-limit-msg {
  padding: 0 14px 10px;
  margin-top: 0;
}

/* ── 5. Responsive — narrow screens ────────────────────────────────*/
@media (max-width: 960px) {
  .chat-panel-header-drop {
    width: calc(100% - 28px) !important;
  }
}

@media (max-width: 600px) {
  .chat-header-btn-label {
    display: none; /* icon only on very small screens */
  }
  .chat-panel-header-drop {
    width: calc(100% - 28px) !important;
    border-radius: 0 0 12px 12px !important;
    max-height: 400px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   SCREEN 1 REDESIGN v2 — Cream / rose marketing-site palette
   Matches vasus.ai homepage exactly: cream bg, rose accents,
   Playfair Display headline, marketing nav.
   ═══════════════════════════════════════════════════════════════ */

/* ── Remove old screen-inner centering for screen 1 ─────────── */
#input-screen-1 { overflow: visible !important; }
#input-screen-1 > .screen-inner { display: none; }

/* ── Nav bar — exact marketing site style ───────────────────── */
.s1-nav-bar {
  position: sticky;
  top: 0;
  z-index: 200;
  background: rgba(248,242,237,0.97);
  backdrop-filter: blur(12px) saturate(1.2);
  -webkit-backdrop-filter: blur(12px) saturate(1.2);
  border-bottom: 1px solid var(--border, #E8D8DC);
}
.s1-nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 48px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.s1-nav-logo-link { display: flex; align-items: center; }
.s1-nav-logo-img  { height: 40px; width: auto; display: block; }
.s1-nav-links {
  display: flex;
  align-items: center;
  gap: 32px;
}
.s1-nav-links a {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--text-2, #5A3A48);
  letter-spacing: 0.01em;
  transition: color 0.2s;
  position: relative;
  padding-bottom: 2px;
  text-decoration: none;
}
.s1-nav-links a::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0; right: 0;
  height: 2px;
  background: var(--rose, #BB4966);
  transform: scaleX(0);
  transition: transform 0.2s ease;
  transform-origin: left;
}
.s1-nav-links a:hover         { color: var(--rose, #BB4966); }
.s1-nav-links a:hover::after  { transform: scaleX(1); }

/* ── Hero band ───────────────────────────────────────────────── */
.s1-hero {
  background: var(--cream, #F8F2ED);
  padding: 64px 0 48px;
}
.s1-hero-inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 48px;
}

/* Eyebrow — matches .hero-eyebrow from marketing */
.s1-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--rose, #BB4966);
  margin-bottom: 20px;
}
.s1-eyebrow::before {
  content: '';
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--rose, #BB4966);
  flex-shrink: 0;
}

/* Headline — matches .hero-h1 from marketing */
.s1-headline {
  font-family: var(--font-display, 'Playfair Display', Georgia, serif);
  font-size: clamp(36px, 5.5vw, 62px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--deep, #2D1F26);
  margin-bottom: 20px;
}
.s1-headline em {
  font-style: italic;
  color: var(--rose, #BB4966);
}

.s1-subhead {
  font-size: clamp(14px, 1.35vw, 17px);
  color: var(--text-2, #5A3A48);
  line-height: 1.75;
  max-width: 640px;
  margin-bottom: 8px;
}
.s1-disclaimer-text {
  font-size: 11.5px;
  color: var(--muted, #B8909A);
  margin-bottom: 28px;
}

/* Feature bullets — uses rose dot, matches homepage feel */
.s1-features {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 9px;
  margin-bottom: 0;
}
.s1-features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13.5px;
  color: var(--text-2, #5A3A48);
  line-height: 1.55;
}
.s1-feat-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--rose, #BB4966);
  flex-shrink: 0;
  margin-top: 6px;
}

/* ── Selector band — white card on cream ─────────────────────── */
.s1-select-band {
  background: var(--cream-2, #FDF8F4);
  border-top: 1px solid var(--border, #E8D8DC);
  padding: 36px 0 48px;
}

.s1-select-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--muted, #B8909A);
  margin-bottom: 16px;
}

/* ── 5 horizontal sensitivity buttons ───────────────────────── */
.s1-sens-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.s1-sens-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex: 1;
  min-width: 140px;
  padding: 13px 16px;
  background: #fff;
  border: 1.5px solid var(--border, #E8D8DC);
  border-radius: 14px;
  cursor: pointer;
  font-family: inherit;
  transition: border-color 0.18s, background 0.18s, box-shadow 0.18s, transform 0.12s;
  text-align: left;
}
.s1-sens-btn:hover {
  border-color: var(--rose, #BB4966);
  background: var(--rose-light, #F9EFF3);
  box-shadow: 0 2px 12px rgba(187,73,102,0.10);
  transform: translateY(-1px);
}
.s1-sens-btn[data-selected="true"] {
  background: var(--rose, #BB4966);
  border-color: var(--rose, #BB4966);
  box-shadow: 0 4px 16px rgba(187,73,102,0.25);
}
.s1-sens-text {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-2, #5A3A48);
  line-height: 1.3;
}
.s1-sens-btn:hover .s1-sens-text {
  color: var(--rose, #BB4966);
}
.s1-sens-btn[data-selected="true"] .s1-sens-text {
  color: #fff;
}
.s1-sens-icon {
  font-size: 18px;
  flex-shrink: 0;
}

/* ── Next button ─────────────────────────────────────────────── */
.s1-next-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
}

/* Override any theme version of s1-next-btn */
#input-screen-1 .s1-next-btn {
  background: var(--rose, #BB4966) !important;
  color: #fff !important;
  border: none !important;
  padding: 13px 30px;
  border-radius: 100px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.01em;
  cursor: pointer;
  font-family: inherit;
  box-shadow: 0 4px 16px rgba(187,73,102,0.28);
  transition: background 0.2s, transform 0.15s, box-shadow 0.2s, opacity 0.2s;
}
#input-screen-1 .s1-next-btn:disabled {
  opacity: 0.38;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}
#input-screen-1 .s1-next-btn:not(:disabled):hover {
  background: var(--rose-hover, #A33D59) !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(187,73,102,0.32);
}
.s1-hint {
  font-size: 12.5px;
  color: var(--muted, #B8909A);
  font-style: italic;
  transition: opacity 0.3s;
}

/* Progress dots */
#input-screen-1 .s1-progress-row { margin-bottom: 20px; }
#input-screen-1 .s1-dot { background: var(--border, #E8D8DC); }
#input-screen-1 .s1-dot-active { background: var(--salmon, #FF9D78); }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .s1-hero-inner { padding: 0 32px; }
  .s1-nav-inner  { padding: 0 32px; }
}
@media (max-width: 768px) {
  .s1-nav-links { gap: 20px; }
  .s1-nav-links a { font-size: 12.5px; }
  .s1-sens-btn  { min-width: calc(50% - 5px); flex: none; }
  .s1-next-wrap { flex-direction: column; align-items: flex-start; gap: 8px; }
  .s1-hero      { padding: 40px 0 32px; }
  .s1-hero-inner { padding: 0 20px; }
  .s1-nav-inner  { padding: 0 20px; }
}
@media (max-width: 540px) {
  .s1-nav-links a:not(:last-child) { display: none; }
  .s1-sens-btn { min-width: 100%; flex: none; }
}


/* ═══════════════════════════════════════════════════════════════
   LAUNCH — Beta badge + legal footer styles
   ═══════════════════════════════════════════════════════════════ */

/* ── Beta badge — shown in nav/header area ───────────────────── */
.beta-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 9px;
  background: rgba(255,157,120,0.15);
  border: 1px solid rgba(255,157,120,0.35);
  border-radius: 100px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--salmon, #FF9D78);
  vertical-align: middle;
  margin-left: 8px;
  flex-shrink: 0;
}

/* Dark background variant (for use in result panels, EHSPI headers etc.) */
.beta-badge-dark {
  background: rgba(187,73,102,0.15);
  border-color: rgba(187,73,102,0.3);
  color: var(--rose, #BB4966);
}

/* ── Legal footer — bottom of the SPA ───────────────────────── */
.legal-footer {
  border-top: 1px solid var(--color-border, #E8D8DC);
  padding: 20px 24px;
  text-align: center;
  background: var(--color-bg-warm, #FAF4EF);
}

.legal-footer-links {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 6px 18px;
  margin-bottom: 8px;
}

.legal-footer-links a {
  font-size: 12px;
  color: var(--color-text-muted, #B8909A);
  text-decoration: none;
  transition: color 0.15s;
}
.legal-footer-links a:hover { color: var(--color-primary, #BB4966); }

.legal-footer-sep {
  font-size: 12px;
  color: var(--color-border, #E8D8DC);
}

.legal-footer-copy {
  font-size: 11px;
  color: var(--color-text-muted, #B8909A);
  line-height: 1.6;
}

.legal-footer-copy a {
  color: var(--color-primary, #BB4966);
  text-decoration: underline;
}

/* ── Launch banner — site-under-construction notice ─────────── */
.launch-banner {
  background: var(--deep-2, #1A1018);
  color: rgba(253,248,244,0.65);
  font-size: 12px;
  text-align: center;
  padding: 9px 16px;
  line-height: 1.5;
}
.launch-banner a {
  color: var(--salmon, #FF9D78);
  text-decoration: underline;
}

/* ── Disclaimer strip — shown below results ─────────────────── */
.disclaimer-strip {
  background: var(--color-bg-warm, #FAF4EF);
  border: 1px solid var(--color-border, #E8D8DC);
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 12px;
  color: var(--color-text-muted, #B8909A);
  line-height: 1.6;
  margin: 16px 0;
}
.disclaimer-strip strong { color: var(--color-text, #2D1F26); }
.disclaimer-strip a { color: var(--color-primary, #BB4966); text-decoration: underline; }

/* ── ICO / compliance notice inline ─────────────────────────── */
.compliance-note {
  font-size: 11px;
  color: var(--color-text-muted, #B8909A);
  display: flex;
  align-items: flex-start;
  gap: 6px;
  line-height: 1.55;
  margin-top: 8px;
}
.compliance-note a { color: var(--color-primary, #BB4966); }

/* ── Privacy link in nav + legal footer (Screen 1) ──────────── */
.s1-nav-privacy {
  font-size: 12px !important;
  color: rgba(253,248,244,0.3) !important;
  letter-spacing: 0 !important;
  font-weight: 500 !important;
}
.s1-nav-privacy:hover { color: var(--rose, #BB4966) !important; }

.s1-legal-footer {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 32px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.07);
  font-size: 11.5px;
  color: rgba(253,248,244,0.25);
}
.s1-legal-footer a {
  color: rgba(253,248,244,0.35);
  transition: color 0.15s;
}
.s1-legal-footer a:hover { color: rgba(253,248,244,0.7); }
/* ── Screen 1 footer links ───────────────────────────────────── */
.s1-footer-links {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.07);
}
.s1-footer-links a {
  font-size: 11.5px;
  color: rgba(253,248,244,0.35);
  font-weight: 500;
  transition: color 0.15s;
  text-decoration: none;
}
.s1-footer-links a:hover {
  color: rgba(253,248,244,0.7);
}

/* ════════════════════════════════════════════════════════════════
   SCREEN 1 REDESIGN v2 — cream/rose palette, dark text on light bg
   ════════════════════════════════════════════════════════════════ */

#input-screen-1.input-screen {
  background: var(--cream, #F8F2ED) !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

/* ── Nav bar ─────────────────────────────────────────────────── */
.s1-nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 32px;
  border-bottom: 1px solid var(--border, #E8D8DC);
  background: var(--cream-2, #FDF8F4);
  flex-shrink: 0;
}
.s1-nav-links { display: flex; align-items: center; gap: 24px; }
.s1-nav-links a {
  font-size: 13px; font-weight: 600; color: var(--text-3, #7A4A5A);
  transition: color 0.15s;
}
.s1-nav-links a:hover { color: var(--rose, #BB4966); }
.s1-nav-cta {
  background: var(--rose, #BB4966) !important; color: #fff !important;
  padding: 7px 16px !important; border-radius: 100px !important;
  font-size: 12.5px !important;
}

/* ── Shared inner ────────────────────────────────────────────── */
.s1-inner { max-width: 900px; margin: 0 auto; padding: 0 32px; width: 100%; }

/* ── Hero band ───────────────────────────────────────────────── */
.s1-hero-band { background: var(--cream, #F8F2ED); padding: 40px 0 32px; flex-shrink: 0; }

.s1-eyebrow {
  font-size: 10.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--rose, #BB4966); margin-bottom: 16px;
  display: flex; align-items: center; gap: 10px;
}
.s1-eyebrow::before {
  content: ''; display: block; width: 22px; height: 1.5px;
  background: var(--rose, #BB4966); flex-shrink: 0;
}

.s1-headline {
  font-family: var(--font-display, 'Playfair Display', Georgia, serif) !important;
  font-size: clamp(36px, 5.5vw, 60px) !important;
  font-weight: 700 !important; line-height: 1.06 !important;
  letter-spacing: -0.025em !important;
  color: var(--deep, #2D1F26) !important;
  margin-bottom: 18px !important; max-width: 700px !important;
}
.s1-headline em { font-style: italic; color: var(--rose, #BB4966); }

.s1-subhead {
  font-size: clamp(14px, 1.3vw, 16px); color: var(--text-2, #5A3A48);
  line-height: 1.75; max-width: 620px; margin-bottom: 8px;
}
.s1-disclaimer {
  font-size: 11.5px; color: var(--muted, #B8909A);
  font-style: italic; margin-bottom: 22px;
}

/* ── Feature bullets ─────────────────────────────────────────── */
.s1-features { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.s1-features li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13px; color: var(--text-3, #7A4A5A); line-height: 1.55;
}
.s1-feat-icon { font-size: 14px; flex-shrink: 0; margin-top: 1px; }

/* ── Selector band ───────────────────────────────────────────── */
.s1-select-band {
  background: var(--cream-2, #FDF8F4);
  border-top: 1px solid var(--border, #E8D8DC);
  padding: 28px 0 40px; flex: 1;
}
.s1-select-label {
  font-size: 10.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--muted, #B8909A); margin-bottom: 14px; margin-top: 4px;
}

/* ── Sensitivity row ─────────────────────────────────────────── */
.s1-sens-row { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 22px; }

.s1-sens-btn {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; flex: 1; min-width: 140px;
  padding: 12px 14px;
  background: var(--cream, #F8F2ED);
  border: 1.5px solid var(--border, #E8D8DC);
  border-radius: 12px; cursor: pointer; font-family: inherit; text-align: left;
  transition: background 0.15s, border-color 0.15s, transform 0.12s;
}
.s1-sens-btn:hover {
  background: var(--rose-light, #F9EFF3);
  border-color: var(--rose, #BB4966); transform: translateY(-1px);
}
.s1-sens-btn[data-selected="true"] {
  background: var(--rose-light, #F9EFF3);
  border-color: var(--rose, #BB4966);
  box-shadow: 0 2px 10px rgba(187,73,102,0.12);
}
.s1-sens-text { font-size: 13px; font-weight: 600; color: var(--text-2, #5A3A48); line-height: 1.35; }
.s1-sens-btn[data-selected="true"] .s1-sens-text { color: var(--rose, #BB4966); }
.s1-sens-icon { font-size: 18px; flex-shrink: 0; }

/* ── Next button ─────────────────────────────────────────────── */
.s1-next-wrap { display: flex; align-items: center; gap: 16px; }

#input-screen-1 .s1-next-btn {
  background: var(--rose, #BB4966) !important; color: #fff !important;
  border: none !important; padding: 12px 28px !important;
  border-radius: 100px !important; font-size: 14px !important;
  font-weight: 700 !important; cursor: pointer !important;
  transition: opacity 0.2s, transform 0.15s !important;
}
#input-screen-1 .s1-next-btn:disabled { opacity: 0.35 !important; cursor: not-allowed !important; }
#input-screen-1 .s1-next-btn:not(:disabled):hover { opacity: 0.88 !important; transform: translateY(-1px) !important; }
#input-screen-1 .s1-hint { font-size: 12.5px; color: var(--muted, #B8909A); font-style: italic; margin: 0; }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 768px) {
  .s1-nav { padding: 14px 20px; }
  .s1-nav-links a:not(.s1-nav-cta) { display: none; }
  .s1-sens-btn { min-width: calc(50% - 5px); flex: none; }
  .s1-next-wrap { flex-direction: column; align-items: flex-start; gap: 8px; }
  .s1-inner { padding: 0 20px; }
}
@media (max-width: 480px) { .s1-sens-btn { min-width: 100%; flex: none; } }

/* ═══════════════════════════════════════════════════════════════
   REQ-FB-FLOAT — Feedback float CTA (bottom-right, results screen)
   All classes prefixed fb-float- to avoid any collisions
   ═══════════════════════════════════════════════════════════════ */

.fb-float-cta {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 500;
  width: 232px;
  background: #fff;
  border: 1.5px solid var(--border, #E8D8DC);
  border-radius: 18px;
  padding: 16px 18px;
  box-shadow: 0 8px 32px rgba(187,73,102,0.12);
  display: flex;
  flex-direction: column;
  gap: 12px;
  animation: fbFloatIn 0.3s cubic-bezier(0.34,1.56,0.64,1) both;
}

@keyframes fbFloatIn {
  from { opacity: 0; transform: translateY(16px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0)    scale(1);    }
}

.fb-float-label {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted, #B8909A);
}

.fb-float-headline {
  font-size: 13px;
  font-weight: 700;
  color: var(--deep, #2D1F26);
  line-height: 1.4;
  margin-top: -4px;
}

.fb-float-thumbs {
  display: flex;
  gap: 8px;
}

.fb-float-thumb {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  background: #fff;
  border: 1.5px solid var(--border, #E8D8DC);
  border-radius: 12px;
  padding: 11px 6px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, transform 0.12s;
  font-family: inherit;
}

.fb-float-thumb:hover {
  border-color: var(--rose, #BB4966);
  background: var(--rose-light, #F9EFF3);
  transform: translateY(-2px);
}

.fb-float-thumb:active { transform: scale(0.97); }

.fb-float-icon {
  font-size: 26px;
  line-height: 1;
  display: block;
}

.fb-float-tlabel {
  font-size: 10.5px;
  font-weight: 600;
  color: var(--text-2, #5A3A48);
}

.fb-float-dismiss {
  background: none;
  border: none;
  font-size: 11px;
  color: var(--muted, #B8909A);
  cursor: pointer;
  text-align: center;
  padding: 0;
  font-family: inherit;
  transition: color 0.15s;
}

.fb-float-dismiss:hover { color: var(--rose, #BB4966); }

/* Mobile — move above bottom nav area, slightly narrower */
@media (max-width: 680px) {
  .fb-float-cta {
    bottom: 16px;
    right: 12px;
    left: 12px;
    width: auto;
  }
}