/* ═══════════════════════════════════════════════════════════
   STOCKSUTRA — DESIGN SYSTEM
   Palette: Deep Navy + Electric Amber + Slate Panels
   Fonts: Syne (display) + Plus Jakarta Sans (body)
═══════════════════════════════════════════════════════════ */

/* ── CSS VARIABLES ── */
:root {
  --bg-base: #080D1A;
  --bg-surface: #0E1628;
  --bg-card: #111827;
  --bg-card-hover: #162035;
  --bg-input: #0A1020;
  --border: #1E2D45;
  --border-light: #243550;
  --accent: #F0A500;
  --accent-dim: #C8880A;
  --accent-glow: rgba(240,165,0,0.15);
  --accent-glow-strong: rgba(240,165,0,0.25);
  --text-primary: #F0F4FF;
  --text-secondary: #8A9BB5;
  --text-muted: #4A5A72;
  --text-accent: #F0A500;
  --green: #22C55E;
  --green-dim: rgba(34,197,94,0.15);
  --red: #EF4444;
  --red-dim: rgba(239,68,68,0.15);
  --blue: #3B82F6;
  --blue-dim: rgba(59,130,246,0.15);
  --purple: #8B5CF6;
  --ticker-h: 36px;
  --header-h: 64px;
  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --shadow: 0 4px 24px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 48px rgba(0,0,0,0.6);
  --transition: 0.2s ease;
}

[data-theme="light"] {
  --bg-base: #F0F4FA;
  --bg-surface: #E8EDF5;
  --bg-card: #FFFFFF;
  --bg-card-hover: #F5F8FF;
  --bg-input: #FFFFFF;
  --border: #D0DAE8;
  --border-light: #C0CEDF;
  --accent: #D4900A;
  --accent-dim: #B87A08;
  --accent-glow: rgba(212,144,10,0.1);
  --accent-glow-strong: rgba(212,144,10,0.2);
  --text-primary: #0A1628;
  --text-secondary: #4A5A72;
  --text-muted: #8A9BB5;
  --text-accent: #D4900A;
  --shadow: 0 4px 24px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 48px rgba(0,0,0,0.12);
}

/* ── RESET & BASE ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--bg-base);
  color: var(--text-primary);
  font-size: 14px;
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
}
a { color: var(--accent); text-decoration: none; }
button { cursor: pointer; font-family: inherit; border: none; outline: none; }
input { font-family: inherit; outline: none; border: none; }
.hidden { display: none !important; }

/* ── TICKER TAPE ── */
.ticker-wrap {
  height: var(--ticker-h);
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
  position: relative;
  z-index: 100;
}
.ticker-track {
  display: flex;
  align-items: center;
  height: 100%;
  white-space: nowrap;
  animation: ticker-scroll 60s linear infinite;
  gap: 0;
}
.ticker-track:hover { animation-play-state: paused; }
@keyframes ticker-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.tick-item, .tick-index {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 20px;
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--text-secondary);
  border-right: 1px solid var(--border);
  height: 100%;
}
.tick-item.up .chg, .tick-index.up .chg { color: var(--green); }
.tick-item.down .chg, .tick-index.down .chg { color: var(--red); }
.tick-sep {
  display: inline-flex;
  align-items: center;
  padding: 0 12px;
  font-size: 10px;
  color: var(--accent);
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  letter-spacing: 0.05em;
  height: 100%;
}
.tick-index { color: var(--text-primary); font-weight: 700; }

/* ── HEADER ── */
.site-header {
  height: var(--header-h);
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 90;
  backdrop-filter: blur(12px);
}
.header-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 24px;
  height: 100%;
  display: flex;
  align-items: center;
  gap: 32px;
}
.logo {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  flex-shrink: 0;
}
.logo-icon { font-size: 22px; color: var(--accent); }
.logo-text {
  font-family: 'Syne', sans-serif;
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.02em;
}
.logo-accent { color: var(--accent); }
.logo-tag {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--text-muted);
  background: var(--border);
  padding: 2px 6px;
  border-radius: 4px;
  margin-left: 2px;
}
.main-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 1;
}
.nav-link {
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  transition: var(--transition);
}
.nav-link:hover, .nav-link.active {
  color: var(--text-primary);
  background: var(--bg-card);
}
.nav-link.active { color: var(--accent); }
.header-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.market-status {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  font-size: 12px;
}
.status-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px var(--green);
  animation: pulse-dot 2s ease-in-out infinite;
}
.status-dot.closed { background: var(--red); box-shadow: 0 0 6px var(--red); animation: none; }
@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}
.status-text { font-weight: 600; color: var(--text-primary); }
.status-time { color: var(--text-muted); }
.theme-toggle {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--bg-card);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-secondary);
  transition: var(--transition);
}
.theme-toggle:hover { color: var(--accent); border-color: var(--accent); }
.theme-toggle svg { width: 16px; height: 16px; }
[data-theme="dark"] .icon-moon { display: none; }
[data-theme="light"] .icon-sun { display: none; }
.btn-primary {
  padding: 8px 18px;
  background: var(--accent);
  color: #000;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 700;
  font-family: 'Syne', sans-serif;
  transition: var(--transition);
}
.btn-primary:hover { background: var(--accent-dim); transform: translateY(-1px); }

/* ── LANDING PAGE ── */
.landing-page {
  min-height: calc(100vh - var(--ticker-h) - var(--header-h));
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 60px 24px 40px;
  overflow: hidden;
}
.landing-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}
.grid-overlay {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 60px 60px;
  opacity: 0.3;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 100%);
}
.glow-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
}
.glow-1 {
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(240,165,0,0.12) 0%, transparent 70%);
  top: -200px; left: 50%;
  transform: translateX(-50%);
}
.glow-2 {
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(59,130,246,0.08) 0%, transparent 70%);
  bottom: 0; right: 10%;
}
.landing-content {
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 760px;
  width: 100%;
}
.landing-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px;
  background: var(--accent-glow);
  border: 1px solid rgba(240,165,0,0.3);
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  letter-spacing: 0.04em;
  margin-bottom: 28px;
  animation: fade-up 0.6s ease both;
}
.badge-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
  animation: pulse-dot 2s ease-in-out infinite;
}
.landing-title {
  font-family: 'Syne', sans-serif;
  font-size: clamp(36px, 6vw, 72px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--text-primary);
  margin-bottom: 20px;
  animation: fade-up 0.6s ease 0.1s both;
}
.title-accent {
  background: linear-gradient(135deg, #F0A500 0%, #FFD060 50%, #F0A500 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.landing-sub {
  font-size: 17px;
  color: var(--text-secondary);
  line-height: 1.7;
  max-width: 560px;
  margin: 0 auto 36px;
  animation: fade-up 0.6s ease 0.2s both;
}
.search-container {
  position: relative;
  max-width: 620px;
  margin: 0 auto 20px;
  animation: fade-up 0.6s ease 0.3s both;
}
.search-box {
  display: flex;
  align-items: center;
  background: var(--bg-card);
  border: 1.5px solid var(--border-light);
  border-radius: 14px;
  padding: 4px 4px 4px 16px;
  gap: 8px;
  transition: var(--transition);
  box-shadow: var(--shadow);
}
.search-box:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow), var(--shadow);
}
.search-box.compact { border-radius: var(--radius-sm); padding: 3px 3px 3px 12px; }
.search-icon { width: 18px; height: 18px; color: var(--text-muted); flex-shrink: 0; }
.search-input {
  flex: 1;
  background: transparent;
  color: var(--text-primary);
  font-size: 15px;
  padding: 10px 0;
}
.search-input::placeholder { color: var(--text-muted); }
.search-btn {
  width: 44px; height: 44px;
  background: var(--accent);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: #000;
  flex-shrink: 0;
  transition: var(--transition);
}
.search-btn:hover { background: var(--accent-dim); transform: scale(1.05); }
.search-btn svg { width: 18px; height: 18px; }
.search-box.compact .search-btn { width: 36px; height: 36px; border-radius: 6px; }
.search-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0; right: 0;
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  z-index: 200;
  overflow: hidden;
  display: none;
}
.search-dropdown.open { display: block; }
.dropdown-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  cursor: pointer;
  transition: var(--transition);
  border-bottom: 1px solid var(--border);
}
.dropdown-item:last-child { border-bottom: none; }
.dropdown-item:hover { background: var(--bg-card-hover); }
.di-left { display: flex; flex-direction: column; gap: 2px; }
.di-name { font-weight: 600; font-size: 14px; color: var(--text-primary); }
.di-meta { font-size: 11px; color: var(--text-muted); }
.di-right { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.di-price { font-family: 'Space Mono', monospace; font-size: 13px; font-weight: 700; }
.di-chg { font-size: 11px; font-weight: 600; }
.di-chg.up { color: var(--green); }
.di-chg.down { color: var(--red); }
.popular-searches {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  animation: fade-up 0.6s ease 0.4s both;
}
.popular-label { font-size: 12px; color: var(--text-muted); font-weight: 500; }
.popular-tag {
  padding: 5px 12px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  transition: var(--transition);
}
.popular-tag:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-glow);
}
.landing-stats {
  display: flex;
  gap: 16px;
  margin-top: 60px;
  position: relative;
  z-index: 1;
  animation: fade-up 0.6s ease 0.5s both;
}
.stat-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 28px;
  text-align: center;
  flex: 1;
  transition: var(--transition);
}
.stat-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.stat-num {
  font-family: 'Syne', sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: var(--accent);
  margin-bottom: 4px;
}
.stat-label { font-size: 12px; color: var(--text-muted); font-weight: 500; }

@keyframes fade-up {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── DASHBOARD PAGE ── */
.dashboard-page { min-height: calc(100vh - var(--ticker-h) - var(--header-h)); }

.dash-search-bar {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
  padding: 12px 24px;
  position: sticky;
  top: var(--header-h);
  z-index: 80;
}
.dash-search-inner {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 16px;
}
.dash-search-inner .search-container { max-width: 400px; margin: 0; animation: none; flex-shrink: 0; }
.dash-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-muted);
}
.breadcrumb-home { cursor: pointer; color: var(--accent); }
.breadcrumb-home:hover { text-decoration: underline; }
.breadcrumb-sep { color: var(--text-muted); }

/* ── OVERVIEW SECTION ── */
.overview-section {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
  padding: 24px;
}
.overview-top {
  max-width: 1440px;
  margin: 0 auto 20px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
}
.company-identity { display: flex; align-items: flex-start; gap: 16px; flex: 1; }
.company-logo-wrap {
  width: 56px; height: 56px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dim) 100%);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Syne', sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #000;
  flex-shrink: 0;
}
.company-meta { flex: 1; }
.company-name {
  font-family: 'Syne', sans-serif;
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}
.company-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 8px; }
.tag {
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.tag-exchange { background: var(--blue-dim); color: var(--blue); border: 1px solid rgba(59,130,246,0.3); }
.tag-sector { background: var(--accent-glow); color: var(--accent); border: 1px solid rgba(240,165,0,0.3); }
.tag-industry { background: var(--bg-card); color: var(--text-secondary); border: 1px solid var(--border); }
.tag-cap { background: var(--purple); color: #fff; opacity: 0.9; }
.company-desc { font-size: 13px; color: var(--text-secondary); line-height: 1.6; max-width: 600px; }

.price-block { text-align: right; flex-shrink: 0; }
.current-price {
  font-family: 'Space Mono', monospace;
  font-size: 36px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: 6px;
}
.price-change {
  font-family: 'Space Mono', monospace;
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 6px;
}
.price-change.up { color: var(--green); }
.price-change.down { color: var(--red); }
.price-meta { font-size: 12px; color: var(--text-muted); margin-bottom: 10px; }
.dot-sep { margin: 0 4px; }
.market-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  background: var(--green-dim);
  color: var(--green);
  border: 1px solid rgba(34,197,94,0.3);
}
.market-badge.closed { background: var(--red-dim); color: var(--red); border-color: rgba(239,68,68,0.3); }
.mbadge-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.mbadge-dot.open { animation: pulse-dot 2s ease-in-out infinite; }

/* ── METRICS STRIP ── */
.metrics-strip {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
  scrollbar-width: none;
}
.metrics-strip::-webkit-scrollbar { display: none; }
.metric-pill {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 10px 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  flex-shrink: 0;
  min-width: 100px;
  transition: var(--transition);
}
.metric-pill:hover { border-color: var(--accent); background: var(--bg-card-hover); }
.mp-label { font-size: 10px; color: var(--text-muted); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; }
.mp-val { font-family: 'Space Mono', monospace; font-size: 13px; font-weight: 700; color: var(--text-primary); }

/* ── DASHBOARD TABS ── */
.dash-tabs-wrap {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  position: sticky;
  top: calc(var(--header-h) + 57px);
  z-index: 70;
}
.dash-tabs {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.dash-tabs::-webkit-scrollbar { display: none; }
.dash-tab {
  padding: 14px 20px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  background: transparent;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: var(--transition);
  font-family: 'Plus Jakarta Sans', sans-serif;
}
.dash-tab:hover { color: var(--text-primary); }
.dash-tab.active { color: var(--accent); border-bottom-color: var(--accent); }

/* ── TAB CONTENT ── */
.tab-content-wrap { max-width: 1440px; margin: 0 auto; padding: 24px; }
.tab-panel { display: none; }
.tab-panel.active { display: block; animation: fade-up 0.3s ease both; }

/* ── PANEL GRIDS ── */
.panel-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.panel-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.span-full { grid-column: 1 / -1; }
.span-2 { grid-column: span 2; }

/* ── PANEL CARDS ── */
.panel-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  transition: var(--transition);
}
.panel-card:hover { border-color: var(--border-light); }
.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.card-header h3 {
  font-family: 'Syne', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: 0.01em;
}
.card-badge {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-glow);
  padding: 3px 8px;
  border-radius: 4px;
}

/* ── METRIC LIST ── */
.metric-list { display: flex; flex-direction: column; gap: 0; }
.ml-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.ml-row:last-child { border-bottom: none; }
.ml-row span:first-child { color: var(--text-secondary); }
.ml-val { font-weight: 600; color: var(--text-primary); font-family: 'Space Mono', monospace; font-size: 12px; }
.ml-val.positive { color: var(--green); }
.ml-val.negative { color: var(--red); }

/* ── INVESTMENT SCORE ── */
.score-card .score-grid {
  display: grid;
  grid-template-columns: 160px 1fr 200px;
  gap: 32px;
  align-items: center;
}
.score-ring-wrap { position: relative; width: 120px; height: 120px; margin: 0 auto; }
.score-ring { width: 120px; height: 120px; transform: rotate(-90deg); }
.ring-bg { fill: none; stroke: var(--border); stroke-width: 8; }
.ring-fill { fill: none; stroke-width: 8; stroke-linecap: round; stroke-dasharray: 314; stroke-dashoffset: 314; transition: stroke-dashoffset 1.2s ease; }
.overall-ring { stroke: var(--accent); filter: drop-shadow(0 0 6px var(--accent)); }
.ring-label {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.ring-score { font-family: 'Syne', sans-serif; font-size: 26px; font-weight: 800; color: var(--text-primary); line-height: 1; }
.ring-text { font-size: 10px; color: var(--text-muted); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; }
.score-bars { display: flex; flex-direction: column; gap: 12px; }
.score-bar-row { display: flex; align-items: center; gap: 10px; }
.sbar-label { font-size: 12px; color: var(--text-secondary); width: 110px; flex-shrink: 0; }
.sbar-track { flex: 1; height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; }
.sbar-fill { height: 100%; border-radius: 3px; width: 0; transition: width 1s ease; }
.health-fill { background: linear-gradient(90deg, var(--blue), #60A5FA); }
.val-fill { background: linear-gradient(90deg, var(--accent), #FFD060); }
.growth-fill { background: linear-gradient(90deg, var(--green), #86EFAC); }
.quality-fill { background: linear-gradient(90deg, var(--purple), #C4B5FD); }
.risk-fill { background: linear-gradient(90deg, var(--red), #FCA5A5); }
.sbar-val { font-family: 'Space Mono', monospace; font-size: 12px; font-weight: 700; color: var(--text-primary); width: 32px; text-align: right; }
.score-verdict {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  text-align: center;
}
.verdict-label { font-size: 10px; color: var(--text-muted); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 8px; }
.verdict-text { font-family: 'Syne', sans-serif; font-size: 22px; font-weight: 800; color: var(--accent); margin-bottom: 8px; }
.verdict-sub { font-size: 12px; color: var(--text-secondary); line-height: 1.5; }

/* ── SHAREHOLDING ── */
.shareholding-chart { display: flex; flex-direction: column; gap: 14px; padding-top: 4px; }
.sh-bar-row { display: flex; align-items: center; gap: 10px; }
.sh-label { font-size: 12px; color: var(--text-secondary); width: 70px; flex-shrink: 0; }
.sh-track { flex: 1; height: 8px; background: var(--border); border-radius: 4px; overflow: hidden; }
.sh-fill { height: 100%; border-radius: 4px; width: 0; transition: width 1s ease; }
.promoter-fill { background: linear-gradient(90deg, #F0A500, #FFD060); }
.fii-fill { background: linear-gradient(90deg, #3B82F6, #93C5FD); }
.dii-fill { background: linear-gradient(90deg, #8B5CF6, #C4B5FD); }
.retail-fill { background: linear-gradient(90deg, #22C55E, #86EFAC); }
.sh-pct { font-family: 'Space Mono', monospace; font-size: 12px; font-weight: 700; color: var(--text-primary); width: 40px; text-align: right; }

/* ── GROWTH GRID ── */
.growth-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.growth-cell {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 12px;
  text-align: center;
  transition: var(--transition);
}
.growth-cell:hover { border-color: var(--accent); }
.gc-period { font-size: 10px; font-weight: 700; color: var(--text-muted); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 2px; }
.gc-label { font-size: 11px; color: var(--text-secondary); margin-bottom: 6px; }
.gc-val { font-family: 'Space Mono', monospace; font-size: 15px; font-weight: 700; color: var(--green); }
.gc-val.negative { color: var(--red); }

/* ── STRENGTHS & WEAKNESSES ── */
.sw-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.sw-col-header {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  margin-bottom: 12px;
}
.strengths-header { background: var(--green-dim); color: var(--green); }
.weaknesses-header { background: var(--red-dim); color: var(--red); }
.sw-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.sw-list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  color: var(--text-secondary);
  padding: 8px 10px;
  background: var(--bg-surface);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  animation: fade-up 0.4s ease both;
}
.sw-list li .sw-icon { flex-shrink: 0; margin-top: 1px; }
.strengths-col .sw-list li .sw-icon { color: var(--green); }
.weaknesses-col .sw-list li .sw-icon { color: var(--red); }

/* ── VALUATION ── */
.val-summary-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
.vs-item {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 16px;
  text-align: center;
  transition: var(--transition);
}
.vs-item:hover { border-color: var(--border-light); }
.highlight-item { border-color: var(--accent); background: var(--accent-glow); }
.vs-model { font-size: 11px; color: var(--text-muted); font-weight: 600; letter-spacing: 0.04em; margin-bottom: 8px; }
.vs-price { font-family: 'Space Mono', monospace; font-size: 18px; font-weight: 700; color: var(--text-primary); margin-bottom: 8px; }
.vs-signal {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  display: inline-block;
}
.vs-signal.undervalued { background: var(--green-dim); color: var(--green); }
.vs-signal.overvalued { background: var(--red-dim); color: var(--red); }
.vs-signal.fair { background: var(--accent-glow); color: var(--accent); }
.vs-signal.neutral { background: var(--bg-card); color: var(--text-muted); }

/* ── MODEL INPUTS ── */
.model-inputs { display: flex; flex-direction: column; gap: 12px; }
.input-row { display: flex; flex-direction: column; gap: 4px; }
.input-row label { font-size: 11px; color: var(--text-muted); font-weight: 600; letter-spacing: 0.04em; }
.input-with-unit {
  display: flex;
  align-items: center;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.input-with-unit input {
  flex: 1;
  padding: 8px 12px;
  background: transparent;
  color: var(--text-primary);
  font-size: 14px;
  font-family: 'Space Mono', monospace;
}
.input-with-unit span {
  padding: 8px 12px;
  background: var(--border);
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 600;
}
.calc-btn {
  padding: 10px;
  background: var(--accent);
  color: #000;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 700;
  font-family: 'Syne', sans-serif;
  transition: var(--transition);
  margin-top: 4px;
}
.calc-btn:hover { background: var(--accent-dim); }
.model-result {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
  color: var(--text-secondary);
}
.model-result:last-child { border-bottom: none; }
.model-result-val { font-family: 'Space Mono', monospace; font-weight: 700; color: var(--text-primary); font-size: 14px; }
.margin-safety { display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--text-muted); }
.mos-val { font-weight: 700; font-family: 'Space Mono', monospace; }
.mos-val.positive { color: var(--green); }
.mos-val.negative { color: var(--red); }
.divider-line { height: 1px; background: var(--border); margin: 4px 0; }

/* ── FINANCIALS ── */
.financials-wrap { display: flex; flex-direction: column; gap: 16px; }
.fin-period-toggle, .fin-tabs {
  display: flex;
  gap: 4px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 4px;
  width: fit-content;
}
.period-btn, .fin-tab {
  padding: 7px 16px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  background: transparent;
  transition: var(--transition);
}
.period-btn.active, .fin-tab.active {
  background: var(--accent);
  color: #000;
}
.period-btn:hover:not(.active), .fin-tab:hover:not(.active) { color: var(--text-primary); }
.fin-table-wrap { overflow-x: auto; }
.fin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.fin-table th {
  padding: 10px 16px;
  text-align: right;
  font-family: 'Syne', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.fin-table th:first-child { text-align: left; }
.fin-table td {
  padding: 10px 16px;
  text-align: right;
  border-bottom: 1px solid var(--border);
  color: var(--text-secondary);
  font-family: 'Space Mono', monospace;
  font-size: 12px;
}
.fin-table td:first-child {
  text-align: left;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  color: var(--text-primary);
  font-weight: 500;
}
.fin-table tr:hover td { background: var(--bg-card-hover); }
.fin-table tr.section-header td {
  background: var(--bg-surface);
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent);
  padding: 8px 16px;
}
.fin-table .positive { color: var(--green); }
.fin-table .negative { color: var(--red); }

/* ── PEER TABLE ── */
.peer-table-wrap { overflow-x: auto; }
.peer-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.peer-table th {
  padding: 10px 14px;
  text-align: right;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.peer-table th:first-child { text-align: left; }
.peer-table td {
  padding: 10px 14px;
  text-align: right;
  border-bottom: 1px solid var(--border);
  font-family: 'Space Mono', monospace;
  font-size: 12px;
  color: var(--text-secondary);
}
.peer-table td:first-child {
  text-align: left;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
}
.peer-table tr.current-company td { background: var(--accent-glow); }
.peer-table tr.current-company td:first-child { color: var(--accent); }
.peer-table tr:hover td { background: var(--bg-card-hover); }

/* ── NEWS ── */
.news-wrap { display: flex; flex-direction: column; gap: 12px; }
.news-item {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 20px;
  display: flex;
  gap: 16px;
  align-items: flex-start;
  transition: var(--transition);
  cursor: pointer;
  animation: fade-up 0.3s ease both;
}
.news-item:hover { border-color: var(--accent); background: var(--bg-card-hover); }
.news-type-badge {
  flex-shrink: 0;
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: 2px;
}
.news-type-badge.earnings { background: var(--green-dim); color: var(--green); }
.news-type-badge.announcement { background: var(--blue-dim); color: var(--blue); }
.news-type-badge.dividend { background: var(--accent-glow); color: var(--accent); }
.news-type-badge.regulatory { background: var(--red-dim); color: var(--red); }
.news-type-badge.general { background: var(--bg-surface); color: var(--text-muted); }
.news-content { flex: 1; }
.news-title { font-size: 14px; font-weight: 600; color: var(--text-primary); margin-bottom: 6px; line-height: 1.4; }
.news-summary { font-size: 12px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 8px; }
.news-meta { display: flex; gap: 12px; font-size: 11px; color: var(--text-muted); }
.news-source { font-weight: 600; color: var(--accent); }

/* ── TECHNICAL ── */
.rsi-gauge-wrap { text-align: center; padding: 8px 0; }
.rsi-bar-track {
  display: flex;
  height: 24px;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 16px;
}
.rsi-zone-oversold { flex: 30; background: var(--red-dim); display: flex; align-items: center; justify-content: center; font-size: 10px; color: var(--red); font-weight: 600; }
.rsi-zone-neutral { flex: 40; background: var(--bg-surface); display: flex; align-items: center; justify-content: center; font-size: 10px; color: var(--text-muted); font-weight: 600; }
.rsi-zone-overbought { flex: 30; background: var(--green-dim); display: flex; align-items: center; justify-content: center; font-size: 10px; color: var(--green); font-weight: 600; }
.rsi-value { font-family: 'Space Mono', monospace; font-size: 40px; font-weight: 700; color: var(--text-primary); line-height: 1; margin-bottom: 8px; }
.rsi-signal { font-size: 13px; font-weight: 700; color: var(--text-secondary); }

/* ── FOOTER ── */
.site-footer {
  background: var(--bg-surface);
  border-top: 1px solid var(--border);
  padding: 20px 24px;
  margin-top: 40px;
}
.footer-inner {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.footer-logo { display: flex; align-items: center; gap: 6px; }
.footer-note { font-size: 11px; color: var(--text-muted); max-width: 400px; text-align: center; }
.footer-links { display: flex; gap: 16px; }
.footer-links a { font-size: 12px; color: var(--text-muted); transition: var(--transition); }
.footer-links a:hover { color: var(--accent); }

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .panel-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .span-2 { grid-column: span 2; }
  .score-card .score-grid { grid-template-columns: 140px 1fr; }
  .score-verdict { grid-column: 1 / -1; }
  .val-summary-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .main-nav { display: none; }
  .panel-grid-3, .panel-grid-2 { grid-template-columns: 1fr; }
  .span-full, .span-2 { grid-column: 1; }
  .score-card .score-grid { grid-template-columns: 1fr; }
  .sw-grid { grid-template-columns: 1fr; }
  .val-summary-grid { grid-template-columns: repeat(2, 1fr); }
  .overview-top { flex-direction: column; }
  .price-block { text-align: left; }
  .landing-stats { flex-wrap: wrap; }
  .stat-card { min-width: calc(50% - 8px); }
  .header-actions .market-status .status-time { display: none; }
}
@media (max-width: 480px) {
  .header-inner { padding: 0 16px; gap: 12px; }
  .landing-title { font-size: 32px; }
  .val-summary-grid { grid-template-columns: 1fr 1fr; }
}
