:root{--primary: #2563eb;--primary-deep: #1d4ed8;--primary-soft: rgba(37, 99, 235, .1);--accent: #d97706;--accent-soft: rgba(217, 119, 6, .12);--bg: #f3f1ea;--surface: #ffffff;--sidebar: #101b30;--text: #1e2a3d;--text-muted: #5b6b81;--border: rgba(30, 42, 61, .1);--border-strong: rgba(30, 42, 61, .18);--danger: #dc2626;--success: #16a34a;--radius: 14px;--sidebar-width: 264px;--ease-out: cubic-bezier(.22, 1, .36, 1);font-family:Inter,system-ui,sans-serif;line-height:1.55;color:var(--text);background:radial-gradient(900px 500px at 85% -10%,rgba(37,99,235,.06),transparent 60%),var(--bg)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:var(--primary);text-decoration:none}button,input,select{font:inherit}h1,h2,h3{font-family:Space Grotesk,Inter,system-ui,sans-serif;letter-spacing:-.02em}.layout{display:flex;min-height:100vh}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#101b3080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:40}.sidebar-overlay.visible{display:block}.sidebar{width:var(--sidebar-width);background:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(165deg,#16233c,#0e1a2e);background-size:26px 26px,26px 26px,100% 100%;color:#dbe4f0;display:flex;flex-direction:column;padding:1.4rem .9rem 1.1rem;flex-shrink:0}.sidebar-brand{display:flex;align-items:center;gap:.65rem;padding:0 .5rem;margin-bottom:1.6rem;color:#f2f6fc}.sidebar-brand .logo-mark{width:32px;height:32px;flex-shrink:0}.sidebar-brand strong{display:block;font-family:Space Grotesk,sans-serif;font-size:1.2rem;letter-spacing:-.02em;line-height:1.15}.sidebar-brand span{display:block;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#7d90ab}.sidebar-nav{display:flex;flex-direction:column;gap:.3rem;flex:1}.sidebar-nav a{position:relative;display:flex;align-items:center;gap:.7rem;padding:.62rem .8rem;border-radius:10px;color:#a9b8cd;font-weight:500;font-size:.93rem;transition:background .2s ease,color .2s ease}.sidebar-nav a svg{width:18px;height:18px;flex-shrink:0;opacity:.85}.sidebar-nav a:hover{background:#ffffff0f;color:#f2f6fc}.sidebar-nav a.active{background:#ffffff17;color:#fff}.sidebar-nav a.active:before{content:"";position:absolute;left:-.9rem;top:20%;bottom:20%;width:3.5px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#f59e0b,#d97706)}.nav-badge{margin-left:auto;min-width:20px;padding:.05rem .4rem;border-radius:999px;background:#d97706;color:#fff;font-size:.72rem;font-weight:700;text-align:center}.sidebar-footer{border-top:1px solid rgba(255,255,255,.08);padding-top:.9rem;margin-top:.9rem}.sidebar-user{display:flex;align-items:center;gap:.65rem;padding:.35rem .45rem .7rem}.avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;font-family:Space Grotesk,sans-serif;font-size:.82rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8)}.sidebar-user-info{min-width:0}.user-chip{font-size:.86rem;font-weight:600;color:#f2f6fc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-chip.muted{font-weight:400;font-size:.76rem;color:#7d90ab}.logout{width:100%;padding:.5rem;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;border:1px solid rgba(255,255,255,.14);background:#ffffff0a;color:#dbe4f0;border-radius:10px;cursor:pointer;font-size:.88rem;font-weight:500;transition:background .2s ease,border-color .2s ease}.logout:hover{background:#dc262624;border-color:#f8717166;color:#fecaca}.logout svg{width:15px;height:15px}.layout-body{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{display:none;align-items:center;gap:.75rem;padding:.7rem 1rem;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:30}.menu-toggle{background:none;border:1px solid var(--border-strong);border-radius:8px;width:36px;height:36px;font-size:1.1rem;cursor:pointer;color:var(--text)}.topbar-title{font-family:Space Grotesk,sans-serif;font-weight:700}.main{padding:2rem 2.2rem 3rem;flex:1;width:100%;max-width:1240px;animation:page-enter .45s var(--ease-out)}@keyframes page-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.page-header{margin-bottom:1.5rem}.page-header:before{content:"";display:block;width:30px;height:8px;border-radius:2.5px;margin-bottom:.7rem;background:repeating-linear-gradient(-45deg,var(--accent) 0 6px,var(--text) 6px 12px);opacity:.85}.page-title{margin:0;font-size:1.65rem;font-weight:700}.page-subtitle{margin:.3rem 0 0;color:var(--text-muted);font-size:.95rem;max-width:640px}.page-status{padding:3rem;text-align:center;color:var(--text-muted)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.35rem 1.4rem;box-shadow:0 4px 20px #1e2a3d0d}.card h2{margin:0 0 .9rem;font-size:1.08rem}.card h3{font-size:.98rem}.section-label{margin:1.6rem 0 .8rem;font-size:.76rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.section-label:first-child{margin-top:0}.section-block{margin-top:1.6rem}.card-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.card-head h2{margin:0}.as-of{font-size:.82rem}th.num,td.num{text-align:right;font-variant-numeric:tabular-nums}td.num.strong{font-weight:700}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1rem}.stat{display:flex;align-items:center;gap:1rem;transition:transform .3s var(--ease-out),box-shadow .3s ease,border-color .3s ease}.stat:hover{transform:translateY(-3px);border-color:#2563eb4d;box-shadow:0 12px 32px #1e2a3d1a}.stat-icon{width:46px;height:46px;flex-shrink:0;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;color:var(--primary-deep);background:linear-gradient(135deg,#2563eb1f,#d977061a);border:1px solid var(--border-strong)}.stat-icon svg{width:22px;height:22px}.stat-body{min-width:0}.stat .value{font-family:Space Grotesk,sans-serif;font-size:1.9rem;font-weight:700;line-height:1.1}.stat .value.money{font-size:1.32rem;white-space:nowrap}.stats-finance{grid-template-columns:repeat(auto-fit,minmax(178px,1fr))}.stat .label{color:var(--text-muted);font-size:.86rem;margin-top:.15rem}.quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:1rem}.quick-card{display:flex;align-items:center;gap:.9rem;color:var(--text);transition:transform .3s var(--ease-out),box-shadow .3s ease,border-color .3s ease}.quick-card:hover{transform:translateY(-3px);border-color:#d9770666;box-shadow:0 12px 32px #1e2a3d1a}.quick-card strong{display:block;font-size:.98rem}.quick-card p{margin:.15rem 0 0;color:var(--text-muted);font-size:.85rem}.quick-card-arrow{margin-left:auto;color:var(--text-muted);transition:transform .3s var(--ease-out),color .3s ease}.quick-card:hover .quick-card-arrow{transform:translate(4px);color:var(--accent)}.form-grid{display:flex;flex-direction:column;gap:1rem}.form-grid label{display:flex;flex-direction:column;gap:.35rem;font-weight:600;font-size:.86rem;color:#33415c}.form-grid input,.form-grid select{padding:.6rem .8rem;border:1px solid var(--border-strong);border-radius:10px;background:#fff;font-weight:500;transition:border-color .25s ease,box-shadow .25s ease}.form-grid input:focus,.form-grid select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3.5px #2563eb24}.form-inline{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;align-items:end}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1.1rem;border-radius:10px;border:1px solid var(--border-strong);background:#fff;color:var(--text);font-weight:600;cursor:pointer;transition:transform .25s var(--ease-out),box-shadow .25s ease,background .25s ease,border-color .25s ease}.btn:hover{border-color:var(--accent);background:var(--accent-soft)}.btn-primary{border:none;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-deep) 100%);color:#fff;box-shadow:0 3px 14px #1d4ed84d,inset 0 1px #ffffff2e}.btn-primary:hover{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-deep) 100%);transform:translateY(-1px);box-shadow:0 8px 22px #1d4ed866,inset 0 1px #ffffff2e}.btn-primary:disabled{opacity:.7;cursor:default;transform:none}.btn-sm{padding:.34rem .7rem;font-size:.84rem;border-radius:8px}.btn-link{background:none;border:none;color:var(--primary);cursor:pointer;padding:0;font-weight:600}.btn-link.danger{color:var(--danger)}.error{color:var(--danger);background:#dc262612;border:1px solid rgba(220,38,38,.25);border-left:3px solid var(--danger);border-radius:10px;padding:.6rem .9rem;font-size:.9rem}.error.small{font-size:.8rem;padding:.4rem .7rem}.muted{color:var(--text-muted)}.table-wrap{overflow-x:auto;padding:.4rem .2rem}table{width:100%;border-collapse:collapse}th{text-align:left;padding:.6rem 1rem;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border-strong)}td{text-align:left;padding:.72rem 1rem;border-bottom:1px solid var(--border);font-size:.92rem}tbody tr{transition:background .15s ease}tbody tr:hover{background:#2563eb0a}tbody tr:last-child td{border-bottom:none}td a{font-weight:600}.badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.76rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;background:var(--primary-soft);color:var(--primary-deep)}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.badge-success{background:#16a34a1a;color:#15803d}.badge-muted{background:#5b6b811f;color:var(--text-muted)}.badge-warning,.badge-processing,.badge-pending{background:#fef3c7;color:#b45309}.badge-failed{background:#dc26261a;color:var(--danger)}.tabs{display:inline-flex;gap:.25rem;margin-bottom:1rem;padding:.28rem;border:1px solid var(--border);border-radius:12px;background:#ffffffb3}.tab{padding:.45rem 1rem;border:none;background:transparent;border-radius:9px;cursor:pointer;font-weight:500;color:var(--text-muted);transition:background .2s ease,color .2s ease,box-shadow .2s ease}.tab:hover{color:var(--text)}.tab.active{background:#fff;color:var(--primary-deep);font-weight:600;box-shadow:0 2px 8px #1e2a3d14}.dropzone{border:2px dashed var(--border-strong);border-radius:var(--radius);padding:2.2rem;text-align:center;cursor:pointer;margin-bottom:1rem;background:#ffffffb3;color:var(--text-muted);transition:border-color .25s ease,background .25s ease,color .25s ease}.dropzone:hover{border-color:var(--primary);background:#2563eb0a;color:var(--text)}.progress-row{margin-top:.5rem;text-align:left;font-size:.85rem}.progress-bar{height:6px;background:#1e2a3d1f;border-radius:3px;margin-top:.25rem;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:3px}.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.doc-card{padding:0;overflow:hidden;transition:transform .3s var(--ease-out),box-shadow .3s ease,border-color .3s ease}.doc-card:hover{transform:translateY(-3px);border-color:#2563eb4d;box-shadow:0 12px 32px #1e2a3d1a}.doc-preview{height:180px;background:#eef0f4;display:flex;align-items:center;justify-content:center}.doc-preview img,.doc-preview iframe{max-width:100%;max-height:100%;object-fit:contain}.doc-preview iframe{width:100%;height:100%;border:none}.doc-placeholder{color:var(--text-muted);font-size:.9rem}.doc-meta{padding:.9rem}.doc-meta strong{display:block;font-size:.9rem;margin-bottom:.35rem;word-break:break-all}.doc-actions{display:flex;gap:.75rem;margin-top:.5rem;font-size:.85rem}.login-page{display:flex;min-height:100vh;background:radial-gradient(900px 600px at 85% -10%,rgba(37,99,235,.09),transparent 60%),radial-gradient(700px 500px at 20% 110%,rgba(217,119,6,.07),transparent 60%),#f5f3ec}.login-scene{position:relative;flex:1.15;min-width:0;overflow:hidden}.login-scene-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block}.login-scene-fade{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(270deg,#f5f3ec 0%,rgba(245,243,236,.25) 22%,transparent 45%),linear-gradient(180deg,rgba(245,243,236,.5),transparent 20%)}.login-brand{position:absolute;left:2.2rem;bottom:2rem;color:#1e2a3d}.login-brand-logo{display:inline-flex;align-items:center;gap:.55rem;font-family:Space Grotesk,Inter,system-ui,sans-serif;font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.login-brand-logo .logo-mark{width:30px;height:30px}.login-brand p{margin:.3rem 0 0;color:#5b6b81;font-size:.95rem}.login-form-side{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{width:min(420px,100%);position:relative;overflow:hidden;border-radius:24px;border:1.5px solid transparent;background:linear-gradient(rgba(37,99,235,.05) 1px,transparent 1px) padding-box,linear-gradient(90deg,rgba(37,99,235,.05) 1px,transparent 1px) padding-box,linear-gradient(#ffffffb8,#ffffffb8) padding-box,linear-gradient(120deg,#2563eb66,#d9770661) border-box;background-size:26px 26px,26px 26px,100% 100%,100% 100%;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 24px 60px #1e2a3d1f;padding:2.4rem 2.2rem 2.2rem}.login-kicker{display:inline-flex;align-items:center;gap:.6rem;font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#d97706;margin-bottom:.8rem}.login-kicker-stripe{width:26px;height:8px;border-radius:2.5px;background:repeating-linear-gradient(-45deg,#d97706 0,#d97706 6px,#1e2a3d 6px,#1e2a3d 12px);opacity:.9}.login-card h2{margin:0 0 .35rem;font-family:Space Grotesk,Inter,system-ui,sans-serif;font-size:1.7rem;letter-spacing:-.02em}.login-desc{margin:0 0 1.6rem;color:var(--text-muted);font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.05rem}.login-field{display:flex;flex-direction:column;gap:.4rem;font-weight:600;font-size:.86rem;color:#33415c}.login-input-wrap{position:relative;display:flex;align-items:center}.login-input-wrap>svg{position:absolute;left:.85rem;width:18px;height:18px;color:#8194ad;pointer-events:none;transition:color .25s ease}.login-input-wrap:focus-within>svg{color:var(--primary)}.login-input-wrap input{width:100%;padding:.72rem 2.6rem .72rem 2.55rem;border:1px solid rgba(30,42,61,.16);border-radius:12px;background:#ffffffd9;font-weight:500;transition:border-color .25s ease,box-shadow .25s ease}.login-input-wrap input::placeholder{color:#a6b3c5;font-weight:400}.login-input-wrap input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3.5px #2563eb24}.login-eye{position:absolute;right:.45rem;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;border-radius:8px;color:#8194ad;cursor:pointer;transition:color .25s ease,background .25s ease}.login-eye:hover{color:#33415c;background:#1e2a3d0f}.login-eye svg{width:18px;height:18px}.login-submit{margin-top:.35rem;padding:.8rem 1rem;border-radius:12px;font-size:1rem;background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 18px #1d4ed859,inset 0 1px #ffffff2e;transition:transform .25s ease,box-shadow .25s ease,opacity .25s ease}.login-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 26px #1d4ed873,inset 0 1px #ffffff2e}.login-submit:disabled{opacity:.7;cursor:default}.login-help{margin:1.4rem 0 0;font-size:.84rem;color:var(--text-muted);text-align:center}.login-help a{font-weight:600}.page-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.finance-toolbar{flex-wrap:wrap;align-items:flex-end}.date-filter{display:flex;align-items:flex-end;gap:.7rem;flex-wrap:wrap}.date-filter label{display:flex;flex-direction:column;gap:.25rem;font-size:.76rem;font-weight:600;color:var(--text-muted)}.date-filter input{padding:.45rem .6rem;border:1px solid var(--border-strong);border-radius:8px;background:#fff}.date-filter input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb24}.row-reversed td{opacity:.5;text-decoration:line-through}.row-reversed td:last-child{opacity:1;text-decoration:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#101b3080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:1.25rem;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{width:min(520px,100%);max-height:90vh;overflow-y:auto;background:var(--surface);border-radius:18px;border:1px solid var(--border);box-shadow:0 30px 70px #0f1a2e4d;padding:1.5rem;animation:modal-pop .25s var(--ease-out)}@keyframes modal-pop{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}.modal-head h2{margin:0;font-size:1.25rem}.modal-close{border:none;background:none;font-size:1.6rem;line-height:1;color:var(--text-muted);cursor:pointer;width:32px;height:32px;border-radius:8px}.modal-close:hover{background:#1e2a3d0f;color:var(--text)}.modal-actions{display:flex;justify-content:flex-end;gap:.7rem;margin-top:.5rem}.form-row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.type-btn{padding:.7rem;border:1.5px solid var(--border-strong);background:#fff;border-radius:10px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.type-btn.income.active{border-color:var(--success);background:#16a34a1a;color:#15803d}.type-btn.expense.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}@media(max-width:900px){.sidebar{position:fixed;inset:0 auto 0 0;z-index:50;transform:translate(-100%);transition:transform .25s var(--ease-out)}.sidebar.open{transform:translate(0)}.topbar{display:flex}.main{padding:1.25rem 1.1rem 2rem}.login-scene{display:none}.login-form-side{padding:1.25rem}.form-row2{grid-template-columns:1fr}.page-header-row{flex-direction:column}}@media(prefers-reduced-motion:reduce){.main{animation:none}.stat,.quick-card,.doc-card,.btn,.sidebar{transition:none}}
