/* =====================================================================
   BillMaster — UI (CSS3, без фреймворків)
   Палітра: тепла кавова + темний текст
   ===================================================================== */
:root {
    --bg:        #f7f4ef;
    --surface:   #ffffff;
    --surface-2: #faf6ee;
    --text:      #2b1f17;
    --muted:     #8a7c6f;
    --border:    #e3dbd0;
    --primary:   #6f4e37;
    --primary-d: #4a3424;
    --primary-l: #a07a5b;
    --accent:    #d99a4f;
    --positive:  #2e8b57;
    --negative:  #c0392b;
    --warn:      #c79a3a;
    --info:      #4a8bc9;
    --shadow:    0 2px 8px rgba(53, 33, 18, .08);
    --shadow-l:  0 1px 3px rgba(53, 33, 18, .06);
    --radius:    10px;
}

/* Dark mode (через data-theme="dark" на <html>) */
html[data-theme="dark"] {
    --bg:        #1c1714;
    --surface:   #28201b;
    --surface-2: #2f2620;
    --text:      #e8dfd2;
    --muted:     #968779;
    --border:    #3d3128;
    --primary:   #c89770;
    --primary-d: #a07a5b;
    --primary-l: #e0b591;
    --accent:    #e8b56f;
    --positive:  #6db98a;
    --negative:  #e57b6c;
    --warn:      #e8c476;
    --info:      #6ea8d9;
    --shadow:    0 2px 8px rgba(0, 0, 0, .3);
    --shadow-l:  0 1px 3px rgba(0, 0, 0, .2);
}
html[data-theme="dark"] .data-table thead th { background: var(--surface-2); }
html[data-theme="dark"] .data-table tbody tr:hover td { background: var(--surface-2); }
html[data-theme="dark"] .data-table tfoot td  { background: var(--surface-2); }
html[data-theme="dark"] .pagination .page { background: var(--surface); color: var(--text); }
html[data-theme="dark"] .pagination .page:hover:not(.disabled):not(.current) { background: var(--surface-2); }
html[data-theme="dark"] .badge { background: var(--surface-2); color: var(--muted); }
html[data-theme="dark"] .filterbar input,
html[data-theme="dark"] .filterbar select,
html[data-theme="dark"] .form-grid input,
html[data-theme="dark"] .form-grid select,
html[data-theme="dark"] .form-grid textarea,
html[data-theme="dark"] .recipe-builder select, html[data-theme="dark"] .recipe-builder input,
html[data-theme="dark"] .purchase-builder select, html[data-theme="dark"] .purchase-builder input {
    background: var(--surface-2); color: var(--text); border-color: var(--border);
}
html[data-theme="dark"] pre, html[data-theme="dark"] .login-hint code {
    background: var(--surface-2); color: var(--text);
}
html[data-theme="dark"] .heatmap td.heat { color: rgba(255,255,255,.85); }
html[data-theme="dark"] .quadrant-star      { background: linear-gradient(135deg, #3d3024, #2e2418); }
html[data-theme="dark"] .quadrant-puzzle    { background: linear-gradient(135deg, #2d2538, #221b30); }
html[data-theme="dark"] .quadrant-plowhorse { background: linear-gradient(135deg, #1f2c3a, #15202c); }
html[data-theme="dark"] .quadrant-dog       { background: linear-gradient(135deg, #3a1f1f, #2c1515); }

/* Theme toggle button */
.theme-toggle {
    background: rgba(255,255,255,.1);
    border: 0; color: #fff; cursor: pointer;
    padding: 6px 10px; border-radius: 8px; font-size: 16px;
    margin-right: 8px;
}
.theme-toggle:hover { background: rgba(255,255,255,.2); }

/* Bell notifications */
.notify-bell {
    position: relative;
    background: rgba(255,255,255,.1);
    border: 0; color: #fff; cursor: pointer;
    padding: 6px 10px; border-radius: 8px; font-size: 16px;
    margin-right: 8px;
}
.notify-bell:hover { background: rgba(255,255,255,.2); }
.notify-bell .badge-count {
    position: absolute; top: -4px; right: -4px;
    background: var(--negative); color: #fff;
    font-size: 10px; font-weight: 600;
    min-width: 16px; height: 16px;
    border-radius: 8px;
    display: inline-flex; align-items: center; justify-content: center;
    padding: 0 4px;
}
.unread-row td { background: #fff8eb; font-weight: 500; }
html[data-theme="dark"] .unread-row td { background: #3d3024; }
.level-info    { background: var(--info);     color: #fff; }
.level-success { background: var(--positive); color: #fff; }
.level-warn    { background: var(--warn);     color: #fff; }
.level-error   { background: var(--negative); color: #fff; }


* { box-sizing: border-box; }
html, body {
    margin: 0; padding: 0; min-height: 100%;
    font-family: -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    background: var(--bg);
    color: var(--text);
    font-size: 14px;
    line-height: 1.45;
}
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

/* =================== Top bar =================== */
.topbar {
    display: flex;
    flex-direction: column;
    background: linear-gradient(180deg, var(--primary), var(--primary-d));
    color: #fff;
    padding: 0;
    box-shadow: var(--shadow);
    position: sticky; top: 0; z-index: 100;
}
/* Перший ряд — brand + search + user-tools */
.topbar-row-main {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 18px;
    height: 56px;
}
.topbar.topbar-with-today .topbar-row-main {
    border-bottom: 1px solid rgba(0, 0, 0, 0.18);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.06);
}
.topbar .brand {
    display: flex; align-items: center; gap: 8px;
    font-weight: 600; font-size: 18px;
    color: #fff; text-decoration: none;
}
.topbar .brand:hover { text-decoration: none; opacity: .92; }
.topbar .logo  { font-size: 22px; }
.topbar .search-trigger { margin-left: auto; }
.topbar-right { display: flex; align-items: center; gap: 12px; }
.user-pill { color: rgba(255,255,255,.9); font-size: 13px; }
.user-pill .muted { color: rgba(255,255,255,.55); }
.btn-logout {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; margin-left: 6px;
    color: rgba(255,255,255,.85); text-decoration: none;
    background: rgba(255,255,255,.10); border-radius: 8px;
    font-size: 18px; transition: background .15s, color .15s;
}
.btn-logout:hover { background: rgba(220,53,69,.65); color: #fff; }
.badge-role {
    background: rgba(255,255,255,.18); color: #fff;
    padding: 2px 8px; border-radius: 10px;
    font-size: 11px; text-transform: uppercase; letter-spacing: .4px; margin-left: 4px;
}

/* =================== Layout shell (sidebar + content) =================== */
.layout-shell {
    display: flex;
    align-items: stretch;
    /* Topbar може бути 56px (logged-out) або ~98px (logged-in з today-row 42px) */
    min-height: calc(100vh - 98px - 50px);
}

.layout-shell { position: relative; }
/* «Канал» сайдбару — pseudo-елемент тягнеться на всю висоту document/layout-shell.
   Сама панель навігації лишається sticky зверху, а під нею — той же фон. */
.layout-shell::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 210px;
    background: var(--surface);
    border-right: 1px solid var(--border);
    box-shadow: var(--shadow-l);
    z-index: 0;
    transition: width .2s ease;
}
html[data-sidebar="collapsed"] .layout-shell::before { width: 56px; }
@media (max-width: 900px) {
    .layout-shell::before { display: none; }
}

.sidebar {
    width: 210px;
    flex-shrink: 0;
    background: transparent;
    position: sticky;
    top: 56px;
    align-self: flex-start;
    padding: 10px 0 16px;
    transition: width .2s ease;
    z-index: 40;
}
html[data-sidebar="collapsed"] .sidebar { width: 56px; }
html[data-sidebar="collapsed"] .sidenav-title { display: none; }
html[data-sidebar="collapsed"] .sidenav-item .lbl { display: none; }
html[data-sidebar="collapsed"] .sidenav-item { justify-content: center; padding: 10px 0; }
html[data-sidebar="collapsed"] .sidenav-section { padding: 0; }
html[data-sidebar="collapsed"] .sidenav-section + .sidenav-section { border-top: 1px solid var(--border); margin-top: 4px; padding-top: 4px; }
html[data-sidebar="collapsed"] .sidebar-collapse { transform: rotate(180deg); }

.sidebar-collapse {
    position: absolute;
    top: 8px; right: 8px;
    background: transparent; border: 0; cursor: pointer;
    color: var(--muted); font-size: 14px; line-height: 1;
    padding: 4px 8px; border-radius: 6px;
    transition: background .15s, color .15s;
}
.sidebar-collapse:hover { background: var(--surface-2); color: var(--text); }

.sidenav { display: flex; flex-direction: column; gap: 1px; padding: 0 6px; }
.sidenav-section { padding: 2px 0; }
.sidenav-section + .sidenav-section { border-top: 1px solid var(--border); margin-top: 3px; padding-top: 4px; }
.sidenav-title {
    font-size: 10px; text-transform: uppercase; letter-spacing: .5px;
    color: var(--muted); padding: 2px 10px 2px; font-weight: 600;
}
.sidenav-item {
    display: flex; align-items: center; gap: 8px;
    padding: 4px 10px;
    border-radius: 6px;
    color: var(--text);
    font-size: 13px;
    line-height: 1.25;
    text-decoration: none;
    white-space: nowrap;
    transition: background .12s, color .12s;
}
.sidenav-item .ico { font-size: 14px; width: 18px; text-align: center; flex-shrink: 0; }
.sidenav-item .lbl { flex: 1; }
.sidenav-item:hover { background: var(--surface-2); color: var(--primary-d); text-decoration: none; }
.sidenav-item.active {
    background: var(--primary);
    color: #fff;
    box-shadow: var(--shadow-l);
}
.sidenav-item.active:hover { background: var(--primary-d); color: #fff; }
html[data-theme="dark"] .sidenav-item.active { color: #fff; }

/* =================== Content / page =================== */
.content-wrap {
    flex: 1;
    min-width: 0; /* allow shrink inside flex */
    display: flex;
    flex-direction: column;
}
.content { max-width: 1480px; width: 100%; margin: 24px auto; padding: 0 24px; box-sizing: border-box; }
.page-title { font-size: 22px; margin: 0; font-weight: 600; }
.page-header {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 12px; margin-bottom: 18px;
}
.page-actions { display: flex; gap: 8px; }
.footer { text-align: center; color: var(--muted); padding: 16px; margin-top: 40px; }

/* =================== Flash =================== */
.flash-stack {
    max-width: 1480px; width: 100%; margin: 16px auto 0; padding: 0 24px;
    box-sizing: border-box;
    display: flex; flex-direction: column; gap: 8px;
}
.alert {
    padding: 10px 16px; border-radius: var(--radius);
    background: var(--surface); border-left: 4px solid var(--info);
    box-shadow: var(--shadow-l);
}
.alert-success { border-left-color: var(--positive); }
.alert-error   { border-left-color: var(--negative); }
.alert-warn    { border-left-color: var(--warn); }
.alert-info    { border-left-color: var(--info); }

/* =================== KPI =================== */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 14px;
    margin-bottom: 28px;
}
/* Modifier: ВСІ KPI у одному ряду (для dashboard з period-filter).
   Використовуємо auto-fit з min(0,1fr) щоб фіксовано вмістити N карток в один ряд.
   На вузьких екранах (<1100px) скорочуємо padding/font; на дуже вузьких (<720px)
   падаємо назад на стандартний flow з 2 колонками. */
.kpi-grid.kpi-grid--row {
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: 10px;
}
.kpi-grid.kpi-grid--row .kpi-card {
    padding: 12px 12px;
}
.kpi-grid.kpi-grid--row .kpi-label { font-size: 10.5px; }
.kpi-grid.kpi-grid--row .kpi-value { font-size: 16px; margin-top: 4px; }
.kpi-grid.kpi-grid--row .kpi-value small { font-size: 11px; color: var(--muted); }
.kpi-grid.kpi-grid--row .kpi-delta { font-size: 10px; padding: 1px 5px; margin-top: 3px; }
@media (max-width: 1300px) {
    .kpi-grid.kpi-grid--row {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}
@media (max-width: 720px) {
    .kpi-grid.kpi-grid--row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .kpi-grid.kpi-grid--row .kpi-value { font-size: 18px; }
}
/* F-02: delta-badge на KPI-картках */
.kpi-delta {
    display: inline-block;
    margin-top: 4px;
    font-size: 11px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 10px;
    line-height: 1.4;
    letter-spacing: 0.2px;
}
.kpi-delta.delta-good { background: rgba(74,222,128,0.15);  color: #16a34a; }
.kpi-delta.delta-bad  { background: rgba(248,113,113,0.15); color: #dc2626; }
.kpi-delta.delta-flat { background: var(--surface-2);       color: var(--muted); }
.kpi-delta.delta-new  { background: rgba(168,85,247,0.15);  color: #9333ea; }
[data-theme="dark"] .kpi-delta.delta-good { color: #4ade80; }
[data-theme="dark"] .kpi-delta.delta-bad  { color: #f87171; }
[data-theme="dark"] .kpi-delta.delta-new  { color: #c084fc; }

.kpi-card {
    background: var(--surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 16px 18px;
    border-left: 4px solid var(--primary);
}
.kpi-label { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .5px; }
.kpi-value { font-size: 20px; font-weight: 600; margin-top: 6px; }
.kpi-revenue   { border-left-color: var(--accent); }
.kpi-cogs      { border-left-color: #b08968; }
.kpi-recurring { border-left-color: #927b5e; }
.kpi-onetime   { border-left-color: #b6855c; }
.kpi-purchases { border-left-color: #8a6a4f; }
.kpi-writeoff  { border-left-color: var(--negative); }
.kpi-card.has-warn { border-left-color: var(--negative); background: rgba(192,57,43,.04); }
.kpi-card.has-warn .kpi-value { color: var(--negative); }
.kpi-profit.positive { border-left-color: var(--positive); }
.kpi-profit.negative { border-left-color: var(--negative); }

/* =================== Cards =================== */
.card {
    --card-pad-x: 20px;
    --card-pad-y: 18px;
    background: var(--surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: var(--card-pad-y) var(--card-pad-x);
    margin-bottom: 18px;
    overflow: hidden; /* щоб таблиця, що розтягнута за межі padding, не обрізала тінь */
}
.card h3 { margin: 0 0 12px; font-size: 16px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 900px) { .grid-2 { grid-template-columns: 1fr; } }

/* =================== Tables (єдиний card-стиль для ВСІХ) =================== */
.data-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 13.5px;
    background: var(--surface);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);
    margin-bottom: 18px;
}
/* Якщо таблиця вже всередині .card — прибираємо дубльовану тінь і фон,
   щоб не виходило подвійного картка-в-картці. */
.card > .data-table,
.card .data-table {
    box-shadow: none;
    border-radius: 0;
    margin-bottom: 0;
}
/* Таблиця простягається на всю ширину картки (edge-to-edge),
   незалежно від внутрішнього padding картки.
   Якщо таблиця — ПЕРШИЙ елемент картки, її верх торкається верху картки.
   Якщо ОСТАННІЙ — низ торкається низу. */
.card > .data-table {
    margin-left: calc(-1 * var(--card-pad-x, 20px));
    margin-right: calc(-1 * var(--card-pad-x, 20px));
    width: calc(100% + 2 * var(--card-pad-x, 20px));
}
.card > .data-table:first-child { margin-top: calc(-1 * var(--card-pad-y, 18px)); }
.card > .data-table:last-child  { margin-bottom: calc(-1 * var(--card-pad-y, 18px)); }
/* Контент після таблиці (наприклад, мутний note) отримує дихання */
.card > .data-table + p,
.card > .data-table + h3,
.card > .data-table + .form-actions { margin-top: 16px; }

/* Якщо таблиця у горизонтальному скролі — оформлення тримає сам wrapper. */
.table-scroll > .data-table {
    box-shadow: none;
    border-radius: 0;
    margin-bottom: 0;
}
.table-scroll {
    background: var(--surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow-x: auto;
    margin-bottom: 18px;
}
.card > .table-scroll {
    margin-left: calc(-1 * var(--card-pad-x, 20px));
    margin-right: calc(-1 * var(--card-pad-x, 20px));
    width: calc(100% + 2 * var(--card-pad-x, 20px));
    border-radius: 0;
    box-shadow: none;
}
.card > .table-scroll:first-child { margin-top: calc(-1 * var(--card-pad-y, 18px)); }
.card > .table-scroll:last-child  { margin-bottom: calc(-1 * var(--card-pad-y, 18px)); }

.data-table thead th {
    text-align: left;
    background: var(--surface-2);
    color: var(--muted);
    font-weight: 600;
    padding: 12px 14px;
    border-bottom: 1px solid var(--border);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .4px;
}
.data-table thead th:first-child { border-top-left-radius: var(--radius); }
.data-table thead th:last-child  { border-top-right-radius: var(--radius); }
.card .data-table thead th:first-child,
.card .data-table thead th:last-child,
.table-scroll .data-table thead th:first-child,
.table-scroll .data-table thead th:last-child { border-radius: 0; }

.data-table tbody td, .data-table tfoot td {
    padding: 11px 14px;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}
.data-table tbody tr:last-child td { border-bottom: 0; }
.data-table tfoot td { background: var(--surface-2); font-weight: 600; border-top: 2px solid var(--border); }
.data-table tbody tr:hover td { background: var(--surface-2); }
.data-table tbody tr.archived { opacity: .55; }

.data-table.compact tbody td,
.data-table.compact thead th,
.data-table.compact tfoot td { padding: 7px 10px; font-size: 13px; }

.data-table .num   { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
.data-table .mono  { font-family: ui-monospace, "SF Mono", Consolas, monospace; font-size: 12px; color: var(--muted); }
.data-table .actions { white-space: nowrap; text-align: right; }
.data-table .actions a, .data-table .actions button { white-space: nowrap; }

html[data-theme="dark"] .data-table { background: var(--surface); }
html[data-theme="dark"] .data-table thead th,
html[data-theme="dark"] .data-table tfoot td { background: var(--surface-2); }
html[data-theme="dark"] .data-table tbody tr:hover td { background: var(--surface-2); }
.muted { color: var(--muted); }
.positive { color: var(--positive); font-weight: 600; }
.negative { color: var(--negative); font-weight: 600; }

.low-stock { margin: 0; padding-left: 18px; }

/* =================== Filterbar / forms =================== */
/* Контейнер: фільтри ліворуч, summary-pill праворуч */
.filter-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 18px;
}
.filter-row .filterbar { margin-bottom: 0; flex: 1 1 auto; }

/* Компактна «таблетка» з підсумком періоду — праворуч від фільтрів */
.summary-pill {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    padding: 10px 18px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--primary), var(--primary-l));
    color: #fff;
    box-shadow: var(--shadow);
    flex-shrink: 0;
}
.summary-pill .lbl {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .5px;
    opacity: .75;
}
.summary-pill .val {
    font-size: 18px;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}
.summary-pill-warn { background: linear-gradient(135deg, var(--negative), #d4634f); }
.summary-pill-positive { background: linear-gradient(135deg, var(--positive), #4ca87a); }
@media (max-width: 700px) {
    .filter-row { flex-direction: column; align-items: stretch; }
    .summary-pill { align-self: flex-start; }
}

.filterbar {
    display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
    margin-bottom: 16px;
}
.filterbar input, .filterbar select, .filterbar textarea {
    padding: 7px 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    font-size: 13.5px;
    min-width: 180px;
    color: var(--text);
}
.filterbar input:focus, .filterbar select:focus { outline: 2px solid var(--accent); outline-offset: -1px; }
.filterbar label { display: flex; align-items: center; gap: 6px; }
.filterbar label.check input { min-width: 0; }

/* Form */
.form { padding: 24px 28px; }
.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px 18px;
}
.form-grid label {
    display: flex; flex-direction: column; gap: 6px;
    color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .4px;
}
.form-grid label.span-2 { grid-column: span 2; }
.form-grid label.check  {
    flex-direction: row; align-items: center;
    text-transform: none; letter-spacing: 0; color: var(--text); font-size: 13.5px;
}
.form-grid input, .form-grid select, .form-grid textarea {
    padding: 8px 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    font-size: 13.5px;
    color: var(--text);
    width: 100%;
}
.form-grid input:focus, .form-grid select:focus, .form-grid textarea:focus {
    outline: 2px solid var(--accent); outline-offset: -1px;
}
.form-actions { margin-top: 20px; display: flex; gap: 10px; }
.info-grid { display: flex; gap: 24px; margin: 16px 0; flex-wrap: wrap; color: var(--muted); }
.period-switch { margin-bottom: 16px; }

/* =================== Buttons =================== */
.btn {
    display: inline-block;
    padding: 7px 16px;
    border: 0;
    border-radius: 8px;
    background: var(--primary);
    color: #fff;
    cursor: pointer;
    font-size: 13.5px;
    transition: background .15s, transform .05s;
    text-decoration: none;
}
.btn:hover { background: var(--primary-d); text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--primary); }
.btn-secondary { background: #d9cdbc; color: var(--text); }
.btn-secondary:hover { background: #cdc0ad; color: var(--text); }
.btn-wide { width: 100%; padding: 10px 16px; font-size: 14px; }
.btn-link {
    background: transparent; border: 0;
    color: var(--primary); cursor: pointer;
    text-decoration: underline; padding: 0 6px;
    font-size: 13px;
}
.btn-link.danger { color: var(--negative); }

.badge {
    display: inline-block; padding: 1px 6px;
    background: #efe7da; color: var(--muted);
    border-radius: 10px;
    font-size: 11px; text-transform: lowercase; margin-left: 4px;
}

/* =================== Tabs =================== */
.tabs { display: flex; gap: 4px; margin-bottom: 12px; border-bottom: 1px solid var(--border); }
.tab {
    padding: 8px 16px;
    color: var(--muted);
    border: 1px solid transparent;
    border-bottom: 0;
    border-radius: 8px 8px 0 0;
    cursor: pointer;
}
.tab.active {
    background: var(--surface); color: var(--text);
    border-color: var(--border); font-weight: 600;
}
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* =================== Modal =================== */
.modal {
    position: fixed; inset: 0;
    background: rgba(35, 22, 14, .55);
    display: flex; align-items: center; justify-content: center;
    z-index: 200;
}
.modal.hidden { display: none; }
.modal-body {
    background: var(--surface);
    padding: 24px 28px;
    border-radius: var(--radius);
    min-width: 480px;
    max-width: 90vw;
    max-height: 80vh;
    overflow: auto;
    box-shadow: 0 12px 40px rgba(0,0,0,.25);
}

/* =================== Toaster =================== */
.toaster {
    position: fixed; right: 24px; bottom: 24px;
    display: flex; flex-direction: column; gap: 10px; z-index: 300;
}
.toast {
    background: var(--surface);
    padding: 12px 18px;
    border-radius: var(--radius);
    box-shadow: 0 6px 18px rgba(0,0,0,.18);
    border-left: 4px solid var(--info);
    min-width: 240px; max-width: 360px;
    animation: toast-in .25s ease;
}
.toast.success { border-left-color: var(--positive); }
.toast.error   { border-left-color: var(--negative); }
.toast.warn    { border-left-color: var(--warn); }
@keyframes toast-in { from { opacity:0; transform: translateY(8px) } to { opacity:1; transform:none } }

/* =================== Login =================== */
.login-bg {
    min-height: 100vh; margin: 0;
    background: linear-gradient(135deg, #6f4e37 0%, #d99a4f 100%);
    display: flex; align-items: center; justify-content: center;
}
.login-card {
    background: var(--surface);
    padding: 36px 32px 28px;
    border-radius: 14px;
    box-shadow: 0 16px 50px rgba(0,0,0,.25);
    width: 360px; max-width: 90vw;
}
.login-brand {
    display: flex; align-items: center; gap: 8px;
    font-size: 22px; font-weight: 600; color: var(--primary);
}
.login-sub { margin: 0 0 20px; color: var(--muted); font-size: 13px; }
.login-card form label {
    display: block; color: var(--muted); font-size: 12px;
    margin-bottom: 12px; text-transform: uppercase; letter-spacing: .4px;
}
.login-card form input {
    width: 100%; margin-top: 6px;
    padding: 9px 12px; border: 1px solid var(--border);
    border-radius: 8px; font-size: 14px;
}
.login-hint { margin-top: 18px; color: var(--muted); font-size: 12px; text-align: center; }
.login-hint code { background: #f4ecdf; padding: 2px 6px; border-radius: 4px; }

/* =================== Recipe / purchase row builders =================== */
.recipe-builder select, .recipe-builder input,
.purchase-builder select, .purchase-builder input {
    padding: 6px 8px;
    border: 1px solid var(--border);
    border-radius: 6px;
    font-size: 13px;
    width: 100%;
    background: var(--surface);
}
.recipe-builder .num input,
.purchase-builder .num input { text-align: right; }

/* =================== Pagination =================== */
.pagination {
    display: flex; gap: 4px; flex-wrap: wrap;
    margin-top: 16px; align-items: center;
}
.pagination .page {
    display: inline-block;
    padding: 4px 10px;
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text);
    background: var(--surface);
    font-size: 13px;
    text-decoration: none;
    min-width: 32px; text-align: center;
}
.pagination .page:hover:not(.disabled):not(.current) { background: #f4ecdf; text-decoration: none; }
.pagination .page.current  { background: var(--primary); color: #fff; border-color: var(--primary); cursor: default; }
.pagination .page.disabled { opacity: .35; cursor: default; }
.pagination .page.dots     { border: 0; background: transparent; }
.pagination .page-info     { margin-left: auto; color: var(--muted); font-size: 12px; }

/* =================== Sidebar mobile toggle =================== */
.nav-toggle {
    display: none;
    background: transparent; color: #fff; border: 0;
    font-size: 22px; line-height: 1;
    padding: 8px 12px;
    cursor: pointer; border-radius: 6px;
}
.nav-toggle:hover { background: rgba(255,255,255,.12); }

.sidebar-backdrop {
    display: none;
    position: fixed; top: 56px; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,.35);
    z-index: 39;
}

@media (max-width: 900px) {
    .nav-toggle { display: inline-flex; }
    .sidebar-collapse { display: none; }
    .sidebar {
        position: fixed;
        top: 56px; left: 0;
        height: calc(100vh - 56px);
        overflow-y: auto;
        transform: translateX(-100%);
        transition: transform .22s ease;
        width: 240px;
        z-index: 50;
        background: var(--surface);
        border-right: 1px solid var(--border);
        box-shadow: var(--shadow-l);
    }
    .sidebar.open { transform: translateX(0); }
    .sidebar.open ~ .content-wrap { /* nothing — backdrop handles overlay */ }
    body.sidebar-open .sidebar-backdrop { display: block; }
    .topbar .search-trigger .lbl,
    .topbar .search-trigger kbd { display: none; }
}
@media (max-width: 480px) {
    .topbar { padding: 0 10px; gap: 6px; }
    .topbar .brand .title { display: none; }
    .user-pill .badge-role { display: none; }
    .content { padding: 0 12px; }
}

/* =================== User dropdown =================== */
.user-menu { position: relative; }
.user-menu .user-pill {
    background: rgba(255,255,255,.12); border: 0; cursor: pointer;
    padding: 6px 12px; border-radius: 16px; font-size: 13px;
    color: #fff;
}
.user-menu .user-pill:hover { background: rgba(255,255,255,.2); }
.user-dropdown {
    display: none;
    position: absolute; right: 0; top: 100%;
    margin-top: 6px;
    background: var(--surface);
    border-radius: var(--radius);
    box-shadow: 0 6px 18px rgba(0,0,0,.18);
    min-width: 200px;
    overflow: hidden;
    z-index: 99;
}
.user-menu.open .user-dropdown { display: block; }
.user-dropdown a {
    display: block;
    padding: 8px 16px;
    color: var(--text);
    text-decoration: none;
    font-size: 13px;
}
.user-dropdown a:hover { background: #faf6ee; text-decoration: none; }
.user-dropdown a.negative { color: var(--negative); }
.user-dropdown hr { border: 0; border-top: 1px solid var(--border); margin: 4px 0; }

/* =================== Horizontal scroll for tables ===================
   Контейнерний стиль (фон, border-radius, тінь) задано вище у блоці Tables. */
.table-scroll {
    -webkit-overflow-scrolling: touch;
}
.table-scroll .data-table { min-width: 720px; }

/* =================== Links list =================== */
.links-list { list-style: none; padding: 0; margin: 0; }
.links-list li {
    padding: 10px 4px;
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
}
.links-list li:last-child { border-bottom: 0; }
.links-list .actions { margin-left: auto; }
.links-list a { font-weight: 600; }

/* =================== Heatmap =================== */
.heatmap td.heat {
    text-align: center; padding: 4px 6px; min-width: 36px;
    font-size: 11px; color: rgba(0,0,0,.55); transition: background .15s;
}
.heatmap td.heat:hover { outline: 2px solid var(--accent); outline-offset: -2px; }

/* ================== Searchable Select (combobox) ================== */
.ss-wrap { position: relative; display: inline-block; width: 100%; }
.ss-wrap.is-disabled { opacity: 0.6; pointer-events: none; }
.ss-input {
    width: 100%; padding: 8px 28px 8px 12px;
    border: 1px solid var(--border); border-radius: 8px;
    background: var(--surface); color: var(--text); font-size: 14px;
    box-sizing: border-box; cursor: pointer;
}
.ss-input:focus { outline: 2px solid var(--primary-l, var(--primary)); outline-offset: -1px; border-color: var(--primary); }
.ss-caret {
    position: absolute; right: 10px; top: 50%; transform: translateY(-50%);
    color: var(--muted); pointer-events: auto; cursor: pointer;
    font-size: 10px; user-select: none;
}
.ss-wrap.is-open .ss-caret { transform: translateY(-50%) rotate(180deg); }
.ss-menu {
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 8px; box-shadow: 0 6px 20px rgba(0,0,0,0.12);
    max-height: 280px; overflow-y: auto; z-index: 9999; margin-top: 4px;
}
.ss-wrap.is-open { position: relative; z-index: 9999; }
/* .card має overflow:hidden для тіней — це ріже dropdown searchable-select.
   Картка, що містить відкритий select, тимчасово знімає overflow і піднімає z-index. */
.card:has(.ss-wrap.is-open) {
    overflow: visible !important;
    position: relative;
    z-index: 9000;
}
/* Fallback для браузерів без :has() — JS додасть клас .has-open-dropdown */
.card.has-open-dropdown {
    overflow: visible !important;
    position: relative;
    z-index: 9000;
}
.ss-item {
    padding: 8px 12px; cursor: pointer; font-size: 13px;
    border-bottom: 1px solid var(--border);
}
.ss-item:last-child { border-bottom: 0; }
.ss-item:hover, .ss-item.is-active { background: var(--surface-2); color: var(--primary); }
.ss-item.is-current { background: rgba(74,139,201,.08); font-weight: 500; }
.ss-empty { padding: 10px 12px; color: var(--muted); font-size: 13px; }
/* F-03: tabs для heatmap (revenue/receipts/avg_check) */
.heatmap-tabs { display: inline-flex; gap: 4px; padding: 3px; background: var(--surface-2); border-radius: 8px; }
.heatmap-tabs .heatmap-tab {
    padding: 6px 12px; font-size: 13px; border: 0; background: transparent; cursor: pointer;
    color: var(--muted); border-radius: 6px; transition: background 0.12s, color 0.12s;
}
.heatmap-tabs .heatmap-tab:hover { color: var(--text); }
.heatmap-tabs .heatmap-tab.is-active {
    background: var(--surface); color: var(--primary); font-weight: 500;
    box-shadow: 0 1px 2px rgba(0,0,0,0.06);
}

/* =================== Quadrants (Menu Engineering) =================== */
.quadrants {
    display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
    margin-top: 16px;
}
.quadrant {
    border: 1px solid var(--border); border-radius: var(--radius);
    padding: 14px 18px;
}
.quadrant h4 { margin: 0 0 4px; font-size: 14px; }
.quadrant ul { margin: 8px 0 0; padding-left: 18px; font-size: 13px; }
.quadrant li { display: flex; justify-content: space-between; gap: 8px; padding: 2px 0; }
.qstats { color: var(--muted); font-size: 12px; white-space: nowrap; }
.quadrant-star      { background: linear-gradient(135deg, #fff8eb, #ffefd0); border-color: var(--accent); }
.quadrant-puzzle    { background: linear-gradient(135deg, #f6efff, #ebe1ff); border-color: #b09ce6; }
.quadrant-plowhorse { background: linear-gradient(135deg, #f0f9ff, #d8edff); border-color: #88baf0; }
.quadrant-dog       { background: linear-gradient(135deg, #fff0f0, #ffe5e5); border-color: #d99e9e; }
.badge.q-star       { background: var(--accent); color: #fff; }
.badge.q-puzzle     { background: #b09ce6; color: #fff; }
.badge.q-plowhorse  { background: #88baf0; color: #fff; }
.badge.q-dog        { background: #d99e9e; color: #fff; }
.badge.abc-a { background: var(--positive); color: #fff; }
.badge.abc-b { background: var(--accent);  color: #fff; }
.badge.abc-c { background: #b08968; color: #fff; }

/* =================== Search palette =================== */
.search-trigger {
    background: rgba(255,255,255,.12); border: 0; color: rgba(255,255,255,.85);
    padding: 6px 12px; border-radius: 8px; cursor: pointer;
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 13px; margin-right: 12px;
}
.search-trigger:hover { background: rgba(255,255,255,.2); }
.search-trigger .icon { font-size: 16px; }
.search-trigger kbd {
    background: rgba(0,0,0,.2); padding: 1px 6px; border-radius: 4px;
    font-size: 10px; font-family: ui-monospace, Consolas, monospace;
}
@media (max-width: 700px) {
    .search-trigger .lbl, .search-trigger kbd { display: none; }
}
.search-palette {
    position: fixed; inset: 0;
    background: rgba(35, 22, 14, .55);
    z-index: 250;
    padding-top: 80px;
    display: flex; justify-content: center; align-items: flex-start;
}
.search-palette.hidden { display: none; }

/* =================== Expenses: paid status & receipts =================== */
.col-paid  { width: 36px; text-align: center; }
.col-photo { width: 40px; text-align: center; }
.paid-toggle {
    background: transparent; border: 0; cursor: pointer;
    font-size: 16px; padding: 2px 4px; border-radius: 4px;
    transition: background .12s;
}
.paid-toggle:hover { background: var(--surface-2); }
tr.expense-paid   td { background: rgba(46,139,87,.04); }
tr.expense-unpaid td { background: rgba(192, 57, 43, .04); }
html[data-theme="dark"] tr.expense-paid   td { background: rgba(109,185,138,.07); }
html[data-theme="dark"] tr.expense-unpaid td { background: rgba(229,123,108,.07); }

.batch-tag {
    display: inline-block;
    margin-left: 6px;
    font-size: 11px;
    opacity: .55;
}
.photo-link {
    display: inline-block;
    text-decoration: none;
    font-size: 18px;
    line-height: 1;
}
.photo-link:hover { text-decoration: none; transform: scale(1.15); }
.receipt-preview { margin-bottom: 12px; }
.receipt-preview img { display: block; box-shadow: var(--shadow); }

/* Drag handle і колонки видалення */
.col-drag, .col-del { width: 28px; text-align: center; }
.drag-handle {
    cursor: grab;
    color: var(--muted);
    font-size: 14px;
    user-select: none;
    line-height: 1;
    display: inline-block;
    padding: 4px 6px;
    border-radius: 4px;
    transition: background .12s, color .12s;
}
.drag-handle:hover { background: var(--surface-2); color: var(--text); }
.drag-handle:active { cursor: grabbing; }
tr.drag-source { opacity: .35; }
tr.drag-over   { box-shadow: inset 0 2px 0 var(--primary); }
.recurring-edit tbody tr { transition: opacity .2s; }
.recurring-edit tbody tr[draggable="true"] { cursor: default; }

/* Категорія з кнопками-чіпами і фото лічильника */
.cat-cell {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    min-height: 28px;
}
.cat-cell .cat-name { margin-right: 2px; }

/* Inline-контрол фото лічильника всередині категорії */
.meter-photo-inline {
    display: inline-flex;
    align-items: center;
    gap: 2px;
}
.meter-photo-inline .photo-link {
    font-size: 14px;
    line-height: 1;
    padding: 2px;
    text-decoration: none;
}
.meter-photo-inline .photo-remove-btn {
    background: transparent;
    border: 0;
    color: var(--negative);
    cursor: pointer;
    font-size: 14px;
    line-height: 1;
    padding: 0 4px;
    border-radius: 4px;
}
.meter-photo-inline .photo-remove-btn:hover { background: rgba(192,57,43,.12); }
.meter-photo-inline .photo-upload-btn {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    cursor: pointer;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 2px 8px;
    font-size: 12px;
    color: var(--muted);
    transition: background .12s, color .12s;
    user-select: none;
}
.meter-photo-inline .photo-upload-btn:hover {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}
.meter-photo-inline .js-photo-name {
    color: var(--text);
    font-size: 11px;
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Лічильники у формі періодичних */
.recurring-edit input.meter-input,
.recurring-edit input.amount-input {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 14px;
    width: 100%;
    box-sizing: border-box;
}
.recurring-edit tr.row-meter input.meter-input { background: #fff8e6; }
html[data-theme="dark"] .recurring-edit tr.row-meter input.meter-input { background: rgba(232,196,118,.08); }

/* Bulk-форма — поля чека */
#bulk-items input[type="text"],
#bulk-items input[type="number"] {
    width: 100%;
    box-sizing: border-box;
    padding: 6px 10px;
    border: 1px solid var(--border);
    border-radius: 6px;
    background: var(--surface);
    font-size: 14px;
}
#bulk-items td { padding: 6px 8px; }
#bulk-items input[type="number"] { text-align: right; }

/* =================== Огляд складових — повна таблиця =================== */
.overview-table { font-size: 13px; }
.overview-table th, .overview-table td { padding: 6px 10px; white-space: nowrap; }
.overview-table thead th {
    background: var(--surface-2);
    color: var(--text);
    font-weight: 600;
    text-align: left;
    border-bottom: 2px solid var(--border);
}
.overview-table thead th.num { text-align: right; }
.overview-table .th-group {
    text-align: center;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .4px;
    color: var(--muted);
    border-bottom: 1px solid var(--border);
}
.overview-table .th-name   { min-width: 220px; }
.overview-table .th-cbid   { width: 110px; }
.overview-table .th-stock  { background: rgba(74, 139, 201, .08); }
.overview-table .th-profit { background: rgba(46, 139, 87, .08); }

/* Кольорові групи колонок */
.overview-table .purch     { background: rgba(217, 154, 79, .06); }
.overview-table .sold      { background: rgba(46, 139, 87, .06); }
.overview-table .wo        { background: rgba(192, 57, 43, .06); }

/* Quick-search у sidebar */
.sidenav-search { padding: 8px 14px 0; }
.sidenav-search input {
    width: 100%;
    padding: 7px 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    color: var(--text);
    font-size: 12px;
    box-sizing: border-box;
}
.sidenav-search input:focus { outline: 2px solid var(--primary-l); outline-offset: -1px; }
[data-sidebar="collapsed"] .sidenav-search { display: none; }
.sidenav-section.is-hidden,
.sidenav-item.is-hidden { display: none !important; }

/* Pinned перша колонка (горизонтальний скрол) */
.overview-table .cell-name,
.overview-table .th-name {
    position: sticky;
    left: 0;
    background: var(--surface);
    z-index: 2;
    box-shadow: 1px 0 0 var(--border);
}
.overview-table thead .th-name { background: var(--surface-2); z-index: 3; }
/* На мобільному додаємо чіткіший shadow для відриву pinned колонки */
@media (max-width: 720px) {
    .overview-table .cell-name,
    .overview-table .th-name {
        box-shadow: 2px 0 6px rgba(53, 33, 18, .12);
        max-width: 160px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    /* hover-стан таблиці не повинен «вилазити» з-під pinned колонки */
    .overview-table tbody tr:hover .cell-name { background: var(--surface-2); }
}
/* Заголовок групи — повна ширина рядка, без sticky (інакше колспан клеїться до лівого краю
   і через всю таблицю просвічує лиш частина фону). */
.overview-table tr.group-row td {
    background: var(--primary) !important;
    color: #fff;
    font-weight: 600;
    padding: 8px 12px;
    border-top: 2px solid var(--primary-d);
}
html[data-theme="dark"] .overview-table tr.group-row td { background: var(--primary-d) !important; }
.overview-table tr.group-row:hover td { background: var(--primary-d) !important; }

/* Hover на звичайних рядках — не зачіпає groups */
.overview-table tbody tr:not(.group-row):hover td:not(.purch):not(.sold):not(.wo) {
    background: var(--surface-2);
}
.overview-table tbody tr:not(.group-row):hover .cell-name { background: var(--surface-2); }
.overview-table tbody tr:not(.group-row):hover .purch { background: rgba(217, 154, 79, .14); }
.overview-table tbody tr:not(.group-row):hover .sold  { background: rgba(46, 139, 87, .14); }
.overview-table tbody tr:not(.group-row):hover .wo    { background: rgba(192, 57, 43, .14); }

html[data-theme="dark"] .overview-table .cell-name { background: var(--surface); }

/* =================== Aliases (синоніми складових) =================== */
.alias-list {
    list-style: none;
    padding: 0;
    margin: 8px 0 14px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.alias-list li {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.alias-chip {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 12px;
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text);
    font-size: 13px;
}

/* =================== Promotions UI =================== */
.dow-picker { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 4px; }
.dow-cell { flex: 1; min-width: 44px; cursor: pointer; }
.dow-cell input { display: none; }
.dow-cell span {
    display: block; text-align: center; padding: 8px 0;
    border: 1px solid var(--border); border-radius: 6px;
    background: var(--surface-2);
    font-size: 13px; color: var(--muted);
    user-select: none;
}
.dow-cell input:checked + span {
    background: var(--primary); border-color: var(--primary); color: #fff; font-weight: 600;
}
.badge-positive {
    display: inline-block; background: var(--positive); color: #fff;
    font-size: 10px; padding: 0 6px; border-radius: 8px; line-height: 1.6;
}
.active-promos { list-style: none; padding: 0; margin: 0; }
.active-promos li { padding: 6px 0; border-bottom: 1px dashed var(--border); }
.active-promos li:last-child { border-bottom: 0; }
.search-palette .search-box {
    background: var(--surface); border-radius: var(--radius);
    width: 600px; max-width: 90vw;
    box-shadow: 0 16px 50px rgba(0,0,0,.4);
    overflow: hidden;
}
.search-palette input {
    width: 100%; padding: 14px 18px;
    border: 0; outline: none; font-size: 16px;
    border-bottom: 1px solid var(--border);
    box-sizing: border-box;
}
.search-results { max-height: 400px; overflow-y: auto; }
.search-results .group-title {
    padding: 6px 18px;
    background: #faf6ee; color: var(--muted);
    font-size: 11px; text-transform: uppercase; letter-spacing: .4px;
}
.search-results .item {
    display: block; padding: 8px 18px;
    color: var(--text); text-decoration: none;
    border-bottom: 1px solid var(--border);
    cursor: pointer;
}
.search-results .item:hover, .search-results .item.active {
    background: #f4ecdf; text-decoration: none;
}
.search-hint {
    padding: 6px 18px; font-size: 11px; background: #faf6ee;
}

/* Helpers for warning rows */
.data-table tr.warn-row td { background: #fff0f0; }
.data-table tr.hint-row td { background: #fff8eb; }
.warn { color: var(--warn); font-weight: 600; }

/* =================== Today strip =================== */
/* ============== Today row (другий ряд topbar-у) ============== */
/*
 * Глобальна стрічка KPI «Сьогодні» — інтегрована як другий ряд header-а.
 * Layout: [title] [────KPI items─── (центр)] [refresh button]
 * Має ТОЙ ЖЕ background як .topbar (єдиний gradient на весь header),
 * відмежовується від першого ряду тонкою лінією у .topbar-row-main.
 * Висота ~42px.
 */
.topbar-row-today {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 6px 24px;
    min-height: 42px;
    color: #fff;
    background: rgba(0, 0, 0, 0.08); /* легке затемнення для відмежування від першого ряду */
}
.today-title {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: rgba(255,255,255,0.92);
    white-space: nowrap;
}
.today-title .today-title-icon {
    font-size: 12px;
    opacity: 0.9;
}
.today-title .today-title-date {
    color: rgba(255,255,255,0.72);
    font-weight: 500;
    letter-spacing: 0.3px;
}
/* F-01: Sync indicator dot — статус Checkbox-синхронізації */
.sync-dot {
    display: inline-flex; align-items: center; justify-content: center;
    width: 14px; height: 14px; border-radius: 50%;
    margin-left: 4px; text-decoration: none; flex: 0 0 auto;
    transition: transform 0.15s;
}
.sync-dot:hover { transform: scale(1.25); }
.sync-dot .sync-dot-circle {
    width: 8px; height: 8px; border-radius: 50%;
    box-shadow: 0 0 0 0 rgba(255,255,255,0);
}
.sync-dot.sync-ok    .sync-dot-circle { background: #4ade80; box-shadow: 0 0 6px rgba(74,222,128,0.7); }
.sync-dot.sync-warn  .sync-dot-circle { background: #fbbf24; box-shadow: 0 0 4px rgba(251,191,36,0.6); }
.sync-dot.sync-stale .sync-dot-circle { background: #f87171; box-shadow: 0 0 4px rgba(248,113,113,0.6); }
.sync-dot.sync-error .sync-dot-circle { background: #ef4444; animation: sync-pulse 1.5s ease-in-out infinite; }
.sync-dot.sync-never .sync-dot-circle,
.sync-dot.sync-unknown .sync-dot-circle { background: #94a3b8; }
@keyframes sync-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(239,68,68,0.7); }
    50%      { box-shadow: 0 0 0 5px rgba(239,68,68,0); }
}
.today-items {
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    min-width: 0;
    flex-wrap: wrap;
}
.today-items .ti {
    display: inline-flex;
    align-items: baseline;
    gap: 7px;
    padding: 4px 18px;
    position: relative;
    white-space: nowrap;
}
.today-items .ti + .ti::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 22px;
    width: 1px;
    background: linear-gradient(180deg,
        rgba(255,255,255,0) 0%,
        rgba(255,255,255,0.22) 50%,
        rgba(255,255,255,0) 100%);
}
.today-items .ti .lbl {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: rgba(255,255,255,0.62);
    font-weight: 500;
}
.today-items .ti .val {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.2px;
    font-variant-numeric: tabular-nums;
}
.today-items .ti.is-zero .val {
    color: rgba(255,255,255,0.45);
    font-weight: 500;
}
.topbar-row-today .positive { color: #b8f5b8; }
.topbar-row-today .negative { color: #ffc7be; }

/* Refresh button — pill, з акцентом */
.today-refresh {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(255,255,255,0.14);
    color: #fff;
    border: 1px solid rgba(255,255,255,0.22);
    border-radius: 999px;
    padding: 6px 14px 6px 12px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.2px;
    cursor: pointer;
    transition: background 0.15s, transform 0.1s, border-color 0.15s;
    line-height: 1;
    font-family: inherit;
    white-space: nowrap;
}
.today-refresh:hover {
    background: rgba(255,255,255,0.22);
    border-color: rgba(255,255,255,0.35);
}
.today-refresh:active { transform: scale(0.97); }
.today-refresh:disabled { cursor: wait; opacity: 0.65; }
.today-refresh:focus-visible {
    outline: 2px solid rgba(255,255,255,0.7);
    outline-offset: 2px;
}
.today-refresh-icon {
    font-size: 14px;
    display: inline-block;
    line-height: 1;
}
.today-refresh.is-loading .today-refresh-icon {
    animation: today-spin 0.8s linear infinite;
}
@keyframes today-spin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

/* Dark theme — затемнення other-row сильніше */
html[data-theme="dark"] .topbar-row-today {
    background: rgba(0, 0, 0, 0.18);
}

/* ≤1100px — items щільніше, менший padding */
@media (max-width: 1100px) {
    .topbar-row-today { padding: 5px 16px; gap: 12px; }
    .today-items .ti { padding: 4px 12px; gap: 6px; }
    .today-items .ti .val { font-size: 13px; }
}

/* ≤768px — title прихований, items згруповані як wrap-grid */
@media (max-width: 768px) {
    .today-title { display: none; }
    .today-items {
        gap: 4px 0;
        justify-content: flex-start;
    }
    .today-items .ti { padding: 3px 10px; flex: 0 0 auto; }
}

/* ≤480px — стек вертикально, refresh-button уся ширина */
@media (max-width: 480px) {
    .topbar-row-today { flex-direction: column; align-items: stretch; padding: 8px 12px; gap: 8px; }
    .today-items {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 6px 0;
        text-align: left;
    }
    .today-items .ti { padding: 2px 8px; flex-direction: column; align-items: flex-start; gap: 0; }
    .today-items .ti + .ti::before { display: none; }
    .today-refresh { justify-content: center; width: 100%; padding: 8px; }
}


/* Inline filterbar для page-actions */
.filterbar.inline {
    display: inline-flex;
    margin-bottom: 0;
    gap: 6px;
}
.filterbar.inline select {
    min-width: 110px;
    padding: 6px 10px;
}

/* =================== Charts =================== */
.chart-wrap {
    position: relative;
    width: 100%;
}
.chart-wrap canvas[data-points] {
    display: block;
    width: 100% !important;
    height: auto;
    cursor: crosshair;
}
.chart-tooltip {
    position: absolute;
    pointer-events: none;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    box-shadow: 0 4px 14px rgba(0,0,0,.18);
    padding: 8px 12px;
    font-size: 12px;
    z-index: 5;
    min-width: 140px;
    transition: opacity .12s;
}
.chart-tooltip .tt-label {
    color: var(--muted);
    font-weight: 600;
    margin-bottom: 4px;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .3px;
}
.chart-tooltip .tt-row {
    display: flex; align-items: center; gap: 6px;
    padding: 2px 0;
}
.chart-tooltip .tt-dot {
    display: inline-block; width: 8px; height: 8px; border-radius: 4px;
}
.chart-tooltip .tt-row .key { color: var(--muted); flex: 1; }
.chart-tooltip .tt-row .val { font-weight: 600; font-variant-numeric: tabular-nums; }
.chart-tooltip.hidden { opacity: 0; }

/* Канвас на всю ширину для звичайних .card теж */
canvas[data-points] { display: block; width: 100% !important; max-width: 100%; }

/* =================== Print =================== */
.print-only { display: none; }
@media print {
    body { background: #fff; }
    .topbar, .footer, .flash-stack, .no-print, .nav-toggle,
    .sidebar, .sidebar-backdrop,
    .page-actions, .search-trigger, .topbar-right { display: none !important; }
    .layout-shell { display: block; }
    .content-wrap { display: block; }
    .content { margin: 0; padding: 0; max-width: none; }
    .card { box-shadow: none; border: 0; padding: 0; margin-bottom: 12px; }
    .data-table { box-shadow: none; border-radius: 0; font-size: 11px; }
    .data-table thead th { background: transparent; color: #000; }
    .table-scroll { overflow: visible; box-shadow: none; }
    .print-only { display: block; }
    a { color: #000; text-decoration: none; }
}

/* =================== Code block =================== */
pre {
    background: #f4ecdf; padding: 10px; border-radius: 6px;
    font-size: 12px; overflow-x: auto; margin: 8px 0;
}
code { font-family: ui-monospace, "SF Mono", Consolas, monospace; }

/* =================== Products page filter (полірована) =================== */
.products-filter {
    background: var(--surface);
    padding: 12px 14px;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    margin-bottom: 14px;
}
.products-filter .pf-row {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.products-filter .pf-search {
    position: relative; flex: 1; min-width: 220px;
}
.products-filter .pf-search .pf-icon {
    position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
    color: var(--muted); font-size: 14px; pointer-events: none;
}
.products-filter .pf-search input[type=text] {
    width: 100%; padding: 9px 12px 9px 32px;
    border: 1px solid var(--border); border-radius: 8px;
    background: var(--surface-2); color: var(--text); font-size: 14px;
    transition: border-color .15s, background .15s;
}
.products-filter .pf-search input[type=text]:focus {
    outline: none; border-color: var(--primary); background: var(--surface);
}
.products-filter .pf-select {
    min-width: 200px; padding: 9px 12px; font-size: 14px;
    border: 1px solid var(--border); border-radius: 8px;
    background: var(--surface-2); color: var(--text);
}
.products-filter .pf-check {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 0 10px; font-size: 14px; color: var(--muted); cursor: pointer;
    user-select: none;
}
.products-filter .pf-check input { accent-color: var(--primary); }
.products-filter .pf-submit { padding: 9px 20px; }
.products-filter .pf-reset  { padding: 9px 14px; }
@media (max-width: 720px) {
    .products-filter .pf-search,
    .products-filter .pf-select { width: 100%; }
}
