/* ================================================================
   Probability Terminal — Dashboard styles
   Self-contained, no Tailwind. Matches the React MVP aesthetic.
   ================================================================ */

:root {
	--ink-950: #07090c;
	--ink-900: #0b0e13;
	--ink-850: #10141b;
	--ink-800: #161b24;
	--ink-700: #1e2530;
	--ink-600: #2a3140;
	--ink-500: #3a4254;
	--ink-text: #e6e9ee;
	--ink-muted: #8a93a6;

	--bull: #22d39a;
	--bull-dim: rgba(34, 211, 154, 0.10);
	--bull-bd: rgba(34, 211, 154, 0.40);
	--bear: #ff5757;
	--bear-dim: rgba(255, 87, 87, 0.10);
	--bear-bd: rgba(255, 87, 87, 0.40);
	--warn: #f5a524;
	--warn-dim: rgba(245, 165, 36, 0.10);
	--warn-bd: rgba(245, 165, 36, 0.40);
	--accent: #7dd3fc;
	--accent-dim: rgba(125, 211, 252, 0.15);
	--accent-bd: rgba(125, 211, 252, 0.40);

	--shadow-glow: 0 0 0 1px rgba(125, 211, 252, 0.15), 0 8px 32px -12px rgba(125, 211, 252, 0.25);
}

body {
	background-image:
		radial-gradient(circle at 20% 0%, rgba(125, 211, 252, 0.04), transparent 40%),
		radial-gradient(circle at 80% 100%, rgba(34, 211, 154, 0.03), transparent 40%),
		linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px);
	background-size: 100% 100%, 100% 100%, 32px 32px, 32px 32px;
	background-attachment: fixed;
}

.num { font-variant-numeric: tabular-nums; font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace; }

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--ink-600); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--ink-500); }

@keyframes pt-pulse-soft { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }
.pt-pulse { animation: pt-pulse-soft 2s ease-in-out infinite; }

/* ---------- Layout ---------- */
.pt-main { padding: 20px 24px; min-height: 100vh; }
.pt-dashboard { font-size: 14px; }

/* Header */
.pt-header {
	display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
	gap: 16px; padding-bottom: 16px; margin-bottom: 20px;
	border-bottom: 1px solid rgba(30, 37, 48, 0.6);
}
.pt-header__brand { display: flex; align-items: center; gap: 12px; }
.pt-logo {
	width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
	border: 1px solid var(--accent-bd); background: var(--accent-dim); border-radius: 4px;
	font-family: "JetBrains Mono", monospace; font-weight: 700; color: var(--accent); font-size: 16px;
}
.pt-header__title { margin: 0; font-size: 16px; font-weight: 600; color: #fff; letter-spacing: -0.01em; }
.pt-header__sub { margin: 2px 0 0; font-size: 11px; color: var(--ink-muted); }

.pt-controls { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; }
.pt-control { display: inline-flex; align-items: center; gap: 8px; }
.pt-control__label,
.pt-eyebrow {
	font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.22em;
	color: var(--ink-muted);
}
.pt-select {
	padding: 6px 12px; border: 1px solid var(--ink-700); background: var(--ink-850);
	color: #fff; font-size: 14px; font-weight: 600; border-radius: 4px; outline: none;
	cursor: pointer;
}
.pt-select:focus { border-color: var(--accent); }

.pt-tf {
	display: inline-flex; gap: 2px; padding: 2px;
	border: 1px solid var(--ink-700); background: var(--ink-850); border-radius: 4px;
}
.pt-tf__btn {
	padding: 4px 12px; background: transparent; color: var(--ink-muted);
	border: 0; cursor: pointer; font-size: 12px; font-weight: 600;
	text-transform: uppercase; letter-spacing: 0.06em; border-radius: 2px;
	transition: color 120ms;
}
.pt-tf__btn:hover { color: #fff; }
.pt-tf__btn.is-active {
	background: var(--accent-dim); color: var(--accent); box-shadow: var(--shadow-glow);
}

.pt-status { display: flex; align-items: center; gap: 8px; font-size: 11px; color: var(--ink-muted); }
.pt-status__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--bull); }

.pt-error {
	margin-bottom: 16px; padding: 8px 16px; border-radius: 4px;
	border: 1px solid var(--bear-bd); background: var(--bear-dim); color: var(--bear); font-size: 12px;
}
.pt-loading {
	display: flex; align-items: center; justify-content: center;
	min-height: 60vh; color: var(--ink-muted);
}

/* Grid */
.pt-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 16px; }
.pt-col-3 { grid-column: span 12; }
.pt-col-4 { grid-column: span 12; }
.pt-col-5 { grid-column: span 12; }
.pt-col-8 { grid-column: span 12; }
@media (min-width: 720px) {
	.pt-col-3 { grid-column: span 6; }
}
@media (min-width: 1100px) {
	.pt-col-3 { grid-column: span 3; }
	.pt-col-4 { grid-column: span 4; }
	.pt-col-5 { grid-column: span 5; }
	.pt-col-8 { grid-column: span 8; }
}

/* Card */
.pt-card {
	border: 1px solid rgba(30, 37, 48, 0.6); background: rgba(11, 14, 19, 0.6);
	backdrop-filter: blur(4px); border-radius: 6px; overflow: hidden;
}
.pt-card__head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 10px 16px; border-bottom: 1px solid rgba(30, 37, 48, 0.6);
}
.pt-card__head h3 {
	margin: 0; font-size: 11px; font-weight: 600;
	text-transform: uppercase; letter-spacing: 0.18em; color: var(--ink-muted);
}
.pt-card__sub { margin: 2px 0 0; font-size: 11px; color: var(--ink-muted); }
.pt-card__body { padding: 16px; }
.pt-meta { font-size: 11px; color: var(--ink-muted); }

/* Badges */
.pt-badge {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 2px 8px; border: 1px solid var(--ink-600); background: var(--ink-800);
	color: var(--ink-muted); border-radius: 3px;
	font-size: 10px; font-weight: 600;
	text-transform: uppercase; letter-spacing: 0.18em;
}
.pt-badge.is-bull { border-color: var(--bull-bd); background: var(--bull-dim); color: var(--bull); }
.pt-badge.is-bear { border-color: var(--bear-bd); background: var(--bear-dim); color: var(--bear); }
.pt-badge.is-warn { border-color: var(--warn-bd); background: var(--warn-dim); color: var(--warn); }

/* Bias card */
.pt-bias { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 8px 0; }
.pt-bias__setup { text-align: center; }
.pt-bias__setup-name { margin-top: 4px; font-size: 14px; font-weight: 600; color: #fff; }

/* Gauge */
.pt-gauge-wrap { display: flex; justify-content: center; }
.pt-gauge { display: flex; flex-direction: column; align-items: center; }
.pt-gauge__svg { display: block; }
.pt-gauge__label { margin-top: 4px; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.22em; color: var(--ink-muted); }
.pt-gauge__sub { margin-top: 2px; font-size: 12px; color: var(--ink-muted); }
.pt-gauge__value {
	position: relative; margin-top: -38px; text-align: center;
	font-family: "JetBrains Mono", monospace; font-size: 30px; font-weight: 600; letter-spacing: -0.02em;
}
.pt-gauge__value-pct { font-size: 16px; color: var(--ink-muted); margin-left: 1px; }

/* MTF grid */
.pt-mtf-head {
	display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px;
}
.pt-mtf-head__score { font-family: "JetBrains Mono", monospace; font-size: 12px; font-weight: 600; color: var(--ink-muted); }
.pt-mtf-head__score.is-aligned { color: var(--bull); }
.pt-mtf-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.pt-mtf-cell {
	display: flex; flex-direction: column; align-items: center; gap: 6px;
	padding: 8px; border: 1px solid var(--ink-700); background: var(--ink-850); border-radius: 4px;
}
.pt-mtf-cell__tf {
	font-family: "JetBrains Mono", monospace; font-size: 11px; font-weight: 600;
	letter-spacing: 0.06em; color: var(--ink-muted);
}

/* Score breakdown */
.pt-score-total {
	display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 12px;
}
.pt-score-total__num { font-family: "JetBrains Mono", monospace; font-size: 24px; font-weight: 700; color: #fff; }
.pt-score-total__num span { font-size: 14px; color: var(--ink-muted); }
.pt-score-row {
	display: grid; grid-template-columns: 110px 1fr 44px;
	align-items: center; gap: 8px; font-size: 12px; margin-bottom: 8px;
}
.pt-score-row__label { color: var(--ink-muted); }
.pt-score-bar { height: 6px; width: 100%; overflow: hidden; border-radius: 999px; background: var(--ink-800); }
.pt-score-bar__fill { height: 100%; transition: width 240ms; }
.pt-score-bar__fill.is-good { background: var(--bull); }
.pt-score-bar__fill.is-mid  { background: var(--warn); }
.pt-score-bar__fill.is-low  { background: var(--ink-600); }
.pt-score-row__val { font-family: "JetBrains Mono", monospace; text-align: right; color: var(--ink-muted); }
.pt-score-row__val span { color: #fff; }

/* Reasoning */
.pt-reason-list { margin: 0; padding: 0; list-style: none; }
.pt-reason-list li {
	display: flex; gap: 8px; font-size: 12px; color: rgba(255,255,255,0.9); margin-bottom: 6px;
}
.pt-reason-list .num { color: var(--accent); }
.pt-reason-block + .pt-reason-block { margin-top: 12px; }
.pt-reason-block__head {
	margin-bottom: 8px; font-size: 10px; font-weight: 600;
	text-transform: uppercase; letter-spacing: 0.22em; color: var(--ink-muted);
}
.pt-confirm { display: flex; flex-wrap: wrap; gap: 6px; }
.pt-confirm span {
	padding: 2px 8px; border: 1px solid var(--ink-700); background: var(--ink-850);
	border-radius: 3px; font-size: 11px; color: var(--ink-muted); text-transform: capitalize;
}

/* Key levels */
.pt-level {
	display: flex; align-items: center; justify-content: space-between;
	padding: 6px 10px; border: 1px solid var(--ink-700); background: var(--ink-850);
	border-radius: 4px; margin-bottom: 6px;
}
.pt-level__lhs { display: flex; align-items: center; gap: 8px; }
.pt-level__type { font-family: "JetBrains Mono", monospace; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; }
.pt-level__type.is-r { color: var(--bear); }
.pt-level__type.is-s { color: var(--bull); }
.pt-level__price { font-family: "JetBrains Mono", monospace; font-size: 14px; color: #fff; }
.pt-level__strength { display: flex; gap: 2px; }
.pt-level__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--ink-700); }
.pt-level__dot.is-on { background: var(--accent); }

/* Risk plan */
.pt-stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.pt-stat {
	padding: 10px; border: 1px solid var(--ink-700); background: var(--ink-850); border-radius: 4px;
}
.pt-stat__label { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.18em; color: var(--ink-muted); }
.pt-stat__value { margin-top: 4px; font-family: "JetBrains Mono", monospace; font-size: 14px; font-weight: 600; color: #fff; }
.pt-stat.is-bull .pt-stat__value { color: var(--bull); }
.pt-stat.is-bear .pt-stat__value { color: var(--bear); }
.pt-stat.is-warn .pt-stat__value { color: var(--warn); }

.pt-calc {
	margin-top: 12px; padding: 12px; border: 1px solid var(--ink-700);
	background: var(--ink-850); border-radius: 4px;
}
.pt-calc__head {
	margin-bottom: 8px; font-size: 10px; font-weight: 600;
	text-transform: uppercase; letter-spacing: 0.22em; color: var(--ink-muted);
}
.pt-calc__inputs { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.pt-calc label { display: block; font-size: 12px; color: var(--ink-muted); }
.pt-calc input {
	margin-top: 4px; width: 100%; padding: 6px 8px;
	border: 1px solid var(--ink-700); background: var(--ink-900); color: #fff;
	font-family: "JetBrains Mono", monospace; font-size: 14px;
	border-radius: 3px; outline: none;
}
.pt-calc input:focus { border-color: var(--accent); }
.pt-calc__result {
	display: flex; justify-content: space-between; align-items: center;
	margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--ink-700);
	font-size: 12px;
}
.pt-calc__result-value { font-family: "JetBrains Mono", monospace; font-size: 16px; font-weight: 600; color: var(--accent); }

/* Backtest */
.pt-bt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 12px; }
.pt-bt-stat {
	padding: 8px; border: 1px solid var(--ink-700); background: var(--ink-850); border-radius: 4px;
}
.pt-bt-stat__label { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.18em; color: var(--ink-muted); }
.pt-bt-stat__value { margin-top: 2px; font-family: "JetBrains Mono", monospace; font-size: 14px; font-weight: 600; }
.pt-bt-stat.is-bull .pt-bt-stat__value { color: var(--bull); }
.pt-bt-stat.is-bear .pt-bt-stat__value { color: var(--bear); }
.pt-bt-stat.is-warn .pt-bt-stat__value { color: var(--warn); }
.pt-bt-stat__value:not(.is-bull):not(.is-bear):not(.is-warn) { color: #fff; }

.pt-ci {
	padding: 10px 12px; border: 1px solid var(--ink-700); background: var(--ink-850);
	border-radius: 4px; margin-bottom: 12px;
}
.pt-ci__head {
	display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px;
	font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.22em; color: var(--ink-muted);
}
.pt-ci__head-val { font-family: "JetBrains Mono", monospace; font-size: 12px; font-weight: 600; color: #fff; text-transform: none; letter-spacing: 0; }
.pt-ci__bar { position: relative; height: 8px; background: var(--ink-800); border-radius: 999px; }
.pt-ci__band { position: absolute; top: 0; bottom: 0; background: rgba(125,211,252,0.4); border-radius: 999px; }
.pt-ci__marker { position: absolute; top: -2px; height: 12px; width: 2px; background: #fff; }
.pt-ci__ref { position: absolute; top: -4px; height: 16px; width: 1px; background: var(--ink-600); }
.pt-ci__scale { display: flex; justify-content: space-between; margin-top: 4px; font-size: 10px; color: var(--ink-muted); }

.pt-bt-status {
	padding: 8px 12px; border-radius: 4px; font-size: 12px; margin-bottom: 8px;
}
.pt-bt-status.is-reliable { border: 1px solid var(--bull-bd); background: var(--bull-dim); color: var(--bull); }
.pt-bt-status.is-warn     { border: 1px solid var(--warn-bd); background: var(--warn-dim); color: var(--warn); }

.pt-bt-notes { margin: 0; padding: 0; list-style: none; }
.pt-bt-notes li {
	display: flex; gap: 8px; font-size: 12px; color: var(--ink-muted); margin-bottom: 4px;
}
.pt-bt-notes li::before { content: "›"; color: var(--ink-600); }

/* Warnings */
.pt-warn-block { padding: 12px; border: 1px solid var(--warn-bd); background: var(--warn-dim); border-radius: 4px; }
.pt-warn-block__head { margin-bottom: 6px; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.22em; color: var(--warn); }
.pt-warn-block ul { margin: 0; padding: 0; list-style: none; }
.pt-warn-block li {
	display: flex; gap: 8px; font-size: 12px; color: rgba(245, 165, 36, 0.9); margin-bottom: 4px;
}
.pt-empty { font-size: 12px; color: var(--ink-muted); }

/* Chart */
.pt-chart-host { padding: 0; }
#pt-chart { height: 420px; width: 100%; }

/* Disclaimer */
.pt-disclaimer {
	grid-column: span 12; margin-top: 8px;
	padding: 16px; border: 1px solid rgba(30, 37, 48, 0.6);
	background: rgba(11, 14, 19, 0.4); border-radius: 6px;
	font-size: 11px; line-height: 1.6; color: var(--ink-muted);
}
.pt-disclaimer strong { color: rgba(255,255,255,0.8); }

/* Fallback page */
.pt-fallback { padding: 80px 24px; max-width: 720px; margin: 0 auto; text-align: center; }
.pt-fallback h1 { margin: 0 0 8px; font-size: 28px; color: #fff; }
.pt-fallback__sub { margin: 0 0 24px; color: var(--ink-muted); }
.pt-button {
	display: inline-block; padding: 10px 20px; border-radius: 4px;
	border: 1px solid var(--accent-bd); background: var(--accent-dim); color: var(--accent);
	font-weight: 600; text-decoration: none;
}
.pt-button:hover { background: rgba(125,211,252,0.25); text-decoration: none; }
.pt-fallback__posts { margin-top: 48px; text-align: left; }
.pt-fallback__posts article { padding: 16px 0; border-top: 1px solid var(--ink-700); }
.pt-fallback__posts h2 { font-size: 18px; margin: 0 0 4px; }
.pt-fallback__posts a { color: #fff; }
