:root{--bg: #f4f5fb;--surface: #ffffff;--surface-2: #f8f9fc;--border: #e5e7eb;--border-strong: #cbd5e1;--text: #1f2937;--text-soft: #374151;--muted: #6b7280;--accent: #3b5bdb;--accent-strong: #2f47b5;--accent-soft: #e7eaff;--accent-on: #ffffff;--topbar: #3b5bdb;--avatar: #d6336c;--danger: #dc2626;--danger-soft: #fee2e2;--warn: #d97706;--warn-soft: #fef3c7;--ok: #15803d;--ok-soft: #dcfce7;--shadow-soft: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 3px rgba(15, 23, 42, .06);--shadow-card: 0 1px 2px rgba(15, 23, 42, .04);--radius: 12px;--radius-sm: 8px;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);color-scheme:light;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100vh;height:100%}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1{font-size:22px;margin:0 0 4px;font-weight:600}h2{font-size:17px;margin:0 0 4px;font-weight:600}h3{font-size:14px;margin:0 0 4px;font-weight:600}p{margin:0}button{font:inherit;cursor:pointer;padding:9px 16px;background:var(--accent);color:var(--accent-on);border:1px solid var(--accent);border-radius:8px;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:background-color .1s ease,border-color .1s ease}button:hover:not(:disabled){background:var(--accent-strong);border-color:var(--accent-strong)}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:var(--surface);color:var(--accent);border-color:var(--border-strong)}button.secondary:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent)}button.danger{background:var(--danger);color:#fff;border-color:var(--danger)}button.danger:hover:not(:disabled){filter:brightness(.92)}button.ghost{background:transparent;color:var(--accent);border-color:transparent;padding:6px 8px}button.ghost:hover:not(:disabled){background:var(--accent-soft)}button.icon-btn{padding:6px;background:transparent;color:var(--muted);border:none;border-radius:8px;min-height:0}button.icon-btn:hover{background:var(--surface-2);color:var(--text)}button.icon-btn.danger{color:var(--danger);background:transparent;border:none}button.icon-btn.danger:hover{background:var(--danger-soft)}input,select,textarea{font:inherit;padding:10px 12px;background:var(--surface);color:var(--text);border:1px solid var(--border-strong);border-radius:8px;width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}textarea{font-family:ui-monospace,SFMono-Regular,monospace;font-size:13px;min-height:80px}label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:500}.field{margin-bottom:14px}.field:last-child{margin-bottom:0}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-card)}.card h2,.card h3{margin-bottom:14px}.card-header{display:flex;align-items:baseline;gap:12px;margin-bottom:16px;flex-wrap:wrap}.card-header h2{margin:0}.card-header .text-muted{font-size:13px}table{width:100%;border-collapse:collapse}th,td{padding:10px 8px;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}th{color:var(--muted);font-weight:600;font-size:12px}tr:last-child td{border-bottom:none}td.text-right,th.text-right{text-align:right}.text-muted{color:var(--muted)}.text-right{text-align:right}.error{color:var(--danger)}.ok{color:var(--ok)}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.col{display:flex;flex-direction:column;gap:12px}.spacer{flex:1}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}@media (max-width: 720px){.grid-2,.grid-3{grid-template-columns:1fr}}.badge{display:inline-flex;align-items:center;font-size:11px;padding:3px 10px;border-radius:999px;font-weight:600;letter-spacing:.02em;line-height:1.4}.badge.ok{background:var(--ok-soft);color:var(--ok)}.badge.warn{background:var(--warn-soft);color:var(--warn)}.badge.muted{background:var(--surface-2);color:var(--muted)}.badge.danger{background:var(--danger-soft);color:var(--danger)}.badge.accent{background:var(--accent-soft);color:var(--accent)}.empty{text-align:center;padding:32px 16px;color:var(--muted);background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:10px}.empty p{margin-bottom:12px}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;min-height:100dvh}.app-shell aside{background:var(--surface);border-right:1px solid var(--border);padding:20px 14px 16px;display:flex;flex-direction:column;gap:14px}.app-shell main{display:flex;flex-direction:column;min-width:0;overflow-x:hidden}.content{padding:24px 28px;max-width:1200px;width:100%}.topbar{background:var(--topbar);color:#fff;display:flex;align-items:center;gap:12px;padding:14px 24px;min-height:56px}.topbar-title{font-size:16px;font-weight:500}.avatar{width:36px;height:36px;border-radius:50%;background:var(--avatar);color:#fff;display:grid;place-items:center;font-weight:600;font-size:14px}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:2px 4px 12px;border-bottom:1px solid var(--border);margin-bottom:4px}.sidebar-brand-text{font-weight:600;font-size:15px}.scope-panel{border:1px solid var(--border-strong);border-radius:8px;padding:12px 12px 4px}.scope-panel .field{margin-bottom:10px}.scope-panel label{font-size:11px}.scope-panel select{padding:8px 10px}.nav-list{display:flex;flex-direction:column;gap:2px}.nav-link{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:8px;color:var(--text-soft);font-weight:500;font-size:14px;transition:background-color .12s ease,color .12s ease}.nav-link:hover{background:var(--surface-2);text-decoration:none}.nav-link.active{background:var(--accent-soft);color:var(--accent-strong)}.nav-link .material-icons{font-size:20px;color:inherit}.mobile-bar{display:none;position:sticky;top:0;z-index:40;align-items:center;gap:10px;padding:10px 14px;background:var(--topbar);color:#fff;border-bottom:1px solid var(--border)}.mobile-bar .topbar-title{color:#fff}.hamburger{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;padding:8px 10px;border-radius:8px;font-size:18px;line-height:1;min-height:0}.hamburger:hover{background:#ffffff1f}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:49;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.page-header{display:flex;align-items:baseline;gap:12px;margin-bottom:20px;flex-wrap:wrap}.page-header h1{margin:0}.page-header .text-muted{font-size:14px}.modal{border:none;border-radius:14px;padding:0;background:var(--surface);color:var(--text);box-shadow:0 24px 48px #0f172a40;max-height:calc(100dvh - 32px)}.modal::backdrop{background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-body{display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;flex:1}.modal-content{padding:22px;max-height:70vh;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 22px;border-top:1px solid var(--border);background:var(--surface-2);border-radius:0 0 14px 14px}.combobox{position:relative}.combobox-options{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;box-shadow:0 8px 24px #0f172a1f;z-index:60;max-height:240px;overflow-y:auto}.combobox-option{padding:8px 12px;cursor:pointer;font-size:14px}.combobox-option:hover,.combobox-option[aria-selected=true]{background:var(--accent-soft)}.combobox-option.is-new{border-top:1px solid var(--border);font-weight:500;color:var(--accent)}.intervals-row{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:end;margin-bottom:8px}.intervals-row .field{margin:0}.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}.scope-picker{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;align-items:end}.export-menu{position:relative;display:inline-block}.export-menu-popover{position:absolute;top:calc(100% + 6px);right:0;z-index:60;background:var(--surface);border:1px solid var(--border-strong);border-radius:12px;box-shadow:0 10px 24px #0f172a29;padding:8px;min-width:240px;display:flex;flex-direction:column;gap:4px}.export-menu-popover button{justify-content:flex-start;width:100%}.export-menu-backdrop{display:none}@media (max-width: 720px){.export-menu-popover{position:fixed;top:auto;right:16px;left:16px;bottom:16px;min-width:0;z-index:70;padding:12px;gap:8px}.export-menu-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:69}}.month-picker{position:relative;display:inline-block}.month-picker-trigger{display:inline-flex;align-items:center;min-width:200px;justify-content:space-between}.month-picker-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:30;background:var(--surface);border:1px solid var(--border-strong);border-radius:12px;box-shadow:0 10px 24px #0f172a1f;padding:12px;width:280px;max-width:calc(100vw - 32px)}@media (max-width: 720px){.month-picker-popover{position:fixed;top:auto;bottom:16px;left:16px;right:16px;width:auto;max-width:none}}.month-picker-year{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 10px;border-bottom:1px solid var(--border);margin-bottom:8px}.month-picker-year strong{font-size:15px}.month-picker-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.month-picker-cell{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:8px 6px;border-radius:8px;font-weight:500;font-size:13px;cursor:pointer}.month-picker-cell:hover{background:var(--surface-2)}.month-picker-cell.is-today{border-color:var(--accent);color:var(--accent-strong)}.month-picker-cell.is-selected{background:var(--accent);border-color:var(--accent);color:#fff}.month-picker-cell.is-selected:hover{background:var(--accent-strong)}.month-picker-footer{margin-top:10px;padding-top:8px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:16px}.kpi-grid .card{margin:0}.kpi-card{padding:20px}.kpi-card-with-icon{display:flex;align-items:center;gap:16px}.kpi-icon{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent);flex-shrink:0}.kpi-icon.ok{background:var(--ok-soft);color:var(--ok)}.kpi-icon.warn{background:var(--warn-soft);color:var(--warn)}.kpi-icon .material-icons{font-size:24px}.kpi-label{font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:500}.kpi-value{font-size:24px;font-weight:700;color:var(--text);line-height:1.1}.kpi-card .kpi-meta{display:flex;gap:8px;align-items:baseline;margin-top:8px;font-size:12px}.kpi-meta.tone-positive>span:first-child{color:var(--ok);font-weight:600}.kpi-meta.tone-negative>span:first-child{color:var(--danger);font-weight:600}.kpi-meta.tone-neutral>span:first-child{color:var(--muted);font-weight:600}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.info-card{display:flex;align-items:center;gap:12px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card)}.info-card .info-icon{width:36px;height:36px;border-radius:8px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent)}.info-card .info-icon .material-icons{font-size:22px}.info-card-label{font-size:12px;color:var(--muted);margin-bottom:2px}.info-card-value{font-size:15px;font-weight:600;line-height:1.2}.info-card.info-card-action{justify-content:center;align-items:stretch;padding:0}.info-card.info-card-action button{flex:1;border-radius:var(--radius);padding:16px;justify-content:center}.subcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.subcard{border:1px solid var(--border);border-radius:10px;padding:12px}.subcard-label{color:var(--muted);font-size:12px}.subcard-value{font-size:18px;font-weight:700;margin:4px 0}.subcard-foot{color:var(--ok);font-size:13px;font-weight:600}.trend-bars{display:flex;align-items:flex-end;gap:12px;height:200px;padding:8px 0}.trend-bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:6px;min-width:0}.trend-bar-value{font-size:11px;color:var(--text-soft);font-weight:500;text-align:center;white-space:nowrap}.trend-bar-fill{width:100%;background:linear-gradient(180deg,var(--accent) 0%,var(--accent-strong) 100%);border-radius:6px 6px 0 0;min-height:4px;transition:height .2s ease}.trend-bar-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px}@media (max-width: 900px){.dashboard-grid{grid-template-columns:1fr}}.day-group{margin-bottom:18px}.day-group-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.day-group-header strong{font-size:14px}.entry-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:10px}.entry-card-top{display:flex;align-items:flex-start;gap:12px}.entry-card-meta{flex:1;min-width:0}.entry-card-time{font-size:13px;color:var(--text-soft);margin-bottom:4px}.entry-card-amount{text-align:right;font-weight:600}.entry-card-amount .secondary{display:block;font-size:12px;color:var(--ok);font-weight:600}.entry-card-task{font-weight:600;margin-top:6px}.entry-card-desc{margin-top:2px;color:var(--muted);font-size:13px}.entry-card-actions{display:flex;justify-content:flex-end;gap:4px;margin-top:8px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px;flex-wrap:wrap}.tab{padding:12px 18px;background:transparent;border:none;color:var(--muted);font-weight:500;font-size:13px;text-transform:uppercase;letter-spacing:.05em;position:relative;cursor:pointer;border-radius:0;min-height:0}.tab:hover:not(:disabled){background:transparent;color:var(--text)}.tab.active{color:var(--accent)}.tab.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--accent)}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap>table{min-width:640px}.table-wrap.table-cards{overflow-x:visible}.table-wrap.table-cards>table{min-width:0}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.mobile-bar{display:flex}main>.topbar{display:none}.app-shell aside{position:fixed;top:0;left:0;bottom:0;width:84vw;max-width:320px;transform:translate(-100%);transition:transform .2s ease;z-index:50;box-shadow:0 12px 24px #0f172a1f;border-right:1px solid var(--border)}.app-shell.drawer-open aside{transform:translate(0)}.content{padding:16px}.topbar{padding:12px 16px}.card:not(:has(.table-cards)){overflow-x:auto}table{font-size:13px}.table-cards table,.table-cards thead,.table-cards tbody,.table-cards tr,.table-cards td{display:block;width:100%}.table-cards thead{display:none}.table-cards tr{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 12px;margin-bottom:10px;box-shadow:var(--shadow-card)}.table-cards tr:hover td{background:transparent}.table-cards td{border:none;padding:6px 0;display:flex;justify-content:space-between;gap:12px;text-align:right;align-items:center;min-height:32px}.table-cards td:before{content:attr(data-label);color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;text-align:left;flex-shrink:0}.table-cards td:first-child{font-size:15px;font-weight:600;border-bottom:1px solid var(--border);margin-bottom:6px;padding-bottom:8px;justify-content:flex-start;text-align:left}.table-cards td:first-child:before{display:none}.table-cards td.actions-cell{padding-top:8px}.table-cards td.actions-cell:before{display:none}.table-cards td.actions-cell .row{justify-content:flex-end;width:100%}}@media (max-width: 720px){h1{font-size:19px}h2{font-size:16px}.card{padding:14px;border-radius:10px}.modal{width:100%;max-width:100%!important;border-radius:0}.modal-content{max-height:calc(100dvh - 140px)}button,input,select,textarea{font-size:16px}button{padding:10px 14px;min-height:44px}input,select{padding:10px 12px;min-height:44px}button.icon-btn{min-height:0;padding:6px}.toolbar{gap:8px}.month-picker-trigger{min-width:160px}.topbar-title{font-size:15px}.content{padding:12px}}@media (hover: none){tr:hover td{background:transparent}}
