/* brok – minimal dark dashboard */

:root {
    --bg:           #0b0f14;
    --bg-elev:      #11161d;
    --bg-card:      #161c25;
    --border:       #232b36;
    --border-soft:  #1c232c;
    --text:         #d9e1ea;
    --text-mute:    #7e8a99;
    --pos:          #4ade80;
    --neg:          #f87171;
    --warn:         #fbbf24;
    --info:         #60a5fa;
    --kill:         #ef4444;
    --kill-hover:   #dc2626;
    --primary:      #3b82f6;
    --primary-hov:  #2563eb;
    --success:      #22c55e;
    --shadow:       0 1px 0 rgba(255,255,255,0.03), 0 12px 32px rgba(0,0,0,0.35);
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--text);
    font: 14px/1.45 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -webkit-text-size-adjust: 100%;
}

/* Respect iPhone notch / Android gesture bar on edge-to-edge devices */
@supports (padding: max(0px)) {
    .topbar    { padding-left:  max(1.5rem, env(safe-area-inset-left));
                 padding-right: max(1.5rem, env(safe-area-inset-right)); }
    .container { padding-left:  max(1.5rem, env(safe-area-inset-left));
                 padding-right: max(1.5rem, env(safe-area-inset-right)); }
    .footer    { padding-bottom: max(1.5rem, env(safe-area-inset-bottom)); }
}

a            { color: var(--info); text-decoration: none; }
a:hover      { text-decoration: underline; }
code, pre    { font-family: "JetBrains Mono", Consolas, Menlo, monospace; font-size: 12px; }
pre          { white-space: pre-wrap; word-break: break-word; }

/* ---- top bar ---- */
.topbar {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    padding: 0.75rem 1.5rem;
    background: var(--bg-elev);
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    z-index: 10;
}
/* Hide horizontal scrollbar of the wrapping nav row but keep scrollability */
.nav::-webkit-scrollbar { display: none; }
.nav { scrollbar-width: none; }
.brand { display: flex; align-items: center; gap: 0.55rem; font-size: 1rem; }
.brand-center { justify-content: center; margin-bottom: 1rem; }
.brand-dot {
    width: 10px; height: 10px; border-radius: 50%;
    background: var(--success);
    box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.15);
}
.brand-sub { color: var(--text-mute); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; margin-left: 0.5rem; }

.nav { display: flex; gap: 0.35rem; flex: 1; }
.nav a {
    padding: 0.35rem 0.75rem;
    border-radius: 6px;
    color: var(--text-mute);
}
.nav a:hover  { color: var(--text); background: var(--bg-card); text-decoration: none; }
.nav a.active { color: var(--text); background: var(--bg-card); }

.logout { margin: 0; }
.btn-ghost { background: transparent; border: 1px solid var(--border); color: var(--text-mute); }
.btn-ghost:hover { color: var(--text); border-color: var(--text-mute); }

/* ---- buttons ---- */
.btn {
    appearance: none;
    border: none;
    border-radius: 6px;
    padding: 0.55rem 1rem;
    font-weight: 500;
    cursor: pointer;
    font-size: 14px;
    color: white;
    background: var(--primary);
    transition: background 0.12s ease, transform 0.05s ease;
}
.btn:hover    { background: var(--primary-hov); }
.btn:active   { transform: translateY(1px); }
.btn-primary  { background: var(--primary); }
.btn-success  { background: var(--success); }
.btn-warn     { background: var(--warn); color: #1a1300; }
.btn-warn:hover { background: #f59e0b; }
.btn-danger   { background: var(--kill); }
.btn-danger:hover { background: var(--kill-hover); }
.btn-sm       { padding: 0.3rem 0.65rem; font-size: 12px; }
.btn-lg       { padding: 0.75rem 1.5rem; font-size: 15px; }
.btn-xl       {
    padding: 1.1rem 2.6rem;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: 0 0 0 6px rgba(239, 68, 68, 0.15);
}

/* ---- layout ---- */
.container { padding: 1.5rem; max-width: 1280px; margin: 0 auto; }
.footer {
    text-align: center;
    padding: 1.5rem;
    color: var(--text-mute);
    font-size: 12px;
}

.page-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.5rem 1rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}
.page-head h1 { font-size: 1.4rem; margin: 0; }

/* ---- cards ---- */
.card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 1rem 1.25rem;
    margin-bottom: 1rem;
    box-shadow: var(--shadow);
}
.card h3 { margin: 0 0 0.75rem 0; font-size: 0.9rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-mute); }
.card-label { color: var(--text-mute); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; }
.card-value { font-size: 1.8rem; font-weight: 600; margin-top: 0.2rem; }
.card-sub   { font-size: 12px; margin-top: 0.15rem; }
.card-foot  { font-size: 11px; margin-top: 0.35rem; }

.grid          { display: grid; gap: 1rem; }
.grid.stats    { grid-template-columns: repeat(4, 1fr); margin-bottom: 1rem; }
.grid.stats-6  { grid-template-columns: repeat(6, 1fr); }
.grid.two      { grid-template-columns: 2fr 1fr; }
.card.wide     { grid-column: span 1; }

/* ---- sub-navigation (tabs inside a section, e.g. /strategies vs.
 *      /strategies/analysis). Sits directly under the page-head and
 *      mirrors the top-nav visual language so the user sees that
 *      these are sibling views, not a separate part of the app.    */
.subnav {
    display: flex;
    gap: 0.35rem;
    margin: 0 0 1rem 0;
    flex-wrap: wrap;
}
.subnav a {
    padding: 0.35rem 0.85rem;
    border-radius: 6px;
    color: var(--text-mute);
    font-size: 13px;
    border: 1px solid transparent;
}
.subnav a:hover  { color: var(--text); background: var(--bg-card); text-decoration: none; }
.subnav a.active { color: var(--text); background: var(--bg-card); border-color: var(--border); }

/* ---- analysis heatmap (used on /strategies/analysis): per-cell and
 *      per-row tinting based on avg-R so eye-scanning the worst/best
 *      buckets is instant. Bands intentionally tight - sample sizes
 *      are small, and we want visual differentiation, not nuance.   */
.heat-pos-3 { background: rgba(34, 197, 94, 0.28); color: #d1fadf; }
.heat-pos-2 { background: rgba(34, 197, 94, 0.18); color: #bbf7d0; }
.heat-pos-1 { background: rgba(34, 197, 94, 0.10); color: #bbf7d0; }
.heat-zero  { background: transparent; color: var(--text-mute); }
.heat-neg-1 { background: rgba(248, 113, 113, 0.10); color: #fecaca; }
.heat-neg-2 { background: rgba(248, 113, 113, 0.18); color: #fecaca; }
.heat-neg-3 { background: rgba(248, 113, 113, 0.28); color: #fee2e2; }
.heat-table tbody tr { transition: background 0.1s ease; }
.heat-table tbody tr:hover { background: rgba(255,255,255,0.04); }

/* ---- kill switch top section ---- */
.dash-top { margin-bottom: 1rem; }
.kill-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    background: linear-gradient(180deg, #161c25, #11161d);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 1.1rem 1.5rem;
}
.kill-card.off {
    border-color: var(--kill);
    background: linear-gradient(180deg, #2a1212, #170a0a);
}
.kill-card h2 { margin: 0 0 0.2rem 0; font-size: 1.05rem; }
.kill-text p  { margin: 0; color: var(--text-mute); }

/* ---- forms ---- */
.form {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    max-width: 360px;
    width: 100%;
}
.form label, .form-grid label {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    color: var(--text-mute);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
input[type="text"],
input[type="password"],
input[type="number"],
select,
textarea {
    width: 100%;
    padding: 0.5rem 0.7rem;
    background: var(--bg);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 6px;
    font: 14px/1.4 inherit;
}
input:focus, select:focus, textarea:focus {
    outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(59,130,246,0.25);
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem 1.25rem;
}
.form-grid .span-2 { grid-column: span 2; }
.form-grid fieldset {
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 0.75rem 1rem 1rem 1rem;
    color: var(--text-mute);
    font-size: 12px;
}
.form-grid fieldset legend { padding: 0 0.4rem; text-transform: uppercase; letter-spacing: 0.06em; }

/* Nested grids inside fieldsets - drive column count via classes (not
 * inline styles) so the mobile breakpoints below can override them. */
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0.85rem 1rem; }
.form-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0.85rem 1rem; }

/* Full-width label/input pair sitting below a nested grid (e.g.
 * "RSS feeds" textbox under a 2-col grid). Display/flex inherits
 * from `.form-grid label`; we only add the top spacing the old
 * inline `style="margin-top:.5rem; display:block"` provided. */
.stacked-input { margin-top: 0.85rem; }

.checkbox { flex-direction: row !important; align-items: center; gap: 0.5rem !important; color: var(--text) !important; text-transform: none !important; font-size: 14px !important; letter-spacing: 0 !important; }
.checkbox input { width: auto; }

/* ---- tables ---- */
.table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.table th, .table td {
    text-align: left;
    padding: 0.55rem 0.6rem;
    border-bottom: 1px solid var(--border-soft);
}
.table th {
    color: var(--text-mute);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 11px;
    font-weight: 500;
}
.table.compact th, .table.compact td { padding: 0.35rem 0.5rem; }
.table tbody tr:hover { background: rgba(255,255,255,0.02); }
.table th.th-group {
    text-align: center;
    border-bottom: 1px solid var(--border);
    color: var(--text);
    font-weight: 600;
    letter-spacing: 0.04em;
}
.muted.small { font-size: 0.85em; }

/* Optional wrapper for very wide tables: scrolls horizontally on small
 * screens with a subtle gradient on the right edge so the user knows
 * more columns exist off-screen. Apply by wrapping the <table> in
 * <div class="table-scroll">. */
.table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    position: relative;
}
.table-scroll::after {
    content: "";
    position: absolute;
    top: 0; right: 0; bottom: 0;
    width: 24px;
    pointer-events: none;
    background: linear-gradient(90deg, transparent, var(--bg-card));
    opacity: 0;
    transition: opacity 0.15s ease;
}
@media (max-width: 900px) {
    .table-scroll::after { opacity: 0.9; }
}

/* ---- alerts ---- */
.alert {
    padding: 0.7rem 1rem;
    border-radius: 8px;
    margin-bottom: 1rem;
    font-size: 13px;
    border: 1px solid transparent;
}
.alert.error { background: rgba(248, 113, 113, 0.08); border-color: rgba(248, 113, 113, 0.35); color: #fecaca; }
.alert.warn  { background: rgba(251, 191, 36, 0.08); border-color: rgba(251, 191, 36, 0.35); color: #fde68a; }
.alert.info  { background: rgba(96, 165, 250, 0.08); border-color: rgba(96, 165, 250, 0.35); color: #dbeafe; }

/* ---- key-value list ---- */
.kv { list-style: none; padding: 0; margin: 0; }
.kv li {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.75rem;
    padding: 0.3rem 0;
    border-bottom: 1px dashed var(--border-soft);
    flex-wrap: wrap;
}
.kv li:last-child { border-bottom: none; }
.kv li span    { color: var(--text-mute); }
.kv li strong  { color: var(--text); text-align: right; word-break: break-word; }

/* ---- pills ---- */
.pill {
    display: inline-block;
    padding: 0.18rem 0.55rem;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 12px;
    color: var(--text-mute);
    margin-right: 0.4rem;
    margin-bottom: 0.3rem;
}
.pill-row { margin: 0; }
.pill-on  { background: rgba(34, 197, 94, 0.18); color: #86efac; border-color: rgba(34, 197, 94, 0.4); }
.pill-off { background: rgba(248, 113, 113, 0.15); color: #fecaca; border-color: rgba(248, 113, 113, 0.4); }
.pill-pos { background: rgba(34, 197, 94, 0.18); color: #86efac; border-color: rgba(34, 197, 94, 0.4); }
.pill-neg { background: rgba(248, 113, 113, 0.15); color: #fecaca; border-color: rgba(248, 113, 113, 0.4); }

/* ---- orders specifics ---- */
.fills-summary {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.4rem 0.6rem;
    margin-bottom: 0.8rem;
}
.orphan-details {
    margin-top: 1rem;
    border-top: 1px dashed var(--border-soft);
    padding-top: 0.8rem;
}
.orphan-details summary {
    cursor: pointer;
    padding: 0.3rem 0;
    user-select: none;
}
.orphan-details summary:hover { color: var(--text); }
.row-muted td { opacity: 0.55; }

/* ---- value coloring ---- */
.pos     { color: var(--pos); }
.neg     { color: var(--neg); }
.neutral { color: var(--text-mute); }

/* ---- event badges ---- */
.ev {
    display: inline-block;
    padding: 0 0.45rem;
    border-radius: 4px;
    background: var(--bg);
    border: 1px solid var(--border);
    font-size: 11px;
    color: var(--text-mute);
}
.ev-order_submitted { color: #86efac; border-color: rgba(34,197,94,0.4); }
.ev-order_failed,
.ev-force_close_failed,
.ev-order_cancel_failed { color: #fecaca; border-color: rgba(248,113,113,0.4); }
.ev-risk_reject,
.ev-kill_switch_auto,
.ev-kill_switch { color: #fde68a; border-color: rgba(251,191,36,0.4); }
.ev-force_close { color: #fbbf24; border-color: rgba(251,191,36,0.4); }
.ev-order_cancelled { color: #cbd5e1; }
.ev-cancel_all { color: #fcd34d; border-color: rgba(251,191,36,0.4); }
.ev-kill_switch_off { color: #86efac; border-color: rgba(34,197,94,0.4); }

/* ---- journal tail list ---- */
.journal-tail { list-style: none; padding: 0; margin: 0; }
.journal-tail li { padding: 0.35rem 0; border-bottom: 1px dashed var(--border-soft); font-size: 13px; }
.journal-tail li:last-child { border-bottom: none; }

/* ---- muted helper ---- */
.muted { color: var(--text-mute); }

/* ---- auth pages ---- */
.page-auth {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    background: radial-gradient(circle at 50% 0%, #11161d 0%, #0b0f14 60%, #06090c 100%);
}
.auth-wrap { width: 100%; max-width: 380px; }
.auth-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 1.75rem;
    box-shadow: var(--shadow);
}
.auth-card h1 { font-size: 1.25rem; margin: 0.5rem 0 1rem; }
.auth-footer { text-align: center; color: var(--text-mute); font-size: 11px; margin-top: 1rem; letter-spacing: 0.08em; text-transform: uppercase; }

/* ---- QR ---- */
.qr-wrap svg { width: 240px; height: 240px; background: white; border-radius: 6px; padding: 8px; }

/* ---- charts ---- */
.chart-toolbar {
    display: flex;
    align-items: center;
    gap: 0.4rem 0.5rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
    row-gap: 0.5rem;
}
.chart-toolbar .muted { margin-right: 0.4rem; }
.chart-toolbar-hint { color: var(--text-mute); font-size: 12px; }
.select-sm {
    padding: 0.3rem 0.55rem;
    background: var(--bg-elev);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 4px;
    font-size: 13px;
    min-width: 9rem;
}
.btn-active {
    background: var(--primary);
    color: white;
    border: 1px solid var(--primary);
}
.chart-container {
    width: 100%;
    height: 480px;
    background: #0f1419;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
}
.chart-status {
    margin: 0.6rem 0 0 0;
    font-size: 12px;
}
.status-error { color: #fecaca; }
.status-warn  { color: #fde68a; }

/* ---- legend (journal page) ---- */
.legend { padding: 1rem 1.25rem; }
.legend > summary {
    cursor: pointer;
    font-size: 14px;
    color: var(--text);
    padding: 0.2rem 0;
    list-style-position: inside;
}
.legend > summary:hover { color: var(--info); }
.legend h4 {
    margin: 1.25rem 0 0.4rem;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-mute);
    border-bottom: 1px solid var(--border-soft);
    padding-bottom: 0.3rem;
}
.legend-table {
    margin-top: 0.25rem;
    font-size: 12.5px;
}
.legend-table td {
    padding: 0.3rem 0.55rem;
    vertical-align: top;
}
.legend-table td:first-child {
    white-space: nowrap;
    width: 1%;
    padding-right: 1rem;
}
.legend-table td:first-child code,
.legend-table td:first-child .ev {
    font-size: 11.5px;
}

/* ---- countdown ---- */
.countdown {
    font-family: "JetBrains Mono", Consolas, Menlo, monospace;
    font-variant-numeric: tabular-nums;
    font-weight: 600;
    margin-left: 0.3rem;
}
.countdown-open    { color: var(--pos); }
.countdown-closed  { color: var(--text-mute); }
.countdown-elapsed { color: var(--warn); }

/* ---- funnel ---- */
.funnel-table td.num { text-align: right; }
.funnel-bar-cell { width: 60%; padding-right: 0.5rem; }
.funnel-bar {
    display: inline-block;
    height: 10px;
    background: linear-gradient(90deg, var(--primary), var(--info));
    border-radius: 4px;
    min-width: 4px;
    vertical-align: middle;
}

/* ============================================================
 * Responsive breakpoints
 * ----------------------------------------------------------
 * The site has three audiences:
 *   - >= 901 px  : desktop/laptop, full sidebar-like layout
 *   - 601-900 px : tablets, 2-column dashboard, wider forms
 *   - 421-600 px : phones landscape / small tablets portrait
 *   - <= 420 px  : phones portrait (iPhone SE, etc.)
 * ============================================================ */

/* Tablet & smaller */
@media (max-width: 900px) {
    .grid.stats   { grid-template-columns: repeat(2, 1fr); }
    .grid.stats-6 { grid-template-columns: repeat(3, 1fr); }
    .grid.two     { grid-template-columns: 1fr; }
    .form-grid    { grid-template-columns: 1fr; }
    .form-grid .span-2 { grid-column: span 1; }
    .form-grid-3  { grid-template-columns: 1fr 1fr; }

    .topbar       { flex-wrap: wrap; gap: 0.75rem; padding: 0.6rem 0.9rem; }
    .topbar .logout { margin-left: auto; }
    .nav          { order: 3; flex-basis: 100%; overflow-x: auto; white-space: nowrap; gap: 0.4rem; -webkit-overflow-scrolling: touch; }
    .nav a        { padding: 0.5rem 0.7rem; font-size: 13px; }

    .container    { padding: 0.9rem; }
    .card         { padding: 0.9rem; }
    .card-value   { font-size: 1.4rem; }

    .table        { font-size: 12px; }
    .table th, .table td { padding: 0.4rem 0.5rem; }

    .chart-container { height: 360px; }
    .btn-xl       { padding: 0.85rem 1.2rem; font-size: 14px; box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.15); }
}

/* Phone landscape / small tablet portrait */
@media (max-width: 600px) {
    .grid.stats   { grid-template-columns: repeat(2, 1fr); }
    .grid.stats-6 { grid-template-columns: repeat(2, 1fr); }
    .form-grid-2,
    .form-grid-3 { grid-template-columns: 1fr; }

    .kill-card    { flex-direction: column; align-items: stretch; gap: 0.75rem; padding: 1rem; }
    .kill-card form { width: 100%; }
    .kill-card .btn { width: 100%; }

    .chart-container { height: 280px; }
    .funnel-bar-cell { width: 50%; }

    /* Inputs hit 16px to defeat iOS' "zoom on focus" behaviour.
     * Padding bumped so touch targets reach ~44px (Apple HIG). */
    input[type="text"],
    input[type="password"],
    input[type="number"],
    select,
    textarea       { font-size: 16px; padding: 0.65rem 0.8rem; }

    .btn           { padding: 0.7rem 1rem; min-height: 44px; }
    .btn-sm        { padding: 0.5rem 0.85rem; min-height: 36px; font-size: 13px; }
    .nav a         { min-height: 36px; display: inline-flex; align-items: center; }

    /* Wide data tables: prefer wrapping in <div class="table-scroll">.
     * Bare <table class="table"> tags inside a card still get a soft
     * fallback (block + overflow) so old templates don't break, but
     * .legend-table is excluded - its text-heavy descriptions wrap
     * better than they horizontally-scroll. */
    .card > .table:not(.legend-table) {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap;
    }
    .legend-table { font-size: 12px; }
    .legend-table td:first-child { white-space: normal; }

    .pill, .ev    { font-size: 11px; }
    code, pre     { font-size: 13px; }

    .brand-sub    { display: none; }
    .topbar       { padding: 0.55rem 0.75rem; gap: 0.5rem; }
    .logout .btn  { padding: 0.45rem 0.85rem; font-size: 13px; min-height: 36px; }

    .page-head h1 { font-size: 1.2rem; }
}

/* iPhone-SE-class / older Android portrait */
@media (max-width: 420px) {
    .grid.stats     { grid-template-columns: 1fr; }
    .grid.stats-6   { grid-template-columns: 1fr; }
    .container      { padding: 0.75rem; }
    .card           { padding: 0.8rem; }
    .card-value     { font-size: 1.2rem; }
    .btn-xl         { padding: 0.8rem 0.9rem; font-size: 13px; letter-spacing: 0.04em; }
    .auth-card      { padding: 1.25rem; }
    .qr-wrap svg    { width: 200px; height: 200px; }
}

/* ---- settings: RSS-feed editor ---- */
.rss-feeds-block { display: block; }
.rss-feeds-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.75rem;
    margin-bottom: 0.4rem;
    font-size: 13px;
}
.rss-feeds-count { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; }
.rss-feeds-table { margin-top: 0.35rem; }
.rss-feeds-table th.num,
.rss-feeds-table td.num { text-align: right; white-space: nowrap; }
.rss-feeds-table th:last-child,
.rss-feeds-table td:last-child { width: 1%; white-space: nowrap; }
.rss-feeds-table .rss-host {
    color: var(--text);
    font-weight: 500;
    font-size: 13px;
    line-height: 1.2;
}
.rss-feeds-table .rss-url {
    color: var(--text-mute);
    font-size: 11px;
    word-break: break-all;
    margin-top: 0.1rem;
}
.rss-feeds-table .rss-url a { color: inherit; text-decoration: none; }
.rss-feeds-table .rss-url a:hover { color: var(--text); text-decoration: underline; }
.rss-empty {
    padding: 0.6rem 0.75rem;
    margin: 0.4rem 0 0 0;
    background: var(--bg-elev);
    border: 1px dashed var(--border-soft);
    border-radius: 6px;
    font-size: 13px;
}
.rss-add-row {
    display: flex;
    gap: 0.4rem;
    margin-top: 0.6rem;
    align-items: stretch;
}
.rss-add-row input[type="url"] {
    flex: 1 1 auto;
    min-width: 0;
}
.rss-add-error { font-size: 12px; color: var(--warn); margin: 0.35rem 0 0 0; }
.rss-manual { margin-top: 0.7rem; }
.rss-manual > summary {
    cursor: pointer;
    font-size: 12px;
    color: var(--text-mute);
    padding: 0.25rem 0;
    user-select: none;
}
.rss-manual > summary:hover { color: var(--text); }
.rss-manual textarea {
    width: 100%;
    margin-top: 0.4rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 12px;
    min-height: 7rem;
}
.rss-manual-actions { display: flex; align-items: center; gap: 0.6rem; margin-top: 0.4rem; flex-wrap: wrap; }
.rss-manual-hint { font-size: 11px; }

/* Minimal badge for the per-feed counter (stale highlight). Generic
 * enough that other settings widgets can reuse `.badge .badge-warn`
 * later without re-declaring. */
.badge {
    display: inline-block;
    padding: 0.05rem 0.4rem;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    background: var(--bg-elev);
    color: var(--text-mute);
    border: 1px solid var(--border-soft);
}
.badge-warn { background: rgba(251, 191, 36, 0.15); color: var(--warn); border-color: rgba(251, 191, 36, 0.35); }

@media (max-width: 640px) {
    .rss-add-row { flex-direction: column; }
    .rss-feeds-head { flex-direction: column; align-items: flex-start; gap: 0.15rem; }
    /* Hide the long URL on phones - hostname is enough; full URL still
     * accessible via the <a href>. */
    .rss-feeds-table .rss-url { display: none; }
}

/* ----------------------------------------------------------------------
 * News-Symbol-Matching (SymbolMatcher) settings widget.
 * Mirrors the visual language of the RSS block above so the two
 * adjacent fieldsets feel cohesive.
 * ---------------------------------------------------------------------- */
.alias-block {
    border: 1px solid var(--border-soft);
    border-radius: 8px;
    padding: 0.75rem 0.9rem;
    margin-top: 0.6rem;
    background: var(--bg-elev);
}
.alias-heading { margin: 0 0 0.35rem 0; font-size: 13px; font-weight: 600; }
.alias-subheading { margin: 0.8rem 0 0.35rem 0; font-size: 12px; font-weight: 600; color: var(--text-mute); text-transform: uppercase; letter-spacing: 0.04em; }
.alias-defaults { margin-top: 0.6rem; }
.alias-defaults > summary {
    cursor: pointer;
    font-size: 12px;
    color: var(--text-mute);
    padding: 0.25rem 0;
    user-select: none;
}
.alias-defaults > summary:hover { color: var(--text); }
.alias-ambig-list { margin: 0.4rem 0 0 0; display: flex; flex-wrap: wrap; gap: 0.3rem; }
.alias-ambig-list code {
    font-size: 11px;
    padding: 0.1rem 0.35rem;
    border-radius: 4px;
    background: var(--bg);
    border: 1px solid var(--border-soft);
}
.data-table-compact {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
    margin-top: 0.4rem;
}
.data-table-compact th,
.data-table-compact td {
    text-align: left;
    padding: 0.25rem 0.5rem;
    border-bottom: 1px solid var(--border-soft);
}
.data-table-compact th {
    color: var(--text-mute);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 10px;
}
.data-table-compact td code { font-size: 11px; }
