*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

        :root {
            --bg-0: var(--c-bg-0a0a0f);
            --bg-1: var(--c-bg-111118);
            --bg-2: var(--c-bg-1a1a24);
            --bg-3: var(--c-bg-22222e);
            --border: var(--c-bg-2a2a3a);
            --text-0: var(--c-text-e8e8f0);
            --text-1: var(--c-text-a0a0b8);
            --text-2: var(--c-text-6a6a80);
            --green: var(--c-neon);
            --green-dim: var(--c-success-deep);
            --red: var(--c-stats-red);
            --red-dim: var(--c-stats-red-dim);
            --amber: var(--c-accent-amber);
            --blue: var(--c-stats-blue);
            --cyan: var(--c-stats-cyan);
            --font: 'JetBrains Mono', monospace;
        }

        html { background: var(--bg-0); }
        body {
            font-family: var(--font);
            background: var(--bg-0);
            color: var(--text-0);
            min-height: 100vh;
            -webkit-font-smoothing: antialiased;
        }

        /* ── Top bar ── */
        .stats-topbar {
            position: sticky;
            top: 0;
            z-index: 100;
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 12px 16px;
            background: var(--bg-0);
            border-bottom: 1px solid var(--border);
        }
        .stats-back {
            display: flex;
            align-items: center;
            gap: 6px;
            color: var(--text-1);
            text-decoration: none;
            font-size: 13px;
            font-family: var(--font);
        }
        .stats-back:hover { color: var(--text-0); }
        .stats-back svg { width: 16px; height: 16px; }
        .stats-title {
            font-size: 14px;
            font-weight: 600;
            letter-spacing: 0.5px;
        }
        .stats-period-sel {
            margin-left: auto;
            display: flex;
            gap: 2px;
            background: var(--bg-2);
            padding: 2px;
        }
        .stats-period-btn {
            font-family: var(--font);
            font-size: 10px;
            font-weight: 500;
            padding: 4px 8px;
            background: none;
            border: none;
            color: var(--text-2);
            cursor: pointer;
            letter-spacing: 0.5px;
        }
        .stats-period-btn.active {
            background: var(--bg-3);
            color: var(--text-0);
        }

        /* ── Content ── */
        .stats-content {
            padding: 0 0 80px 0;
        }

        /* ── Section ── */
        .stats-section {
            border-bottom: 1px solid var(--border);
        }
        .stats-section-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 14px 16px 0;
        }
        .stats-section-title {
            font-size: 10px;
            font-weight: 600;
            letter-spacing: 1.5px;
            color: var(--text-2);
            text-transform: uppercase;
        }
        .stats-section-sub {
            font-size: 10px;
            color: var(--text-2);
        }

        /* ── Headline numbers ── */
        .stats-headline {
            display: flex;
            padding: 12px 16px 16px;
            gap: 0;
        }
        .stats-headline-item {
            flex: 1;
            min-width: 0;
        }
        .stats-headline-item:not(:last-child) {
            border-right: 1px solid var(--border);
            padding-right: 12px;
            margin-right: 12px;
        }
        .stats-hl-label {
            font-size: 9px;
            font-weight: 500;
            color: var(--text-2);
            letter-spacing: 0.8px;
            text-transform: uppercase;
            margin-bottom: 4px;
        }
        .stats-hl-value {
            font-size: 18px;
            font-weight: 600;
            color: var(--text-0);
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }
        .stats-hl-value.positive { color: var(--green); }
        .stats-hl-value.negative { color: var(--red); }

        /* ── Metrics grid ── */
        .stats-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            padding: 0 16px 16px;
            gap: 0;
        }
        .stats-grid-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 10px 0;
            border-bottom: 1px solid rgba(42, 42, 58, 0.5);
        }
        .stats-grid-item:nth-child(odd) {
            padding-right: 12px;
            border-right: 1px solid rgba(42, 42, 58, 0.5);
            margin-right: 12px;
        }
        .stats-gi-label {
            font-size: 10px;
            color: var(--text-2);
        }
        .stats-gi-value {
            font-size: 11px;
            font-weight: 500;
            color: var(--text-0);
            text-align: right;
        }
        .stats-gi-value.positive { color: var(--green); }
        .stats-gi-value.negative { color: var(--red); }

        /* ── Chart containers ── */
        .stats-chart-wrap {
            padding: 12px 16px 16px;
            position: relative;
        }
        .stats-chart-wrap canvas {
            width: 100% !important;
            height: 200px !important;
        }

        /* ── Calendar heatmap ── */
        .stats-calendar {
            padding: 8px 16px 16px;
            overflow-x: auto;
            -webkit-overflow-scrolling: touch;
        }
        .stats-cal-grid {
            display: grid;
            grid-template-columns: repeat(53, 1fr);
            gap: 2px;
            min-width: 500px;
        }
        .stats-cal-cell {
            aspect-ratio: 1;
            min-width: 7px;
        }
        .stats-cal-labels {
            display: flex;
            justify-content: space-between;
            padding: 4px 0 0;
            min-width: 500px;
        }
        .stats-cal-label {
            font-size: 8px;
            color: var(--text-2);
        }
        .stats-cal-legend {
            display: flex;
            align-items: center;
            gap: 4px;
            padding: 8px 0 0;
            font-size: 8px;
            color: var(--text-2);
        }
        .stats-cal-legend-cell {
            width: 10px;
            height: 10px;
        }
        .stats-cal-legend-cell.loss-strong { background: rgba(255,68,102,0.6); }
        .stats-cal-legend-cell.loss-light { background: rgba(255,68,102,0.25); }
        .stats-cal-legend-cell.neutral { background: rgba(42,42,58,0.3); }
        .stats-cal-legend-cell.win-light { background: rgba(0,255,136,0.25); }
        .stats-cal-legend-cell.win-strong { background: rgba(0,255,136,0.6); }

        /* ── Hourly heatmap ── */
        .stats-hourly {
            padding: 8px 16px 16px;
        }
        .stats-hourly-grid {
            display: grid;
            grid-template-columns: 30px repeat(24, 1fr);
            gap: 2px;
        }
        .stats-hourly-label {
            font-size: 8px;
            color: var(--text-2);
            display: flex;
            align-items: center;
        }
        .stats-hourly-cell {
            aspect-ratio: 1;
            min-width: 0;
        }
        .stats-hourly-header {
            font-size: 7px;
            color: var(--text-2);
            text-align: center;
        }

        /* ── Agent breakdown table ── */
        .stats-table-wrap {
            padding: 0 16px 16px;
            overflow-x: auto;
            -webkit-overflow-scrolling: touch;
        }
        .stats-table {
            width: 100%;
            border-collapse: collapse;
            min-width: 500px;
        }
        .stats-table th {
            font-size: 9px;
            font-weight: 600;
            color: var(--text-2);
            letter-spacing: 0.5px;
            text-transform: uppercase;
            text-align: left;
            padding: 8px 6px;
            border-bottom: 1px solid var(--border);
            white-space: nowrap;
        }
        .stats-table th:not(:first-child) { text-align: right; }
        .stats-table td {
            font-size: 11px;
            padding: 8px 6px;
            border-bottom: 1px solid rgba(42, 42, 58, 0.4);
            white-space: nowrap;
        }
        .stats-table td:not(:first-child) { text-align: right; }
        .stats-table .agent-name {
            display: flex;
            align-items: center;
            gap: 6px;
        }
        .stats-table .agent-dot {
            width: 8px;
            height: 8px;
            flex-shrink: 0;
        }
        .stats-table .positive { color: var(--green); }
        .stats-table .negative { color: var(--red); }

        /* ── Trade log ── */
        .stats-trades {
            padding: 0 16px 16px;
        }
        .stats-trade-row {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px 0;
            border-bottom: 1px solid rgba(42, 42, 58, 0.4);
        }
        .stats-trade-side {
            font-size: 9px;
            font-weight: 600;
            letter-spacing: 0.5px;
            padding: 2px 6px;
            min-width: 28px;
            text-align: center;
        }
        .stats-trade-side.yes { background: rgba(0, 255, 136, 0.12); color: var(--green); }
        .stats-trade-side.no { background: rgba(255, 68, 102, 0.12); color: var(--red); }
        .stats-trade-ticker {
            font-size: 11px;
            font-weight: 500;
            flex: 1;
            min-width: 0;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        .stats-trade-meta {
            text-align: right;
        }
        .stats-trade-pnl {
            font-size: 11px;
            font-weight: 500;
        }
        .stats-trade-pnl.positive { color: var(--green); }
        .stats-trade-pnl.negative { color: var(--red); }
        .stats-trade-time {
            font-size: 9px;
            color: var(--text-2);
        }
        .stats-trade-filter {
            display: flex;
            gap: 2px;
            padding: 8px 0;
            background: var(--bg-2);
            padding: 2px;
            margin-bottom: 8px;
        }
        .stats-trade-filter-btn {
            font-family: var(--font);
            font-size: 10px;
            padding: 4px 10px;
            background: none;
            border: none;
            color: var(--text-2);
            cursor: pointer;
        }
        .stats-trade-filter-btn.active {
            background: var(--bg-3);
            color: var(--text-0);
        }

        /* ── Distribution chart ── */
        .stats-dist-bars {
            display: flex;
            align-items: flex-end;
            gap: 2px;
            height: 100px;
            padding: 12px 16px 4px;
        }
        .stats-dist-bar {
            flex: 1;
            min-width: 0;
            transition: height 0.3s ease;
        }
        .stats-dist-bar.is-positive { background: var(--green); }
        .stats-dist-bar.is-negative { background: var(--red); }
        .stats-dist-bar.is-neutral { background: var(--bg-3); }
        .stats-dist-labels {
            display: flex;
            justify-content: space-between;
            padding: 2px 16px 16px;
            font-size: 8px;
            color: var(--text-2);
        }

        /* ── Streaks ── */
        .stats-streaks {
            display: flex;
            padding: 0 16px 16px;
            gap: 0;
        }
        .stats-streak-item {
            flex: 1;
            text-align: center;
            padding: 10px 0;
        }
        .stats-streak-item:not(:last-child) {
            border-right: 1px solid var(--border);
        }
        .stats-streak-val {
            font-size: 22px;
            font-weight: 700;
        }
        .stats-streak-val.positive { color: var(--green); }
        .stats-streak-val.negative { color: var(--red); }
        .stats-streak-val.neutral { color: var(--text-0); }
        .stats-streak-frac {
            color: var(--text-2);
            font-size: 12px;
        }
        .stats-streak-label {
            font-size: 9px;
            color: var(--text-2);
            margin-top: 2px;
        }

        /* ── Correlation matrix ── */
        .stats-corr {
            padding: 8px 16px 16px;
        }
        .stats-corr-grid {
            display: grid;
            gap: 2px;
        }
        .stats-corr-cell {
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 9px;
            font-weight: 500;
            aspect-ratio: 1;
            min-height: 28px;
        }
        .stats-corr-label {
            display: flex;
            align-items: center;
            font-size: 8px;
            color: var(--text-2);
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        /* ── Empty state ── */
        .stats-empty {
            text-align: center;
            padding: 40px 16px;
            color: var(--text-2);
        }
        .stats-empty-icon {
            font-size: 28px;
            margin-bottom: 8px;
            opacity: 0.4;
        }
        .stats-empty-text {
            font-size: 12px;
        }

        /* ── Loading ── */
        .stats-loading {
            text-align: center;
            padding: 60px 16px;
            color: var(--text-2);
            font-size: 12px;
        }
        @keyframes pulse { 0%, 100% { opacity: 0.4; } 50% { opacity: 1; } }
        .stats-loading-dot {
            display: inline-block;
            animation: pulse 1.2s ease-in-out infinite;
        }

        /* ── Desktop ── */
        @media (min-width: 768px) {
            .stats-content { max-width: 900px; margin: 0 auto; }
            .stats-grid { grid-template-columns: 1fr 1fr 1fr 1fr; }
            .stats-headline { gap: 0; }
            .stats-chart-wrap canvas { height: 260px !important; }
        }
