/* ============================================================
   AIX Bonds Monitor — светлая тема «финансовый терминал».
   Токены дизайна собраны в :root; плотная типографика для данных.
   ============================================================ */

:root {
    /* Палитра */
    --paper:      #F5F6F8;   /* фон страницы, холодный светло-серый */
    --surface:    #FFFFFF;   /* поверхности: таблица, панели */
    --ink:        #18222E;   /* основной текст, тёмно-синие чернила */
    --muted:      #6B7686;   /* вторичный текст */
    --line:       #E3E7ED;   /* разделители */
    --accent:     #0F4C81;   /* фирменный глубокий синий (тон AIX) */
    --accent-bg:  #EAF1F8;   /* подложка активных элементов */
    --gold:       #9A6B15;   /* акцент купона */
    --gold-bg:    #FBF3E2;
    --good:       #1B7A43;   /* зелёный: сделки, рост */
    --good-bg:    #E8F5EE;
    --bad:        #B23842;   /* красный: падение */
    --lowact-bg:  #FFF8E8;   /* подсветка низкой активности */
    --grey-text:  #A6AEB9;   /* «не интересно» */

    /* Типографика */
    --font-ui:   'Inter', system-ui, sans-serif;
    --font-mono: 'IBM Plex Mono', ui-monospace, monospace;
}

* { box-sizing: border-box; }

/* Атрибут hidden обязан скрывать элемент даже там, где компонентный
   стиль задаёт display:flex (авторские стили сильнее UA-стилей). */
[hidden] { display: none !important; }

html, body {
    margin: 0;
    background: var(--paper);
    color: var(--ink);
    font-family: var(--font-ui);
    font-size: 14px;
}

.muted { color: var(--muted); }
.mono  { font-family: var(--font-mono); font-size: 0.92em; }

/* ---------- Шапка ---------- */

.topbar {
    display: flex;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap;
    padding: 10px 16px;
    background: var(--surface);
    border-bottom: 1px solid var(--line);
    position: sticky;
    top: 0;
    z-index: 30;
}

.brand { display: flex; align-items: baseline; gap: 7px; }

.brand-mark {
    font-weight: 700;
    letter-spacing: 0.06em;
    color: #fff;
    background: var(--accent);
    padding: 2px 7px;
    border-radius: 4px;
    font-size: 13px;
}

.brand-name { font-weight: 600; font-size: 15px; }

.market-status {
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 600;
    font-size: 13px;
}

.dot {
    width: 9px; height: 9px;
    border-radius: 50%;
    background: var(--grey-text);
}
.dot.open   { background: var(--good); box-shadow: 0 0 0 3px var(--good-bg); }
.dot.closed { background: var(--bad); }

.refresh-box {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 13px;
}

.profiles-progress {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 12px;
}
.profiles-progress progress { width: 110px; height: 8px; }

/* ---------- Кнопки, поля, чипы ---------- */

.btn {
    font: inherit;
    padding: 5px 11px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: var(--surface);
    color: var(--ink);
    cursor: pointer;
}
.btn:hover { border-color: var(--accent); color: var(--accent); }
.btn-ghost { background: transparent; }

select, input[type="search"], input[type="number"], textarea {
    font: inherit;
    padding: 5px 8px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: var(--surface);
    color: var(--ink);
}
select:focus, input:focus, textarea:focus, .btn:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 1px;
}

.controls {
    padding: 9px 16px 0;
}

.controls-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.search { width: 280px; }

.chips { display: flex; gap: 5px; flex-wrap: wrap; }

.chip {
    font: inherit;
    font-size: 12.5px;
    font-weight: 600;
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: var(--surface);
    color: var(--muted);
    cursor: pointer;
}
.chip.active {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
}
.chip .chip-n { font-weight: 400; opacity: 0.75; margin-left: 3px; }

.counter { margin-left: auto; font-size: 12.5px; }

/* ---------- Панель фильтров ---------- */

.filters {
    margin-top: 9px;
    padding: 11px 14px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    gap: 11px;
}

.filter-group {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    align-items: center;
}
.filter-group label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--muted);
}
.filter-group input[type="number"] { width: 70px; }

.rules { display: flex; gap: 18px; flex-wrap: wrap; }

.rule {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    border: 1px dashed var(--line);
    border-radius: 7px;
    font-size: 13px;
}
.rule-check { display: flex; align-items: center; gap: 5px; cursor: pointer; }
.rule-num   { width: 62px; }
.rule-mode  { font-size: 12.5px; }

/* ---------- Таблица ---------- */

.table-wrap {
    margin: 10px 16px 14px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: auto;
    max-height: calc(100vh - 175px);
}

table.grid {
    border-collapse: separate;
    border-spacing: 0;
    width: 100%;
    font-size: 13px;
}

.grid thead th {
    position: sticky;
    top: 0;
    z-index: 10;
    background: #F0F3F7;
    color: var(--muted);
    font-weight: 600;
    font-size: 11.5px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 8px 9px;
    border-bottom: 1px solid var(--line);
    text-align: left;
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
}
.grid thead th.no-sort { cursor: default; }
.grid thead th .arrow { color: var(--accent); margin-left: 3px; }

.grid tbody td {
    padding: 6px 9px;
    border-bottom: 1px solid #EEF1F5;
    white-space: nowrap;
    vertical-align: middle;
}

.grid tbody tr:hover td { background: #F7FAFD; }

td.num { text-align: right; font-family: var(--font-mono); font-size: 12.5px; }

.issuer-cell { max-width: 300px; }
.issuer-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 300px;
    font-weight: 500;
}
.sec-code { font-family: var(--font-mono); font-size: 11px; color: var(--muted); }

/* Бейдж типа купона */
.coupon-type {
    display: inline-block;
    font-size: 10.5px;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 4px;
}
.coupon-type.fixed { background: var(--accent-bg); color: var(--accent); }
.coupon-type.float { background: var(--gold-bg);   color: var(--gold); }

/* ---------- Строковые состояния ---------- */

/* Подсветка низкой активности */
tr.low-activity td { background: var(--lowact-bg); }

/* Сигнатурный элемент: «пульс сделки» — по бумаге прошли сделки
   за последний интервал обновления */
tr.traded td:first-child { box-shadow: inset 3px 0 0 var(--good); }
tr.traded td { background: var(--good-bg); }
.trade-delta {
    display: inline-block;
    font-size: 10.5px;
    font-weight: 700;
    color: #fff;
    background: var(--good);
    border-radius: 999px;
    padding: 1px 7px;
    margin-left: 6px;
    animation: pulse-in 0.6s ease;
}
@keyframes pulse-in {
    0%   { transform: scale(0.6); opacity: 0; }
    100% { transform: scale(1);   opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
    .trade-delta { animation: none; }
}

/* «Не интересно»: строка остаётся, но приглушается */
tr.not-interested td,
tr.not-interested td .issuer-name,
tr.not-interested td .sec-code { color: var(--grey-text); }
tr.not-interested .coupon-type { opacity: 0.45; }

/* Подсветка ячеек по умным правилам */
td.hl-coupon { background: var(--gold-bg); color: var(--gold); font-weight: 600; }
td.hl-ytm    { background: var(--good-bg); color: var(--good); font-weight: 600; }

/* YTM, рассчитанная не по ASK (фолбэк на последнюю сделку) */
.ytm-fallback { color: var(--muted); font-style: italic; }

/* Изменение цены */
.pct-up   { color: var(--good); }
.pct-down { color: var(--bad); }

/* ---------- Флаги ---------- */

.flags-cell { white-space: nowrap; }

.flag-btn {
    font: inherit;
    font-size: 13px;
    line-height: 1;
    border: none;
    background: none;
    cursor: pointer;
    padding: 2px 3px;
    color: #C9CFD8;          /* неактивный флаг — едва заметен */
    border-radius: 4px;
}
.flag-btn:hover { color: var(--muted); background: var(--paper); }

.flag-btn.on-favorite       { color: #C99412; }
.flag-btn.on-watch          { color: var(--accent); }
.flag-btn.on-interesting    { color: var(--good); }
.flag-btn.on-not_interested { color: var(--bad); }

.flag-btn.note-btn.has-note { color: var(--accent); }

/* ---------- Заметка (поповер) ---------- */

.note-pop {
    position: absolute;
    z-index: 50;
    width: 290px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: 0 8px 26px rgba(24, 34, 46, 0.16);
    padding: 11px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.note-pop-title { font-weight: 600; font-size: 13px; }
.note-pop textarea { resize: vertical; }
.note-pop-actions { display: flex; gap: 7px; justify-content: flex-end; }

/* ---------- Прочее ---------- */

.loading-cell {
    text-align: center;
    color: var(--muted);
    padding: 36px 0 !important;
}

.footnote {
    padding: 0 16px 16px;
    font-size: 11.5px;
    line-height: 1.5;
}

/* Узкие экраны: панель скроллится, поиск на всю ширину */
@media (max-width: 760px) {
    .search { width: 100%; }
    .counter { margin-left: 0; }
    .table-wrap { margin: 8px 6px 12px; max-height: none; }
}
