:root {
  color-scheme: dark;
  --bg-0: #050506;
  --bg-1: #0b0c0e;
  --bg-2: #121317;
  --ink: #f5f7fb;
  --muted: #99a0aa;
  --line: rgba(242, 245, 249, 0.19);
  --line-soft: rgba(230, 235, 240, 0.12);
  --glass: rgba(20, 22, 27, 0.6);
  --accent: #d8dde5;
  --accent-soft: #b3bac4;
  --good: #5fc498;
  --bad: #f18d8d;
  --warn: #d8b168;
  --shadow: rgba(1, 2, 3, 0.48);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  color: var(--ink);
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Helvetica, Arial,
    sans-serif;
  background:
    radial-gradient(900px 560px at -10% -10%, rgba(146, 154, 170, 0.26), transparent 72%),
    radial-gradient(880px 460px at 105% 0%, rgba(104, 111, 125, 0.2), transparent 74%),
    linear-gradient(150deg, var(--bg-0), var(--bg-1) 52%, var(--bg-2));
  overflow-x: hidden;
  animation: backgroundSweep 18s ease-in-out infinite alternate;
}

@keyframes backgroundSweep {
  0% {
    background-position: 0 0, 100% 0, 0 0;
  }
  100% {
    background-position: 10% 8%, 96% 4%, 0 0;
  }
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.18;
  background-image: linear-gradient(transparent 95%, rgba(210, 220, 230, 0.16) 95%),
    linear-gradient(90deg, transparent 95%, rgba(210, 220, 230, 0.1) 95%);
  background-size: 34px 34px;
}

h1,
h2,
h3,
h4,
p {
  margin: 0;
}

h2 {
  font-size: 1.12rem;
}

h3 {
  font-size: clamp(1.34rem, 2.1vw, 2.2rem);
  line-height: 1.25;
  max-width: 25ch;
}

h4 {
  font-size: 1.03rem;
}

main {
  width: min(1320px, calc(100vw - 34px));
  margin: 16px auto 52px;
  display: grid;
  gap: 16px;
}

.eyebrow {
  font-size: 0.73rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--muted);
}

.mono {
  font-family: ui-monospace, "SFMono-Regular", SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

.mini {
  font-size: 0.77rem;
  color: var(--muted);
}

.bg-aura {
  position: fixed;
  width: 42vw;
  height: 42vw;
  border-radius: 50%;
  filter: blur(88px);
  pointer-events: none;
  opacity: 0.35;
  animation: breathe 14s ease-in-out infinite alternate;
}

.aura-1 {
  top: -16vw;
  left: -8vw;
  background: rgba(156, 165, 182, 0.38);
}

.aura-2 {
  top: 24vh;
  right: -12vw;
  background: rgba(115, 122, 137, 0.35);
  animation-duration: 18s;
}

.aura-3 {
  bottom: -16vw;
  left: 34vw;
  background: rgba(166, 174, 191, 0.3);
  animation-duration: 20s;
}

@keyframes breathe {
  from {
    transform: scale(1) translateY(0);
  }
  to {
    transform: scale(1.07) translateY(-16px);
  }
}

.glass {
  position: relative;
  background: linear-gradient(145deg, rgba(22, 24, 29, 0.7), rgba(12, 14, 18, 0.66));
  border: 1px solid var(--line);
  border-radius: 20px;
  backdrop-filter: blur(24px) saturate(132%);
  -webkit-backdrop-filter: blur(24px) saturate(132%);
  box-shadow: 0 24px 54px var(--shadow), inset 0 1px rgba(250, 251, 255, 0.18);
  overflow: hidden;
}

.glass::before {
  content: "";
  position: absolute;
  inset: -40%;
  pointer-events: none;
  background: linear-gradient(110deg, transparent 46%, rgba(250, 252, 255, 0.14) 50%, transparent 54%);
  transform: translateX(-70%);
  animation: sheen 9s ease-in-out infinite;
}

@keyframes sheen {
  0%,
  80% {
    transform: translateX(-80%);
  }
  100% {
    transform: translateX(90%);
  }
}

.topbar {
  width: min(1320px, calc(100vw - 34px));
  margin: 18px auto 0;
  padding: 14px 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
}

.brand-block {
  display: flex;
  align-items: center;
  gap: 12px;
}

.brand-mark {
  width: 38px;
  height: 38px;
  border-radius: 11px;
  display: grid;
  place-content: center;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  color: #08090b;
  background: linear-gradient(140deg, #f3f5f8, #d4d9e0);
  box-shadow: 0 0 0 4px rgba(226, 232, 243, 0.2);
}

.topbar-right {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.79rem;
  color: var(--muted);
}

.dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(224, 232, 241, 0.9);
}

.hero {
  padding: 24px;
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 16px;
}

.hero p {
  margin-top: 12px;
  color: #bcc2cb;
  max-width: 60ch;
}

.accent {
  color: var(--accent);
  text-shadow: 0 0 14px rgba(220, 226, 236, 0.2);
}

.hero-side {
  display: grid;
  gap: 12px;
}

.symbol-form,
.auth-card {
  border-radius: 15px;
  padding: 12px;
  background: rgba(23, 25, 31, 0.66);
  border: 1px solid var(--line-soft);
}

.symbol-form label {
  display: block;
  font-size: 0.79rem;
  color: var(--muted);
  margin-bottom: 8px;
}

.symbol-row {
  display: flex;
  gap: 8px;
}

input,
button,
select,
textarea {
  border: 0;
  font: inherit;
}

input,
select,
textarea {
  width: 100%;
  padding: 10px 11px;
  border-radius: 11px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.08);
  color: var(--ink);
  outline: none;
  transition: border-color 140ms ease, background-color 140ms ease;
}

textarea {
  min-height: 96px;
  resize: vertical;
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(232, 238, 247, 0.54);
  background: rgba(255, 255, 255, 0.12);
}

button {
  cursor: pointer;
  border-radius: 11px;
  padding: 10px 13px;
  min-width: 108px;
  font-weight: 700;
  color: #0a0b0d;
  background: linear-gradient(132deg, #f5f7fb, #d5dbe4);
  transition: transform 120ms ease, filter 120ms ease;
}

button:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
}

button:active {
  transform: translateY(0);
}

.ghost-btn {
  color: var(--ink);
  background: rgba(244, 247, 252, 0.08);
  border: 1px solid var(--line);
  min-width: 0;
}

.auth-guest {
  display: grid;
  gap: 10px;
}

.auth-form {
  display: grid;
  gap: 8px;
}

.auth-user {
  display: grid;
  gap: 8px;
}

.auth-user-name {
  font-size: 1rem;
  font-weight: 700;
}

.auth-message {
  min-height: 18px;
  margin-top: 6px;
}

.hidden {
  display: none !important;
}

.grid {
  display: grid;
  gap: 16px;
}

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

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

.panel {
  padding: 17px;
}

.panel-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 12px;
}

.stackable {
  align-items: center;
}

.workspace-card {
  min-height: 360px;
}

.workspace-form {
  display: grid;
  gap: 8px;
  margin-bottom: 10px;
}

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

.alert-grid button {
  grid-column: span 2;
}

.workspace-list {
  display: grid;
  gap: 8px;
  max-height: 300px;
  overflow: auto;
  padding-right: 4px;
}

.workspace-item {
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  padding: 9px;
  background: rgba(255, 255, 255, 0.06);
  display: grid;
  gap: 6px;
}

.workspace-item-head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
}

.workspace-item-title {
  font-size: 0.88rem;
  font-weight: 700;
}

.workspace-item-actions {
  display: flex;
  gap: 6px;
}

.workspace-item-actions button {
  min-width: 0;
  padding: 6px 8px;
  border-radius: 9px;
  font-size: 0.72rem;
}

.workspace-item-actions .danger {
  background: linear-gradient(130deg, #f2b3b3, #e68f8f);
  color: #260b0b;
}

.workspace-item-meta {
  font-size: 0.75rem;
  color: var(--muted);
}

.workspace-action {
  margin-bottom: 8px;
}

.workspace-eval {
  display: grid;
  gap: 8px;
}

.eval-hit {
  border-left: 4px solid var(--good);
}

.eval-miss {
  border-left: 4px solid var(--warn);
}

.regime-wrap {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 16px;
  align-items: center;
}

.regime-meter {
  width: 160px;
  height: 160px;
  border-radius: 50%;
  display: grid;
  place-content: center;
  border: 1px solid var(--line);
  background: conic-gradient(from 235deg, #b4bac4, #ddcaa0, #d59a9a, #b4bac4);
  box-shadow: inset 0 0 0 13px rgba(9, 10, 12, 0.92);
  text-align: center;
}

.meter-value {
  font-weight: 800;
  font-size: 1.92rem;
}

.meter-label {
  font-size: 0.78rem;
  color: var(--muted);
}

.regime-details {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
}

.kpi {
  padding: 8px 9px;
  border-radius: 11px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.05);
}

.kpi-title {
  color: var(--muted);
  font-size: 0.72rem;
  margin-bottom: 2px;
}

.kpi-value {
  font-size: 0.95rem;
  font-family: ui-monospace, "SFMono-Regular", SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

.pulse-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(152px, 1fr));
  gap: 9px;
}

.live-wire {
  padding: 14px 17px 16px;
}

.ticker-shell {
  margin-top: 2px;
  width: 100%;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.04);
}

.ticker-track {
  display: flex;
  align-items: center;
  gap: 8px;
  width: max-content;
  padding: 10px 8px;
  will-change: transform;
}

.ticker-track.live {
  animation: tickerMove 58s linear infinite;
}

.ticker-item {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 11px;
  border-radius: 999px;
  border: 1px solid var(--line-soft);
  text-decoration: none;
  white-space: nowrap;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.06);
  font-size: 0.78rem;
}

.ticker-label {
  font-size: 0.72rem;
  letter-spacing: 0.04em;
}

.ticker-change {
  font-weight: 700;
}

.ticker-quote.up {
  border-color: rgba(95, 196, 152, 0.6);
  background: rgba(95, 196, 152, 0.15);
}

.ticker-quote.up .ticker-change {
  color: #76edb8;
}

.ticker-quote.down {
  border-color: rgba(241, 141, 141, 0.66);
  background: rgba(241, 141, 141, 0.14);
}

.ticker-quote.down .ticker-change {
  color: #ff9da3;
}

.ticker-quote.neutral {
  border-color: rgba(216, 177, 104, 0.6);
  background: rgba(216, 177, 104, 0.13);
}

.ticker-quote.neutral .ticker-change {
  color: #f1cc88;
}

.ticker-source {
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #a8b5cb;
}

.ticker-time {
  color: var(--muted);
  font-size: 0.72rem;
}

.ticker-news {
  max-width: min(70vw, 720px);
  overflow: hidden;
  text-overflow: ellipsis;
}

.ticker-news:hover {
  border-color: rgba(111, 182, 255, 0.65);
  background: rgba(111, 182, 255, 0.14);
}

.ticker-empty {
  padding: 12px;
}

@keyframes tickerMove {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-50%, 0, 0);
  }
}

.pulse-card {
  border-radius: 12px;
  padding: 9px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.05);
}

.pulse-card h5 {
  margin: 0;
  font-size: 0.82rem;
}

.pulse-price {
  margin-top: 7px;
  font-family: ui-monospace, "SFMono-Regular", SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 1rem;
}

.delta {
  margin-top: 4px;
  font-size: 0.78rem;
}

.up {
  color: var(--good);
}

.down {
  color: var(--bad);
}

.neutral {
  color: var(--warn);
}

.company-snapshot {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
  margin-bottom: 10px;
}

.snapshot-block {
  padding: 8px;
  border-radius: 11px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.05);
}

.snapshot-title {
  font-size: 0.71rem;
  color: var(--muted);
}

.snapshot-value {
  margin-top: 4px;
  font-size: 0.95rem;
  font-family: ui-monospace, "SFMono-Regular", SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

.score-bars {
  margin-bottom: 10px;
  display: grid;
  gap: 7px;
}

.score-line {
  display: grid;
  grid-template-columns: 136px 1fr 44px;
  gap: 7px;
  align-items: center;
}

.score-track {
  width: 100%;
  height: 8px;
  border-radius: 999px;
  background: rgba(223, 229, 238, 0.22);
  overflow: hidden;
}

.score-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(92deg, #d9dee6, #afb6c2, #e5d1a8);
}

.factor-headline {
  margin-bottom: 8px;
  padding: 8px 10px;
  border-radius: 11px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.05);
}

.table-wrap {
  overflow: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

th,
td {
  padding: 8px;
  text-align: left;
  border-bottom: 1px solid var(--line-soft);
  white-space: nowrap;
}

th {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.watchlist-form {
  display: flex;
  gap: 7px;
}

.watchlist-form input {
  min-width: 280px;
}

.dcf-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

.dcf-grid label {
  display: grid;
  gap: 6px;
  font-size: 0.74rem;
  color: var(--muted);
}

.dcf-grid button {
  align-self: end;
  min-width: 0;
}

.dcf-output {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.dcf-card {
  padding: 8px;
  border-radius: 10px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.05);
}

.sources ul,
#sourceList {
  list-style: none;
  margin: 0;
  padding: 0;
}

#sourceList li {
  padding: 8px 0;
  border-bottom: 1px solid var(--line-soft);
  font-size: 0.86rem;
}

#sourceList a {
  color: #c9d0db;
}

canvas {
  width: 100% !important;
  max-height: 310px;
}

.intro-screen {
  position: fixed;
  inset: 0;
  z-index: 99;
  display: grid;
  place-content: center;
  overflow: hidden;
  background: radial-gradient(900px 600px at 50% 35%, rgba(135, 146, 166, 0.25), rgba(6, 8, 11, 0.97));
}

.intro-noise {
  position: absolute;
  inset: 0;
  opacity: 0.18;
  background-image: radial-gradient(circle, rgba(224, 232, 246, 0.2) 0.5px, transparent 0.5px);
  background-size: 8px 8px;
}

.intro-content {
  position: relative;
  z-index: 2;
  text-align: center;
  display: grid;
  gap: 10px;
  animation: introRise 1200ms cubic-bezier(0.18, 0.82, 0.26, 1);
}

.intro-mark {
  width: 74px;
  height: 74px;
  border-radius: 20px;
  margin: 0 auto;
  display: grid;
  place-content: center;
  letter-spacing: 0.08em;
  font-weight: 800;
  color: #0a0b0d;
  background: linear-gradient(150deg, #f5f7fb, #d4dae4);
  box-shadow: 0 0 0 10px rgba(220, 228, 241, 0.16);
}

.intro-copy {
  color: var(--muted);
}

.intro-screen.done {
  animation: introFade 700ms ease forwards;
}

@keyframes introRise {
  from {
    opacity: 0;
    transform: translateY(30px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes introFade {
  to {
    opacity: 0;
    visibility: hidden;
  }
}

.reveal {
  animation: reveal 620ms ease both;
}

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

.toast {
  position: fixed;
  left: 50%;
  bottom: 20px;
  transform: translateX(-50%) translateY(18px);
  border-radius: 999px;
  padding: 10px 15px;
  background: rgba(236, 241, 249, 0.92);
  color: #0a0b0d;
  font-size: 0.82rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease, transform 220ms ease;
  z-index: 120;
}

.toast.visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

@media (max-width: 1200px) {
  .grid.three {
    grid-template-columns: 1fr;
  }

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

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

  .watchlist-form input {
    min-width: 0;
  }

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

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

@media (max-width: 760px) {
  .topbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .topbar-right {
    flex-wrap: wrap;
  }

  .symbol-row,
  .watchlist-form {
    flex-direction: column;
  }

  .company-snapshot {
    grid-template-columns: 1fr;
  }

  .score-line {
    grid-template-columns: 1fr;
  }

  .regime-wrap {
    grid-template-columns: 1fr;
  }

  .regime-meter {
    margin: 0 auto;
  }

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

  .alert-grid button {
    grid-column: span 1;
  }

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

  .ticker-track.live {
    animation-duration: 72s;
  }

  .ticker-news {
    max-width: 88vw;
  }
}
