/* ═══════════════════════════════════════════════════════════════
   IndustryPulse — Global Styles
   Design system: Mayur Design Universe (Periwinkle / Royal Blue)
   Fonts: Roboto Condensed (display) · Roboto (body) · JetBrains Mono
   Light + Dark via [data-theme]
   ═══════════════════════════════════════════════════════════════ */

/* ── Google Fonts ──────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed:ital,wght@0,100;0,200;0,300;0,400;0,700;1,200;1,300&family=Roboto:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}

/* ── Light Theme (default — Periwinkle) ────────────────────── */
:root,[data-theme="light"]{
  /* Backgrounds — lavender scale */
  --bg-base:        #EAEBF4;   /* page background    */
  --bg-elevated:    #FFFFFF;   /* cards / modals     */
  --bg-subtle:      #E2E3EF;   /* alternating rows   */
  --bg-inverse:     #1A1A2E;   /* inverse / footer   */

  /* Text — navy scale */
  --text-primary:   #1A1A2E;
  --text-secondary: #555578;
  --text-muted:     #4B4B6B;
  --text-inverse:   #EAEBF4;

  /* Accent — Royal Blue */
  --accent:         #2563EB;
  --accent-hover:   #1D53D8;
  --accent-strong:  #3B78F6;
  --accent-glow:    #5B93FF;
  --accent-bg:      rgba(37,99,235,0.07);
  --accent-border:  rgba(37,99,235,0.18);
  --accent-shadow:  0 8px 28px rgba(37,99,235,0.22);

  /* Borders */
  --border:         #CDD0E8;
  --border-strong:  #A0A4C8;
  --tan:            #7070A0;   /* rules, eyebrow support */

  /* Semantic status */
  --red:            #DC2626;
  --red-soft:       #EF4444;
  --red-bg:         rgba(220,38,38,0.07);
  --orange:         #EA580C;
  --orange-soft:    #F97316;
  --orange-bg:      rgba(234,88,12,0.07);
  --green:          #16A34A;
  --green-soft:     #22C55E;
  --green-bg:       rgba(22,163,74,0.07);
  --yellow:         #CA8A04;
  --purple:         #7C3AED;
  --purple-soft:    #8B5CF6;
  --purple-bg:      rgba(124,58,237,0.07);
  --cyan:           #0891B2;
  --cyan-soft:      #06B6D4;
  --cyan-bg:        rgba(8,145,178,0.07);

  /* Spacing & shape */
  --radius-sm:   8px;
  --radius:      12px;
  --radius-lg:   20px;
  --radius-xl:   24px;
  --radius-pill: 999px;

  /* Shadows */
  --shadow-sm:   0 2px  8px rgba(26,26,46,0.06);
  --shadow:      0 4px 20px rgba(26,26,46,0.09);
  --shadow-lg:   0 8px 40px rgba(26,26,46,0.12);
  --shadow-nav:  0 2px 16px rgba(26,26,46,0.10);

  /* Motion */
  --ease:        cubic-bezier(.4,0,.2,1);
  --dur-fast:    160ms;
  --dur:         240ms;
  --dur-slow:    400ms;

  /* Topbar */
  --topbar-bg:   rgba(234,235,244,0.88);
}

/* ── Dark Theme ─────────────────────────────────────────────── */
[data-theme="dark"]{
  --bg-base:        #0D0D1C;
  --bg-elevated:    #161628;
  --bg-subtle:      #1E1E35;
  --bg-inverse:     #08080F;

  --text-primary:   #EAEBF4;
  --text-secondary: #A0A0C8;
  --text-muted:     #7070A0;
  --text-inverse:   #EAEBF4;

  --accent:         #5B93FF;
  --accent-hover:   #6B9FFF;
  --accent-strong:  #3B78F6;
  --accent-glow:    #2563EB;
  --accent-bg:      rgba(91,147,255,0.10);
  --accent-border:  rgba(91,147,255,0.20);
  --accent-shadow:  0 8px 28px rgba(91,147,255,0.20);

  --border:         rgba(205,208,232,0.10);
  --border-strong:  rgba(205,208,232,0.22);
  --tan:            #4848A0;

  --red:            #F87171;
  --red-soft:       #FCA5A5;
  --red-bg:         rgba(239,68,68,0.10);
  --orange:         #FB923C;
  --orange-soft:    #FDBA74;
  --orange-bg:      rgba(251,146,60,0.10);
  --green:          #4ADE80;
  --green-soft:     #86EFAC;
  --green-bg:       rgba(74,222,128,0.10);
  --yellow:         #FDE047;
  --purple:         #A78BFA;
  --purple-soft:    #C4B5FD;
  --purple-bg:      rgba(167,139,250,0.10);
  --cyan:           #22D3EE;
  --cyan-soft:      #67E8F9;
  --cyan-bg:        rgba(34,211,238,0.10);

  --shadow-sm:   0 2px  8px rgba(0,0,0,0.30);
  --shadow:      0 4px 20px rgba(0,0,0,0.40);
  --shadow-lg:   0 8px 40px rgba(0,0,0,0.50);
  --shadow-nav:  0 2px 16px rgba(0,0,0,0.40);
  --topbar-bg:   rgba(13,13,28,0.90);
}

/* ── Base ───────────────────────────────────────────────────── */
body{
  font-family:'Roboto',system-ui,sans-serif;
  background:var(--bg-base);
  color:var(--text-primary);
  line-height:1.6;
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  transition:background var(--dur-slow) var(--ease),color var(--dur-slow) var(--ease);
}

/* Ambient radial gradient — subtle depth */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 50% at 50% -10%,rgba(37,99,235,0.06),transparent),
    radial-gradient(ellipse 50% 40% at 85% 60%,rgba(91,147,255,0.04),transparent);
  transition:opacity var(--dur-slow) var(--ease);
}
[data-theme="dark"] body::before{
  background:
    radial-gradient(ellipse 70% 50% at 50% -10%,rgba(91,147,255,0.10),transparent),
    radial-gradient(ellipse 50% 40% at 85% 60%,rgba(37,99,235,0.06),transparent);
}

/* ── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}

/* ── Layout ─────────────────────────────────────────────────── */
.container{max-width:1440px;margin:0 auto;padding:0 28px;position:relative;z-index:1}
.section{margin-bottom:56px}

/* ── Focus ring (accessibility) ─────────────────────────────── */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

/* ════════════════════════════════════════════════════════════
   TOPBAR — sticky pill nav
   ════════════════════════════════════════════════════════════ */
.topbar{
  position:sticky;top:0;z-index:200;
  background:var(--topbar-bg);
  backdrop-filter:blur(20px) saturate(150%);
  -webkit-backdrop-filter:blur(20px) saturate(150%);
  border-bottom:1px solid var(--border);
  transition:background var(--dur-slow) var(--ease);
}
.topbar-inner{
  max-width:1440px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  height:60px;padding:0 28px;gap:12px;
}

/* Logo */
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{
  width:34px;height:34px;border-radius:10px;
  background:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-family:'Roboto Condensed',sans-serif;
  font-size:14px;font-weight:700;color:#fff;
  letter-spacing:0.5px;
  flex-shrink:0;
}
.logo-text{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:300;font-size:20px;
  letter-spacing:-0.3px;
  color:var(--text-primary);
}
.logo-text em{font-style:normal;color:var(--accent)}

/* Nav pills */
.nav-pills{
  display:flex;gap:2px;
  background:var(--bg-subtle);
  border:1px solid var(--border);
  border-radius:var(--radius-pill);
  padding:4px;flex-shrink:0;
}
.nav-pill{
  padding:6px 16px;border-radius:var(--radius-pill);
  font-family:'Roboto',sans-serif;
  font-size:12px;font-weight:500;letter-spacing:0.04em;text-transform:uppercase;
  color:var(--text-muted);cursor:pointer;
  border:none;background:transparent;
  transition:all var(--dur-fast) var(--ease);white-space:nowrap;
}
.nav-pill:hover{color:var(--text-primary)}
.nav-pill.active{
  background:var(--accent);color:#fff;
  box-shadow:var(--accent-shadow);
}

/* Topbar right controls */
.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}

.live-badge{
  display:flex;align-items:center;gap:5px;
  font-family:'Roboto',sans-serif;font-size:11px;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  color:var(--green);background:var(--green-bg);
  padding:5px 12px;border-radius:var(--radius-pill);
  border:1px solid rgba(22,163,74,0.18);
}
.live-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--green);animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}

.date-badge{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--text-muted);
}

.icon-btn{
  width:36px;height:36px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:var(--bg-elevated);
  color:var(--text-muted);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all var(--dur-fast) var(--ease);flex-shrink:0;
}
.icon-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}
.icon-btn.spinning svg{animation:spin 0.9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Theme toggle */
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
[data-theme="dark"] .theme-toggle .icon-sun{display:block}
[data-theme="dark"] .theme-toggle .icon-moon{display:none}

/* ════════════════════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════════════════════ */
.hero{padding:52px 0 32px;position:relative;z-index:1}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--accent);background:var(--accent-bg);
  padding:5px 14px;border-radius:var(--radius-pill);
  border:1px solid var(--accent-border);margin-bottom:20px;
}
.hero h1{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:200;
  font-size:clamp(38px,5.5vw,72px);
  line-height:1.05;letter-spacing:-1.5px;
  color:var(--text-primary);
  margin-bottom:16px;
}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero-lead{
  font-size:17px;color:var(--text-secondary);
  max-width:580px;line-height:1.65;
}

/* ════════════════════════════════════════════════════════════
   FILTER BAR
   ════════════════════════════════════════════════════════════ */
.year-bar{
  background:var(--bg-elevated);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:12px 20px;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;margin-bottom:24px;flex-wrap:wrap;
  box-shadow:var(--shadow-sm);
}
.year-bar-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.year-bar-label{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--tan);white-space:nowrap;
}
.year-pills{display:flex;gap:4px}
.year-pill{
  padding:6px 18px;border-radius:var(--radius-pill);
  font-family:'Roboto',sans-serif;
  font-size:12px;font-weight:500;letter-spacing:0.04em;text-transform:uppercase;
  color:var(--text-secondary);cursor:pointer;
  border:1px solid var(--border);background:transparent;
  transition:all var(--dur-fast) var(--ease);
}
.year-pill:hover{color:var(--text-primary);border-color:var(--border-strong)}
.year-pill.active{
  background:var(--accent);color:#fff;
  border-color:var(--accent);
  box-shadow:0 2px 8px rgba(37,99,235,0.25);
}
.year-bar-right{display:flex;align-items:center;gap:12px}
.data-version{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--tan);background:var(--bg-subtle);
  padding:3px 8px;border-radius:6px;border:1px solid var(--border);
  white-space:nowrap;
}
.refresh-status{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--text-muted);white-space:nowrap;
  display:flex;align-items:center;gap:5px;
}
.freshness-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}
.freshness-dot.fresh{background:var(--green)}
.freshness-dot.stale{background:var(--orange)}

/* ════════════════════════════════════════════════════════════
   NEWS TICKER
   ════════════════════════════════════════════════════════════ */
.news-ticker{
  background:var(--bg-elevated);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:16px 20px;
  margin-bottom:24px;
  box-shadow:var(--shadow-sm);
}
.news-ticker-header{
  display:flex;align-items:center;gap:8px;margin-bottom:12px;
}
.news-ticker-badge{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;
  background:var(--red-bg);color:var(--red);
  padding:2px 8px;border-radius:4px;border:1px solid rgba(220,38,38,0.15);
}
.news-ticker-title{
  font-family:'Roboto',sans-serif;font-size:13px;font-weight:600;
  color:var(--text-primary);letter-spacing:0.01em;
}
.news-items{
  display:flex;flex-direction:column;gap:6px;
  max-height:180px;overflow-y:auto;
}
.news-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:8px 12px;background:var(--bg-subtle);border-radius:var(--radius);
  font-size:13px;color:var(--text-secondary);line-height:1.4;
  transition:background var(--dur-fast) var(--ease);
  border:1px solid transparent;
}
.news-item:hover{background:var(--bg-elevated);border-color:var(--border)}
.news-item-time{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--text-muted);white-space:nowrap;flex-shrink:0;margin-top:1px;
}
.news-item a{color:var(--accent);text-decoration:none}
.news-item a:hover{text-decoration:underline}
.news-source-tag{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:500;letter-spacing:0.5px;text-transform:uppercase;
  padding:1px 6px;border-radius:4px;
  background:var(--accent-bg);color:var(--accent);
  border:1px solid var(--accent-border);white-space:nowrap;flex-shrink:0;
}

/* ════════════════════════════════════════════════════════════
   KPI CARDS
   ════════════════════════════════════════════════════════════ */
.kpi-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:16px;margin-bottom:40px;
}
.kpi-card{
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-xl);padding:24px;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
/* Accent top stripe */
.kpi-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
}
.kpi-card.k-red::before{background:linear-gradient(90deg,var(--red),var(--orange))}
.kpi-card.k-blue::before{background:linear-gradient(90deg,var(--accent),var(--cyan-soft))}
.kpi-card.k-orange::before{background:linear-gradient(90deg,var(--orange),var(--yellow))}
.kpi-card.k-purple::before{background:linear-gradient(90deg,var(--purple),var(--accent))}
.kpi-card.k-green::before{background:linear-gradient(90deg,var(--green),var(--cyan-soft))}

.kpi-eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--tan);margin-bottom:10px;
}
.kpi-value{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:200;font-size:42px;letter-spacing:-1.5px;line-height:1;
  margin-bottom:6px;
}
.kpi-value.c-red{color:var(--red)}
.kpi-value.c-blue{color:var(--accent)}
.kpi-value.c-orange{color:var(--orange-soft)}
.kpi-value.c-purple{color:var(--purple-soft)}
.kpi-value.c-green{color:var(--green)}
.kpi-sub{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.kpi-sub .up{color:var(--red);font-weight:600}
.kpi-sub .down{color:var(--green);font-weight:600}

/* ════════════════════════════════════════════════════════════
   SECTION HEADERS
   ════════════════════════════════════════════════════════════ */
.section-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;flex-wrap:wrap;gap:12px;
}
.section-title{
  display:flex;align-items:center;gap:10px;
}
.section-title-text{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:300;font-size:26px;letter-spacing:-0.4px;
  color:var(--text-primary);
}
.section-eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--accent);background:var(--accent-bg);
  padding:4px 10px;border-radius:6px;border:1px solid var(--accent-border);
}
.section-icon{
  width:32px;height:32px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;font-size:15px;
}

/* ════════════════════════════════════════════════════════════
   CARDS
   ════════════════════════════════════════════════════════════ */
.card{
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-xl);padding:24px;
  box-shadow:var(--shadow-sm);
  transition:border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease);
}
.card:hover{border-color:var(--border-strong)}
.card-eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--tan);margin-bottom:12px;
}
.card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:16px}
.card-desc{font-size:13px;color:var(--text-muted);margin-bottom:16px;line-height:1.5}

/* ════════════════════════════════════════════════════════════
   CHARTS GRID
   ════════════════════════════════════════════════════════════ */
.charts-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:16px;margin-bottom:32px;
}
.chart-full{grid-column:1/-1}
.chart-container{position:relative;height:240px;width:100%}

/* ════════════════════════════════════════════════════════════
   SEARCH BAR
   ════════════════════════════════════════════════════════════ */
.search-wrap{position:relative;margin-bottom:16px}
.search-bar{
  width:100%;padding:13px 20px 13px 46px;
  background:var(--bg-elevated);
  border:1px solid var(--border);border-radius:var(--radius-pill);
  color:var(--text-primary);
  font-size:14px;font-family:'Roboto',sans-serif;
  outline:none;transition:all var(--dur-fast) var(--ease);
}
.search-bar::placeholder{color:var(--text-muted)}
.search-bar:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.search-icon-el{
  position:absolute;left:16px;top:50%;transform:translateY(-50%);
  color:var(--text-muted);font-size:16px;pointer-events:none;
}
.search-count-el{
  position:absolute;right:16px;top:50%;transform:translateY(-50%);
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--text-muted);background:var(--bg-subtle);
  padding:2px 8px;border-radius:4px;
}
.search-clear-btn{
  display:none;position:absolute;right:88px;top:50%;transform:translateY(-50%);
  width:22px;height:22px;border-radius:6px;border:none;
  background:var(--bg-subtle);color:var(--text-muted);
  cursor:pointer;align-items:center;justify-content:center;font-size:12px;
  transition:all var(--dur-fast) var(--ease);
}
.search-clear-btn:hover{background:var(--red-bg);color:var(--red)}

/* ════════════════════════════════════════════════════════════
   TABLE
   ════════════════════════════════════════════════════════════ */
.table-scroller{overflow-x:auto;border-radius:var(--radius-lg)}
table{width:100%;border-collapse:collapse;font-size:13px}
thead{background:var(--bg-subtle)}
th{
  padding:12px 16px;text-align:left;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:500;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--tan);border-bottom:1px solid var(--border);
  position:sticky;top:0;background:var(--bg-subtle);z-index:2;
}
td{
  padding:13px 16px;border-bottom:1px solid var(--border);
  vertical-align:middle;
}
tr:hover td{background:var(--bg-subtle)}
tr:last-child td{border-bottom:none}
tr.hidden-row{display:none}
.no-results-row td{
  text-align:center;padding:48px;
  color:var(--text-muted);font-size:14px;
}

/* Company cell */
.company-cell{display:flex;align-items:center;gap:10px}
.company-mark{
  width:34px;height:34px;border-radius:var(--radius-sm);
  background:var(--bg-subtle);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-family:'Roboto Condensed',sans-serif;
  font-size:11px;font-weight:700;color:var(--accent);flex-shrink:0;
  letter-spacing:0.5px;
}
.company-name{font-weight:600;color:var(--text-primary);font-size:13px;line-height:1.2}
.company-industry{font-size:11px;color:var(--text-muted)}

.count-severe{color:var(--red);font-weight:700}
.count-moderate{color:var(--orange-soft);font-weight:600}
.count-mild{color:var(--yellow);font-weight:500}

/* Confidence bar */
.conf-track{
  width:56px;height:5px;border-radius:999px;
  background:var(--bg-subtle);overflow:hidden;
  display:inline-block;vertical-align:middle;margin-right:6px;
}
.conf-fill{height:100%;border-radius:999px}

/* Detected badge */
.live-detected-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-family:'JetBrains Mono',monospace;
  font-size:8px;font-weight:600;letter-spacing:0.8px;text-transform:uppercase;
  color:var(--orange);background:var(--orange-bg);
  padding:2px 6px;border-radius:4px;
  border:1px solid rgba(234,88,12,0.20);
}

/* ════════════════════════════════════════════════════════════
   TAGS
   ════════════════════════════════════════════════════════════ */
.tag{
  display:inline-flex;align-items:center;
  padding:3px 8px;border-radius:6px;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:500;letter-spacing:0.5px;text-transform:uppercase;
}
.tag-blue  {background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}
.tag-red   {background:var(--red-bg);color:var(--red-soft);border:1px solid rgba(220,38,38,0.15)}
.tag-orange{background:var(--orange-bg);color:var(--orange-soft);border:1px solid rgba(234,88,12,0.15)}
.tag-green {background:var(--green-bg);color:var(--green-soft);border:1px solid rgba(22,163,74,0.15)}
.tag-purple{background:var(--purple-bg);color:var(--purple-soft);border:1px solid rgba(124,58,237,0.15)}
.tag-cyan  {background:var(--cyan-bg);color:var(--cyan-soft);border:1px solid rgba(8,145,178,0.15)}
.tag-yellow{background:rgba(202,138,4,.08);color:var(--yellow);border:1px solid rgba(202,138,4,0.15)}
.tag-tan   {background:rgba(112,112,160,.08);color:var(--tan);border:1px solid rgba(112,112,160,0.15)}

/* ════════════════════════════════════════════════════════════
   SKILLS HEATMAP
   ════════════════════════════════════════════════════════════ */
.skills-impact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.skills-col-label{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  margin-bottom:14px;display:flex;align-items:center;gap:6px;
}
.skill-bar-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 0;border-bottom:1px solid var(--border);
}
.skill-bar-item:last-child{border-bottom:none}
.skill-label{
  font-size:12px;font-weight:500;color:var(--text-secondary);
  width:150px;flex-shrink:0;text-align:right;
}
.skill-track{
  flex:1;height:22px;background:var(--bg-subtle);
  border-radius:6px;overflow:hidden;
}
.skill-fill{
  height:100%;border-radius:6px;
  display:flex;align-items:center;justify-content:flex-end;
  padding:0 8px;font-family:'JetBrains Mono',monospace;
  font-size:10px;font-weight:700;color:#fff;min-width:44px;
  transition:width 1s var(--ease);
}
.skill-fill.declining{background:linear-gradient(90deg,rgba(220,38,38,.6),var(--red))}
.skill-fill.rising{background:linear-gradient(90deg,rgba(22,163,74,.6),var(--green))}
.skills-legend{display:flex;gap:20px;justify-content:center;margin-bottom:18px}
.skills-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}
.skills-legend-dot{width:9px;height:9px;border-radius:3px;flex-shrink:0}
.skills-legend-dot.declining{background:var(--red)}
.skills-legend-dot.rising{background:var(--green)}

/* ════════════════════════════════════════════════════════════
   SENTIMENT CARDS
   ════════════════════════════════════════════════════════════ */
.sentiment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.sentiment-card{
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-xl);padding:20px;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
  position:relative;overflow:hidden;
}
.sentiment-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.sentiment-card::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:3px;
  border-radius:var(--radius-xl) 0 0 var(--radius-xl);
}
.sentiment-card.high-risk::before{background:var(--red)}
.sentiment-card.med-risk::before{background:var(--orange)}
.sentiment-card.low-risk::before{background:var(--yellow)}

.sentiment-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.sentiment-co{font-weight:700;font-size:15px;color:var(--text-primary)}
.sentiment-score{
  font-family:'JetBrains Mono',monospace;font-weight:700;font-size:13px;
  padding:3px 9px;border-radius:6px;
}
.score-neg{background:var(--red-bg);color:var(--red)}
.score-neu{background:var(--orange-bg);color:var(--orange-soft)}

.risk-meters{display:flex;gap:14px;margin-bottom:12px}
.risk-meter{flex:1}
.risk-meter-label{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.8px;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}
.risk-bar-track{height:6px;border-radius:999px;background:var(--bg-subtle);overflow:hidden}
.risk-bar-fill{height:100%;border-radius:999px}
.risk-bar-fill.layoff{background:linear-gradient(90deg,var(--orange),var(--red))}
.risk-bar-fill.hiring{background:linear-gradient(90deg,var(--yellow),var(--orange))}

.sentiment-themes{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}
.sentiment-signal{
  font-size:12px;color:var(--text-secondary);font-style:italic;
  padding:8px 12px;background:var(--bg-subtle);
  border-radius:var(--radius-sm);border-left:2px solid var(--accent);
  line-height:1.5;
}

/* ════════════════════════════════════════════════════════════
   INSIGHTS PANELS
   ════════════════════════════════════════════════════════════ */
.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(420px,1fr));gap:20px}
.insight-panel{
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm);
}
.insight-panel-head{
  padding:20px 24px;border-bottom:1px solid var(--border);
}
.insight-panel-head h3{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:300;font-size:22px;letter-spacing:-0.3px;
}
.insight-panel-body{padding:20px 24px}
.insight-sub{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--tan);margin:18px 0 10px;
}
.insight-list{list-style:none}
.insight-list li{
  padding:9px 0;border-bottom:1px solid var(--border);
  display:flex;align-items:flex-start;gap:10px;
  font-size:13px;color:var(--text-secondary);line-height:1.5;
}
.insight-list li:last-child{border-bottom:none}
.bullet{width:5px;height:5px;border-radius:50%;margin-top:6px;flex-shrink:0}
.bullet.b-green{background:var(--green)}
.bullet.b-blue{background:var(--accent)}
.bullet.b-orange{background:var(--orange)}
.bullet.b-purple{background:var(--purple)}
.tag-wrap{display:flex;flex-wrap:wrap;gap:6px}

.employer-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:18px}
.employer-metric{
  background:var(--bg-subtle);border-radius:var(--radius-lg);padding:16px;text-align:center;
  border:1px solid var(--border);
}
.employer-metric .em-label{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--tan);margin-bottom:6px;
}
.employer-metric .em-value{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:200;font-size:32px;letter-spacing:-1px;
}

/* ════════════════════════════════════════════════════════════
   RESOURCES
   ════════════════════════════════════════════════════════════ */
.resources-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
.resource-card{
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-xl);padding:22px;
  display:flex;align-items:flex-start;gap:16px;
  text-decoration:none;color:inherit;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur-fast) var(--ease);
  position:relative;overflow:hidden;
}
.resource-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
  border-color:var(--accent);
}
.resource-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--cyan-soft));
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
}
.resource-icon-wrap{
  width:44px;height:44px;border-radius:var(--radius-sm);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:20px;
}
.ri-blue  {background:var(--accent-bg)}
.ri-red   {background:var(--red-bg)}
.ri-green {background:var(--green-bg)}
.ri-orange{background:var(--orange-bg)}
.ri-purple{background:var(--purple-bg)}
.ri-cyan  {background:var(--cyan-bg)}
.ri-tan   {background:rgba(112,112,160,.08)}

.resource-body{flex:1;min-width:0}
.resource-title{
  font-size:15px;font-weight:600;color:var(--text-primary);
  margin-bottom:3px;display:flex;align-items:center;gap:6px;
}
.resource-ext{font-size:11px;color:var(--text-muted)}
.resource-url{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--accent);margin-bottom:6px;
}
.resource-desc{font-size:12px;color:var(--text-secondary);line-height:1.5}
.resource-tags{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}

/* ════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════ */
.footer{
  background:var(--bg-inverse);color:var(--text-inverse);
  border-top:1px solid rgba(205,208,232,0.08);
  padding:40px 0 24px;margin-top:48px;
}
.footer-inner{
  max-width:1440px;margin:0 auto;padding:0 28px;
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
}
.footer-brand{margin-bottom:12px}
.footer-wordmark{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:200;font-size:24px;letter-spacing:-0.3px;
  color:var(--text-inverse);
}
.footer-wordmark em{font-style:normal;color:var(--accent)}
.footer-tagline{font-size:13px;color:rgba(234,235,244,0.50);line-height:1.6;max-width:340px}
.footer-sources-label{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;letter-spacing:1.5px;text-transform:uppercase;
  color:rgba(234,235,244,0.35);margin-bottom:10px;
}
.footer-source-links{
  display:flex;flex-wrap:wrap;gap:6px;
  font-size:12px;color:rgba(234,235,244,0.50);
  font-family:'Roboto',sans-serif;font-weight:400;
}
.footer-source-links a{
  font-size:12px;color:rgba(234,235,244,0.50);
  text-decoration:none;
  transition:color var(--dur-fast) var(--ease);
}
.footer-source-links a:hover{color:var(--accent)}
.footer-meta{
  max-width:1440px;margin:0 auto;
  padding:20px 28px 0;
  border-top:1px solid rgba(205,208,232,0.07);
  margin-top:32px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px;
}
.footer-copy{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.8px;text-transform:uppercase;
  color:rgba(234,235,244,0.25);
}
.footer-credit{font-size:12px;color:rgba(234,235,244,0.45)}
.footer-credit a{color:var(--accent);text-decoration:none;font-weight:500}
.footer-credit a:hover{text-decoration:underline}

/* ════════════════════════════════════════════════════════════
   ANIMATIONS
   ════════════════════════════════════════════════════════════ */
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(16px)}
  to{opacity:1;transform:translateY(0)}
}
.animate-in{animation:fadeInUp 0.5s var(--ease) both;opacity:0}
.d1{animation-delay:0.05s}.d2{animation-delay:0.10s}
.d3{animation-delay:0.15s}.d4{animation-delay:0.20s}
.d5{animation-delay:0.25s}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .skills-impact-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
}
@media(max-width:900px){
  .charts-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .container{padding:0 16px}
  .topbar-inner{height:52px;padding:0 16px}
  .nav-pills{display:none}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .charts-grid{grid-template-columns:1fr}
  .chart-container{height:220px}
  .hero h1{font-size:36px}
  .insights-grid{grid-template-columns:1fr}
  .footer-inner{gap:24px}
  .date-badge,.live-badge{display:none}
  .data-version{display:none}
}
@media(max-width:480px){
  .kpi-grid{grid-template-columns:1fr}
  .year-pills{flex-wrap:wrap}
  .footer-meta{flex-direction:column;text-align:center}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .animate-in{opacity:1}
}

/* ════════════════════════════════════════════════════════════
   WEEKLY MARKET INTELLIGENCE PANEL
   ════════════════════════════════════════════════════════════ */
.intel-panel{
  background:var(--bg-elevated);
  border:1px solid var(--accent-border);
  border-radius:var(--radius-xl);
  padding:28px;margin-bottom:32px;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow);
}
.intel-panel::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--cyan-soft),var(--purple-soft));
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
}
.intel-panel-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;flex-wrap:wrap;gap:12px;
}
.intel-title{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:200;font-size:24px;letter-spacing:-0.3px;
  color:var(--text-primary);
}
.intel-date{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-muted)}
.intel-stat-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:14px;margin-bottom:20px;
}
.intel-stat{
  background:var(--bg-subtle);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:14px;text-align:center;
}
.intel-stat-label{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--tan);margin-bottom:6px;
}
.intel-stat-val{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:200;font-size:28px;letter-spacing:-1px;color:var(--accent);
}
.intel-stat-val.v-red   {color:var(--red)}
.intel-stat-val.v-green {color:var(--green)}
.intel-stat-val.v-orange{color:var(--orange)}
.intel-stat-val.v-purple{color:var(--purple-soft)}
.intel-narrative{
  font-size:14px;color:var(--text-secondary);line-height:1.75;
  padding:16px 20px;background:var(--accent-bg);
  border-radius:var(--radius-lg);border-left:3px solid var(--accent);
}
.intel-narrative strong{color:var(--accent)}

/* ════════════════════════════════════════════════════════════
   OPPORTUNITY BRIDGE — Hiring Leaders
   ════════════════════════════════════════════════════════════ */
.opp-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));
  gap:16px;
}
.opp-card{
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-xl);padding:20px;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur-fast) var(--ease);
}
.opp-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--green)}
.opp-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--green),var(--cyan-soft));
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
}
.opp-card-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:8px}
.opp-company{font-weight:700;font-size:15px;color:var(--text-primary)}
.opp-industry{font-size:11px;color:var(--text-muted);margin-top:2px}
.opp-badge{
  font-family:'JetBrains Mono',monospace;
  font-size:8px;font-weight:600;letter-spacing:0.8px;text-transform:uppercase;
  padding:3px 8px;border-radius:var(--radius-pill);white-space:nowrap;flex-shrink:0;
}
.ob-ai    {background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}
.ob-green {background:var(--green-bg);color:var(--green-soft);border:1px solid rgba(22,163,74,.20)}
.ob-purple{background:var(--purple-bg);color:var(--purple-soft);border:1px solid rgba(124,58,237,.20)}
.ob-orange{background:var(--orange-bg);color:var(--orange-soft);border:1px solid rgba(234,88,12,.20)}
.ob-cyan  {background:var(--cyan-bg);color:var(--cyan-soft);border:1px solid rgba(8,145,178,.20)}

.opp-metrics{display:flex;gap:20px;margin-bottom:14px}
.opp-metric-val{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:200;font-size:28px;color:var(--green);letter-spacing:-0.5px;
}
.opp-metric-label{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;color:var(--tan);text-transform:uppercase;letter-spacing:0.8px;margin-top:2px;
}
.opp-roles{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}
.opp-from-label{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;letter-spacing:0.8px;text-transform:uppercase;
  color:var(--tan);margin-bottom:5px;
}
.opp-from-tags{display:flex;flex-wrap:wrap;gap:4px}

/* ════════════════════════════════════════════════════════════
   COMPANY HEALTH SCORES
   ════════════════════════════════════════════════════════════ */
.health-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:14px;
}
.health-card{
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-xl);padding:18px;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.health-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.health-card.h-leader ::before,
.health-card.h-stable ::before,
.health-card.h-caution::before,
.health-card.h-risk   ::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:3px;
  border-radius:var(--radius-xl) 0 0 var(--radius-xl);
}
.health-card.h-leader ::before{background:var(--green)}
.health-card.h-stable ::before{background:var(--accent)}
.health-card.h-caution::before{background:var(--orange)}
.health-card.h-risk   ::before{background:var(--red)}
.health-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px;gap:8px}
.health-company{font-weight:700;font-size:14px;color:var(--text-primary)}
.health-industry{font-size:11px;color:var(--text-muted);margin-top:2px}
.health-score{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:200;font-size:38px;letter-spacing:-1.5px;
  line-height:1;flex-shrink:0;
}
.hs-green {color:var(--green)}
.hs-blue  {color:var(--accent)}
.hs-orange{color:var(--orange)}
.hs-red   {color:var(--red)}
.health-badge{
  display:inline-flex;align-items:center;
  font-family:'JetBrains Mono',monospace;
  font-size:8px;font-weight:600;letter-spacing:0.8px;text-transform:uppercase;
  padding:2px 7px;border-radius:var(--radius-pill);margin-bottom:10px;
}
.hb-green {background:var(--green-bg);color:var(--green-soft);border:1px solid rgba(22,163,74,.20)}
.hb-blue  {background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}
.hb-orange{background:var(--orange-bg);color:var(--orange-soft);border:1px solid rgba(234,88,12,.20)}
.hb-red   {background:var(--red-bg);color:var(--red-soft);border:1px solid rgba(220,38,38,.15)}
.health-metrics{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.hm-item{background:var(--bg-subtle);border-radius:var(--radius-sm);padding:8px;border:1px solid var(--border)}
.hm-label{font-family:'JetBrains Mono',monospace;font-size:8px;letter-spacing:0.8px;text-transform:uppercase;color:var(--tan);margin-bottom:3px}
.hm-value{font-size:12px;font-weight:600;color:var(--text-primary)}

/* ════════════════════════════════════════════════════════════
   INDUSTRY SAFETY INDEX
   ════════════════════════════════════════════════════════════ */
.safety-table{width:100%;border-collapse:collapse;font-size:13px}
.safety-table th{
  padding:10px 16px;text-align:left;
  font-family:'JetBrains Mono',monospace;font-size:9px;
  font-weight:500;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--tan);border-bottom:1px solid var(--border);
  background:var(--bg-subtle);position:sticky;top:0;z-index:2;
}
.safety-table td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
.safety-table tr:hover td{background:var(--bg-subtle)}
.safety-table tr:last-child td{border-bottom:none}
.safety-status{
  display:inline-flex;align-items:center;gap:5px;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:600;letter-spacing:0.8px;text-transform:uppercase;
  padding:4px 10px;border-radius:var(--radius-pill);
}
.ss-growing  {background:var(--green-bg);color:var(--green-soft);border:1px solid rgba(22,163,74,.20)}
.ss-stable   {background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}
.ss-caution  {background:var(--orange-bg);color:var(--orange-soft);border:1px solid rgba(234,88,12,.20)}
.ss-declining{background:var(--red-bg);color:var(--red-soft);border:1px solid rgba(220,38,38,.15)}
.safety-score-wrap{display:flex;align-items:center;gap:8px}
.score-track{width:72px;height:5px;border-radius:999px;background:var(--bg-subtle);overflow:hidden;display:inline-block;flex-shrink:0}
.score-fill{height:100%;border-radius:999px}
.score-fill.growing  {background:linear-gradient(90deg,var(--green),var(--cyan-soft))}
.score-fill.stable   {background:linear-gradient(90deg,var(--accent),var(--cyan-soft))}
.score-fill.caution  {background:linear-gradient(90deg,var(--orange),var(--yellow))}
.score-fill.declining{background:linear-gradient(90deg,var(--red),var(--orange))}

/* ════════════════════════════════════════════════════════════
   TALENT SUPPLY POOL
   ════════════════════════════════════════════════════════════ */
.supply-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.supply-item{
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:16px;
  display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-sm);
}
.supply-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.supply-role{font-weight:600;font-size:13px;color:var(--text-primary)}
.supply-count{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:200;font-size:22px;letter-spacing:-0.5px;
}
.supply-count.surplus{color:var(--accent)}
.supply-count.deficit{color:var(--green)}
.supply-bar-track{height:5px;border-radius:999px;background:var(--bg-subtle);overflow:hidden}
.supply-bar-fill{height:100%;border-radius:999px;transition:width 1s var(--ease)}
.supply-bar-fill.surplus{background:linear-gradient(90deg,var(--accent),var(--cyan-soft))}
.supply-bar-fill.deficit{background:linear-gradient(90deg,var(--green),var(--cyan-soft))}
.supply-meta{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text-muted)}
.supply-tag{
  font-family:'JetBrains Mono',monospace;font-size:8px;font-weight:600;
  letter-spacing:0.8px;text-transform:uppercase;padding:2px 6px;border-radius:4px;
}
.supply-tag.surplus{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}
.supply-tag.deficit{background:var(--green-bg);color:var(--green-soft);border:1px solid rgba(22,163,74,.20)}

/* ════════════════════════════════════════════════════════════
   WATCHLIST FAB + PANEL
   ════════════════════════════════════════════════════════════ */
.watchlist-btn{
  width:24px;height:24px;border-radius:6px;border:none;
  background:transparent;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:15px;color:var(--text-muted);
  transition:all var(--dur-fast) var(--ease);
  vertical-align:middle;
}
.watchlist-btn:hover{color:var(--accent);background:var(--accent-bg)}
.watchlist-btn.w-active{color:var(--accent)}

.watchlist-fab{
  position:fixed;right:20px;bottom:20px;z-index:600;
  width:50px;height:50px;border-radius:50%;
  background:var(--accent);color:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:20px;
  box-shadow:var(--accent-shadow);
  transition:transform var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease);
}
.watchlist-fab:hover{transform:scale(1.10);background:var(--accent-hover)}
.wl-count{
  position:absolute;top:-4px;right:-4px;
  min-width:18px;height:18px;padding:0 4px;
  border-radius:999px;background:var(--red);color:#fff;
  font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--bg-base);
}

.watchlist-panel{
  position:fixed;right:20px;bottom:80px;width:290px;
  max-height:400px;
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);
  z-index:600;overflow:hidden;flex-direction:column;
  display:none;
}
.watchlist-panel.wl-open{display:flex}
.wl-head{
  padding:14px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.wl-head-title{font-weight:600;font-size:13px;color:var(--text-primary)}
.wl-close{
  width:24px;height:24px;border-radius:6px;
  border:1px solid var(--border);background:transparent;
  color:var(--text-muted);cursor:pointer;font-size:12px;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur-fast) var(--ease);
}
.wl-close:hover{background:var(--red-bg);color:var(--red);border-color:rgba(220,38,38,.20)}
.wl-body{padding:8px;overflow-y:auto;flex:1}
.wl-item{
  padding:10px 12px;border-radius:var(--radius-sm);
  display:flex;align-items:center;gap:10px;
  transition:background var(--dur-fast) var(--ease);cursor:default;
}
.wl-item:hover{background:var(--bg-subtle)}
.wl-item-mark{
  width:30px;height:30px;border-radius:var(--radius-sm);
  background:var(--accent-bg);border:1px solid var(--accent-border);
  display:flex;align-items:center;justify-content:center;
  font-family:'Roboto Condensed',sans-serif;
  font-size:10px;font-weight:700;color:var(--accent);flex-shrink:0;
}
.wl-item-name{font-weight:600;font-size:13px;color:var(--text-primary);flex:1}
.wl-item-ind{font-size:11px;color:var(--text-muted)}
.wl-empty{padding:32px;text-align:center;color:var(--text-muted);font-size:13px}

/* ════════════════════════════════════════════════════════════
   CAREER RISK SCORE (in Insights)
   ════════════════════════════════════════════════════════════ */
.risk-context-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}
.risk-ctx-item{
  background:var(--bg-subtle);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:14px;text-align:center;
}
.risk-ctx-label{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--tan);margin-bottom:6px;
}
.risk-ctx-val{
  font-family:'Roboto Condensed',sans-serif;
  font-weight:200;font-size:26px;letter-spacing:-0.8px;
}

/* ════════════════════════════════════════════════════════════
   UX DESIGN INTELLIGENCE
   ════════════════════════════════════════════════════════════ */

/* Impact stat row */
.ux-impact-stats{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(148px,1fr));
  gap:12px;
  margin-bottom:28px;
}
.ux-stat-card{
  background:var(--bg-elevated);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:16px;
  text-align:center;
  box-shadow:var(--shadow-sm);
}
.ux-stat-val{
  font-family:'Roboto Condensed',sans-serif;
  font-size:26px;font-weight:200;letter-spacing:-0.5px;
  margin-bottom:6px;
}
.ux-stat-lbl{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;text-transform:uppercase;letter-spacing:0.8px;
  color:var(--text-muted);line-height:1.5;
}

/* Skills Matrix — two-column */
.ux-skills-section{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:32px;
}
.ux-skills-col{
  background:var(--bg-elevated);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.ux-col-head{
  display:flex;align-items:center;gap:8px;
  padding:11px 16px;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;
}
.ux-col-decline{
  background:var(--red-bg);color:var(--red);
  border-bottom:1px solid rgba(220,38,38,.15);
}
.ux-col-rise{
  background:var(--green-bg);color:var(--green-soft);
  border-bottom:1px solid rgba(22,163,74,.15);
}
.ux-skill-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:2px 12px;
  padding:10px 16px;
  border-bottom:1px solid var(--border);
  align-items:start;
}
.ux-skill-row:last-child{border-bottom:none}
.ux-skill-name{
  font-size:13px;font-weight:500;color:var(--text-primary);
  grid-column:1;grid-row:1;
}
.ux-skill-change{
  font-family:'JetBrains Mono',monospace;
  font-size:12px;font-weight:700;
  grid-column:2;grid-row:1;white-space:nowrap;
}
.ux-skill-change.decline{color:var(--red)}
.ux-skill-change.rise{color:var(--green-soft)}
.ux-skill-note{
  font-size:11px;color:var(--text-muted);line-height:1.45;
  grid-column:1 / -1;grid-row:2;
}

/* Role Safety */
.ux-subsection{margin-bottom:32px}
.ux-subsection-title{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;
  color:var(--text-muted);margin-bottom:14px;
}
.ux-role-row{
  display:flex;align-items:center;gap:16px;
  padding:11px 0;
  border-bottom:1px solid var(--border);
}
.ux-role-row:last-child{border-bottom:none}
.ux-role-left{flex:1;min-width:0}
.ux-role-name{
  font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:7px;
}
.ux-role-bar-track{
  height:4px;border-radius:999px;
  background:var(--bg-subtle);overflow:hidden;
}
.ux-role-bar-fill{
  height:100%;border-radius:999px;
  transition:width 1.1s var(--ease);
}
.ux-role-right{
  display:flex;flex-direction:column;align-items:flex-end;gap:4px;
  flex-shrink:0;min-width:76px;
}
.ux-role-score{
  font-family:'Roboto Condensed',sans-serif;
  font-size:22px;font-weight:200;color:var(--text-primary);line-height:1;
}
.ux-role-trend{
  font-family:'JetBrains Mono',monospace;
  font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:0.7px;
  padding:2px 7px;border-radius:4px;
}
.rs-growing  {background:var(--green-bg);  color:var(--green-soft);  border:1px solid rgba(22,163,74,.18)}
.rs-stable   {background:var(--accent-bg); color:var(--accent);      border:1px solid var(--accent-border)}
.rs-caution  {background:var(--orange-bg); color:var(--orange);      border:1px solid rgba(234,88,12,.18)}
.rs-risk     {background:var(--red-bg);    color:var(--red);         border:1px solid rgba(220,38,38,.18)}
.rs-declining{background:rgba(220,38,38,.14);color:var(--red);       border:1px solid rgba(220,38,38,.25)}

/* Trend Cards */
.ux-trends-grid{display:flex;flex-direction:column;gap:12px}
.ux-trend-card{
  background:var(--bg-elevated);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:16px 18px;
  box-shadow:var(--shadow-sm);
}
.ux-trend-head{
  display:flex;align-items:center;flex-wrap:wrap;gap:10px;
  margin-bottom:10px;
}
.ux-trend-icon{font-size:20px;line-height:1}
.ux-trend-title{
  font-size:14px;font-weight:600;color:var(--text-primary);flex:1;
}
.ux-trend-body{
  font-size:13px;color:var(--text-secondary);line-height:1.65;
}
/* UX tag variants */
.ux-tag{
  font-family:'JetBrains Mono',monospace;
  font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:0.7px;
  padding:3px 8px;border-radius:4px;white-space:nowrap;
}
.ux-tag-purple{background:var(--purple-bg);     color:var(--purple-soft);  border:1px solid rgba(124,58,237,.20)}
.ux-tag-blue  {background:var(--accent-bg);      color:var(--accent);       border:1px solid var(--accent-border)}
.ux-tag-green {background:var(--green-bg);        color:var(--green-soft);   border:1px solid rgba(22,163,74,.20)}
.ux-tag-orange{background:var(--orange-bg);       color:var(--orange);       border:1px solid rgba(234,88,12,.20)}
.ux-tag-cyan  {background:var(--cyan-bg);         color:var(--cyan-soft);    border:1px solid rgba(8,145,178,.20)}

/* Hiring Grid */
.ux-hiring-grid{display:flex;flex-direction:column;gap:10px}
.ux-hiring-card{
  display:flex;align-items:center;gap:14px;
  background:var(--bg-elevated);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:14px 16px;
  box-shadow:var(--shadow-sm);
}
.ux-hiring-mark{
  width:42px;height:42px;border-radius:10px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:'Roboto Condensed',sans-serif;
  font-size:13px;font-weight:700;
}
.ux-co-ai    {background:var(--accent-bg);   color:var(--accent);      border:1px solid var(--accent-border)}
.ux-co-blue  {background:var(--cyan-bg);     color:var(--cyan-soft);   border:1px solid rgba(8,145,178,.20)}
.ux-co-green {background:var(--green-bg);    color:var(--green-soft);  border:1px solid rgba(22,163,74,.20)}
.ux-co-red   {background:var(--red-bg);      color:var(--red-soft);    border:1px solid rgba(220,38,38,.18)}
.ux-co-purple{background:var(--purple-bg);   color:var(--purple-soft); border:1px solid rgba(124,58,237,.20)}
.ux-hiring-body{flex:1;min-width:0}
.ux-hiring-company{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:3px}
.ux-hiring-roles{font-size:12px;color:var(--text-muted);line-height:1.4}
.ux-hiring-count{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}
.ux-hiring-num{
  font-family:'Roboto Condensed',sans-serif;
  font-size:26px;font-weight:200;color:var(--green-soft);line-height:1;
}
.ux-hiring-lbl{
  font-family:'JetBrains Mono',monospace;
  font-size:8px;text-transform:uppercase;letter-spacing:0.7px;color:var(--text-muted);
}

/* ════════════════════════════════════════════════════════════
   ADDITIONAL RESPONSIVE
   ════════════════════════════════════════════════════════════ */
/* ════════════════════════════════════════════════════════════
   INDIA UX DESIGN MARKET
   ════════════════════════════════════════════════════════════ */

/* GCC Callout */
.ind-gcc-callout{
  background:var(--bg-elevated);
  border:1px solid rgba(22,163,74,.22);
  border-left:4px solid var(--green);
  border-radius:var(--radius-lg);
  padding:18px 20px;
  margin-bottom:28px;
}
.ind-gcc-head{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:10px}
.ind-gcc-icon{font-size:20px}
.ind-gcc-title{font-size:14px;font-weight:600;color:var(--text-primary);flex:1}
.ind-gcc-body{font-size:13px;color:var(--text-secondary);line-height:1.65;margin-bottom:12px}
.ind-gcc-chips{display:flex;flex-wrap:wrap;gap:7px}
.ind-gcc-chip{
  font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;
  padding:3px 9px;border-radius:6px;
  background:var(--green-bg);color:var(--green-soft);
  border:1px solid rgba(22,163,74,.20);
}

/* Salary Table */
.ind-table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}
.ind-sal-table,.ind-risk-table{
  width:100%;border-collapse:collapse;font-size:13px;
}
.ind-sal-table th,.ind-risk-table th{
  font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.8px;color:var(--text-muted);
  padding:10px 16px;text-align:left;background:var(--bg-subtle);
  border-bottom:1px solid var(--border);
}
.ind-sal-table td,.ind-risk-table td{
  padding:11px 16px;border-bottom:1px solid var(--border);
  vertical-align:top;
}
.ind-sal-table tr:last-child td,.ind-risk-table tr:last-child td{border-bottom:none}
.ind-sal-table tr:hover td,.ind-risk-table tr:hover td{background:var(--bg-subtle)}
.ind-sal-level{font-weight:500;color:var(--text-primary)}
.ind-sal-inr{font-family:'JetBrains Mono',monospace;font-weight:600;color:var(--accent);white-space:nowrap}
.ind-sal-usd{font-size:11px;color:var(--text-muted);white-space:nowrap}
.ind-trend-dot{display:inline-block;width:8px;height:8px;border-radius:50%}
.ind-dot-boom {background:var(--green);box-shadow:0 0 6px var(--green)}
.ind-dot-grow {background:var(--green-soft)}
.ind-dot-flat {background:var(--text-muted)}

/* City Grid */
.ind-city-grid{display:flex;flex-direction:column;gap:10px}
.ind-city-card{
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:14px 16px;
}
.ind-city-head{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.ind-city-rank{
  width:28px;height:28px;border-radius:8px;flex-shrink:0;
  background:rgba(255,153,51,.12);color:#FF9933;
  font-family:'Roboto Condensed',sans-serif;font-size:15px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.ind-city-name{font-size:14px;font-weight:600;color:var(--text-primary)}
.ind-city-tag{font-size:11px;color:var(--text-muted);margin-top:1px}
.ind-city-premium{
  margin-left:auto;font-family:'JetBrains Mono',monospace;
  font-size:13px;font-weight:700;color:var(--green-soft);
}
.ind-city-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ind-demand-badge{
  font-family:'JetBrains Mono',monospace;font-size:8px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.7px;padding:2px 8px;border-radius:4px;
}
.ind-demand-vh{background:var(--green-bg);  color:var(--green-soft); border:1px solid rgba(22,163,74,.20)}
.ind-demand-h {background:var(--accent-bg); color:var(--accent);     border:1px solid var(--accent-border)}
.ind-demand-m {background:var(--orange-bg); color:var(--orange);     border:1px solid rgba(234,88,12,.20)}
.ind-city-cos{font-size:11px;color:var(--text-muted);line-height:1.4}

/* Hiring Cards (India) */
.ind-hire-card{
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:8px;
}
.ind-hire-card:last-child{margin-bottom:0}
.ind-hire-company{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:3px}
.ind-hire-city{font-size:11px;color:var(--text-muted);margin-bottom:4px}
.ind-hire-roles{font-size:12px;color:var(--text-secondary);line-height:1.4}
.ind-hire-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.ind-hire-num{
  font-family:'Roboto Condensed',sans-serif;
  font-size:24px;font-weight:200;color:var(--green-soft);line-height:1;
}
.ind-hire-lbl{font-family:'JetBrains Mono',monospace;font-size:8px;text-transform:uppercase;letter-spacing:0.7px;color:var(--text-muted)}
.ind-type-badge{
  font-family:'JetBrains Mono',monospace;font-size:8px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.6px;padding:2px 7px;border-radius:4px;
}
.ind-type-mnc  {background:var(--accent-bg);  color:var(--accent);     border:1px solid var(--accent-border)}
.ind-type-start{background:var(--purple-bg);  color:var(--purple-soft);border:1px solid rgba(124,58,237,.20)}
.ind-type-it   {background:var(--cyan-bg);    color:var(--cyan-soft);  border:1px solid rgba(8,145,178,.20)}

/* At-Risk Table */
.ind-risk-table td:first-child{white-space:nowrap}
.ind-co-name{font-weight:600;color:var(--text-primary);font-size:13px}
.ind-sector{
  display:block;font-size:10px;color:var(--text-muted);font-weight:400;margin-top:2px;
}
.ind-co-detail{font-size:12px;color:var(--text-secondary);line-height:1.45}
.ind-status-badge{
  font-family:'JetBrains Mono',monospace;font-size:8px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.6px;padding:3px 8px;border-radius:4px;white-space:nowrap;
}
.ind-sev{background:rgba(220,38,38,.14);color:var(--red);   border:1px solid rgba(220,38,38,.25)}
.ind-high{background:var(--red-bg);    color:var(--red);   border:1px solid rgba(220,38,38,.18)}
.ind-cau{background:var(--orange-bg);  color:var(--orange);border:1px solid rgba(234,88,12,.18)}

/* Hiring/At-Risk side-by-side */
.ind-split-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:28px}

/* Skills Pills */
.ind-skills-grid{display:flex;flex-direction:column;gap:8px}
.ind-skill-pill{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius);padding:11px 16px;
}
.ind-skill-name{font-size:13px;font-weight:500;color:var(--text-primary)}
.ind-demand-tag{
  font-family:'JetBrains Mono',monospace;font-size:8px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.7px;padding:3px 9px;border-radius:4px;
}
.ind-very-high{background:var(--green-bg);  color:var(--green-soft);  border:1px solid rgba(22,163,74,.22)}
.ind-high     {background:var(--accent-bg); color:var(--accent);      border:1px solid var(--accent-border)}
.ind-growing  {background:var(--purple-bg); color:var(--purple-soft); border:1px solid rgba(124,58,237,.20)}
.ind-moderate {background:var(--bg-subtle); color:var(--text-muted);  border:1px solid var(--border)}

/* Footer credit update */
.footer-credit-sep{color:var(--text-muted);margin:0 6px}
.footer-credit-sub{color:var(--text-muted);font-size:12px}
.footer-credit a{color:var(--accent);text-decoration:none}
.footer-credit a:hover{text-decoration:underline}

/* ════════════════════════════════════════════════════════════
   ADDITIONAL RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media(max-width:768px){
  .opp-grid{grid-template-columns:1fr}
  .health-grid{grid-template-columns:repeat(2,1fr)}
  .supply-grid{grid-template-columns:1fr}
  .intel-stat-grid{grid-template-columns:repeat(2,1fr)}
  .risk-context-grid{grid-template-columns:repeat(2,1fr)}
  .watchlist-panel{right:12px;bottom:72px;width:calc(100vw - 24px)}
  .watchlist-fab{right:12px;bottom:12px}
  .ux-skills-section{grid-template-columns:1fr}
  .ux-impact-stats{grid-template-columns:repeat(3,1fr)}
  .ind-split-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .health-grid{grid-template-columns:1fr}
  .intel-stat-grid{grid-template-columns:1fr 1fr}
  .ux-impact-stats{grid-template-columns:repeat(2,1fr)}
}
