: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); 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: 12px; }
.btn-logout { background:transparent; border:1px solid #e5e7eb; padding: 8px 14px; border-radius: 6px; cursor:pointer; font-family:inherit; color: var(--ink); text-decoration: none; display: inline-flex; align-items: center; font-size: 13px; }

.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; }

.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 td.num { text-align: right; font-variant-numeric: tabular-nums; font-weight: 500; }
.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; }

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

.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; }