:root { --bg: #ffffff; --ink: #0a0a0a; --ink-soft: #6b7280; --line: #e5e7eb; --line-soft: #f3f4f6; --hover: #f9fafb; --radius: 10px; --radius-sm: 6px; }
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background: #f8f9fa; color: var(--ink); font-size: 14px; line-height: 1.5; -webkit-font-smoothing: antialiased; }
.app-bar { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,0.92); backdrop-filter: saturate(180%) blur(10px); -webkit-backdrop-filter: saturate(180%) blur(10px); border-bottom: 1px solid var(--line); }
.app-bar-inner { max-width: 1100px; margin: 0 auto; padding: 14px 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.app-bar-brand { display: flex; align-items: center; gap: 12px; }
.app-bar-brand img { height: 34px; width: auto; display: block; }
.brand-text { line-height: 1.1; }
.brand-name { font-size: 15px; font-weight: 600; letter-spacing: -0.01em; }
.brand-sub { font-size: 10px; color: var(--ink-soft); font-weight: 500; text-transform: uppercase; letter-spacing: 0.1em; margin-top: 2px; }
.app-nav { display: flex; gap: 4px; }
.app-nav a { background: transparent; border: 1px solid transparent; padding: 8px 14px; color: var(--ink-soft); cursor: pointer; border-radius: var(--radius-sm); font-size: 13px; font-weight: 500; transition: all 0.15s ease; text-decoration: none; }
.app-nav a:hover { background: var(--hover); color: var(--ink); }
.app-nav a.active { background: var(--ink); color: #fff; }
.container { max-width: 1100px; margin: 0 auto; padding: 32px 24px 96px; }
.page-heading { margin-bottom: 24px; }
.page-heading h1 { margin: 0 0 4px; font-size: 24px; font-weight: 600; letter-spacing: -0.02em; }
.page-heading p { margin: 0; color: var(--ink-soft); font-size: 14px; }
.tab-content { display: none; }
.tab-content.active { display: block; }
.filters-bar { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 12px; margin-bottom: 20px; background: var(--hover); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; }
.filter-field { display: flex; flex-direction: column; gap: 4px; }
.filter-field label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); font-weight: 600; }
.filter-field input, .filter-field select { border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 9px 12px; font: inherit; font-size: 14px; background: #fff; color: var(--ink); }
.filter-field input:focus, .filter-field select:focus { outline: none; border-color: var(--ink); }
.summary-line { display: flex; gap: 16px; align-items: center; margin-bottom: 16px; font-size: 13px; color: var(--ink-soft); }
.summary-line strong { color: var(--ink); font-weight: 600; }
.saved-table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.saved-table thead { background: var(--hover); }
.saved-table th { text-align: left; padding: 12px 16px; font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); font-weight: 600; border-bottom: 1px solid var(--line); }
.saved-table td { padding: 14px 16px; border-bottom: 1px solid var(--line-soft); font-size: 14px; vertical-align: middle; }
.saved-table tbody tr:last-child td { border-bottom: none; }
.saved-table tbody tr { transition: background 0.1s; }
.saved-table tbody tr:hover { background: var(--hover); cursor: pointer; }
.saved-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
.badge { display: inline-block; padding: 3px 10px; background: var(--line-soft); border-radius: 4px; font-size: 12px; font-weight: 500; font-family: ui-monospace, 'SF Mono', Menlo, monospace; }
.saved-table .mini-btn { padding: 6px 12px; font-size: 12px; border: 1px solid var(--line); background: #fff; border-radius: 6px; cursor: pointer; font: inherit; transition: all 0.15s; text-decoration: none; color: var(--ink); }
.saved-table .mini-btn:hover { border-color: var(--ink); background: var(--hover); }
.empty-state { text-align: center; padding: 64px 20px; color: var(--ink-soft); border: 1px dashed var(--line); border-radius: var(--radius); background: var(--hover); }
.empty-state h3 { margin: 0 0 6px; color: var(--ink); font-size: 16px; font-weight: 600; }
.btn { border: 1px solid var(--line); background: #fff; color: var(--ink); padding: 11px 20px; font: inherit; font-size: 14px; font-weight: 500; border-radius: 8px; cursor: pointer; transition: all 0.15s ease; display: inline-flex; align-items: center; gap: 8px; text-decoration: none; }
.btn:hover { background: var(--hover); border-color: #d1d5db; }
.toast { position: fixed; bottom: 24px; right: 24px; background: var(--ink); color: #fff; padding: 12px 20px; border-radius: 8px; font-size: 14px; font-weight: 500; box-shadow: 0 10px 30px rgba(0,0,0,0.25); transform: translateY(100px); opacity: 0; transition: all 0.25s ease; z-index: 1000; max-width: 320px; }
.toast.show { transform: translateY(0); opacity: 1; }

/* Status Indicators */
.status-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 6px; vertical-align: middle; cursor: help; }
.status-dot.red { background-color: #dc2626; }
.total-red { color: #dc2626; font-weight: 600; }
.total-green { color: #059669; font-weight: 600; }

@media (max-width: 768px) { .app-bar-inner { padding: 12px 16px; } .container { padding: 20px 16px 80px; } .filters-bar { grid-template-columns: 1fr; } .saved-table { font-size: 12px; } .saved-table th, .saved-table td { padding: 10px 8px; } }