:root{--brand-navy: #0F1E2D;--brand-navy-2: #162333;--brand-teal: #1DAF90;--brand-teal-2: #17937A;--brand-teal-3: #0F7261;--brand-teal-bg: #E8F7F3;--bg: #F4F2EE;--bg-2: #EDEBE7;--surface: #FFFFFF;--surface-2: #FAFAF8;--surface-3: #F5F4F1;--border: #E4DFD8;--border-2: #D5CFCA;--text-1: #141920;--text-2: #4B5361;--text-3: #8A929E;--text-4: #B0B7C0;--text-inv: #ECF0F4;--paid: #1B6B45;--paid-bg: #ECFDF5;--paid-border: #A4D9BF;--planned: #1E4F8C;--planned-bg: #EFF6FF;--planned-border:#93C5E8;--open: #8B5E2A;--open-bg: #FFF7ED;--open-border: #EDBA7A;--danger: #A8200A;--danger-bg: #FFF1F1;--danger-border: #F9A8A0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--sidebar-w: 260px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 18px;--r-2xl: 24px;--shadow-xs: 0 1px 2px rgba(14,22,32,.04);--shadow-sm: 0 1px 3px rgba(14,22,32,.07), 0 1px 2px rgba(14,22,32,.04);--shadow-md: 0 4px 12px rgba(14,22,32,.08), 0 1px 4px rgba(14,22,32,.04);--shadow-lg: 0 8px 24px rgba(14,22,32,.1), 0 2px 6px rgba(14,22,32,.05);--shadow-xl: 0 16px 48px rgba(14,22,32,.14), 0 4px 12px rgba(14,22,32,.07);--shadow-overlay: 0 24px 64px rgba(0,0,0,.24);--ease: .16s cubic-bezier(.2, 0, 0, 1);--ease-slow: .3s cubic-bezier(.2, 0, 0, 1);--ease-spring: .4s cubic-bezier(.34, 1.4, .64, 1);--font: "Inter", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text-1);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}input,select,textarea{font:inherit;color:inherit}table{border-collapse:collapse;width:100%}img,svg{display:block;max-width:100%}h1,h2,h3,h4{font-weight:600;line-height:1.25;letter-spacing:-.02em}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.app-shell{display:flex;min-height:100vh}.app-main{flex:1;min-width:0;padding:var(--space-8) 2.5rem;overflow-y:auto}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--brand-navy);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden;z-index:40}.sidebar__brand{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.07)}.sidebar__brand-text{display:flex;flex-direction:column;gap:1px}.sidebar__app-name{font-size:1rem;font-weight:800;color:#edf1f6;letter-spacing:-.025em;line-height:1.15}.sidebar__app-by{font-size:.675rem;font-weight:400;color:#ffffff4d;letter-spacing:.01em}.sidebar__footer{padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0}.sidebar__footer-logo{display:inline-flex;align-items:center;background:#fffffff0;border-radius:var(--r-md);padding:5px 10px;transition:opacity var(--ease)}.sidebar__footer-logo:hover{opacity:.85}.sidebar__footer-logo img{height:22px;width:auto;display:block;object-fit:contain}.sidebar__budget-strip{padding:.75rem 1.125rem;border-bottom:1px solid rgba(255,255,255,.07)}.sidebar__budget-meta{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.35rem}.sidebar__budget-label{font-size:.675rem;font-weight:600;letter-spacing:.065em;text-transform:uppercase;color:#ffffff52}.sidebar__budget-pct{font-size:.775rem;font-weight:700;color:var(--brand-teal);font-variant-numeric:tabular-nums}.sidebar__budget-pct--over{color:#ff7a6e}.sidebar__budget-bar{height:3px;background:#ffffff1a;border-radius:2px;overflow:hidden}.sidebar__budget-fill{height:100%;background:linear-gradient(90deg,var(--brand-teal-3),var(--brand-teal));border-radius:2px;transition:width .6s var(--ease-slow)}.sidebar__budget-fill--over{background:#ff7a6e}.sidebar__nav{flex:1;padding:var(--space-2) var(--space-2);overflow-y:auto;display:flex;flex-direction:column;gap:1px}.sidebar__nav-group-label{padding:.625rem var(--space-3) .25rem;font-size:.65rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:#ffffff38}.sidebar__link{display:flex;align-items:center;gap:.625rem;padding:.5625rem .75rem;border-radius:var(--r-md);font-size:.8375rem;font-weight:500;color:#ffffff80;transition:background var(--ease),color var(--ease);position:relative;letter-spacing:-.005em;padding-left:calc(.75rem + 3px)}.sidebar__link:hover{background:#fff1;color:#ffffffd9}.sidebar__link--active{background:#1daf9024;color:#edf1f6;font-weight:600}.sidebar__link--active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--brand-teal);border-radius:0 3px 3px 0}.sidebar__link-icon{display:flex;align-items:center;justify-content:center;width:18px;flex-shrink:0;opacity:.6;transition:opacity var(--ease)}.sidebar__link:hover .sidebar__link-icon{opacity:.85}.sidebar__link--active .sidebar__link-icon{opacity:1;color:var(--brand-teal)}.mobile-bar{display:none;position:sticky;top:0;z-index:30;background:var(--surface);border-bottom:1px solid var(--border);padding:0 1rem;height:52px;align-items:center;gap:var(--space-3);box-shadow:var(--shadow-xs)}.mobile-bar__menu{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-md);color:var(--text-2);transition:background var(--ease)}.mobile-bar__menu:hover{background:var(--bg)}.mobile-bar__brand{font-size:.9375rem;font-weight:700;color:var(--text-1);letter-spacing:-.02em}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:39;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn var(--ease-slow) forwards}.page{display:flex;flex-direction:column;gap:1.625rem;max-width:1120px}.page__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap}.page__title{font-size:1.625rem;font-weight:800;color:var(--text-1);letter-spacing:-.03em;line-height:1.15}.page__subtitle{font-size:.875rem;color:var(--text-3);line-height:1.55;margin-top:.25rem}.page__actions{display:flex;gap:var(--space-2);flex-shrink:0;align-items:center}.back-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.8125rem;color:var(--text-3);margin-bottom:.3rem;transition:color var(--ease)}.back-link:hover{color:var(--text-1)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:box-shadow var(--ease)}.card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;padding-bottom:.875rem;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:var(--space-2)}.card__title{font-size:.9375rem;font-weight:700;color:var(--text-1);letter-spacing:-.015em}.card__subtitle{font-size:.8rem;color:var(--text-3);margin-top:.2rem;font-weight:400}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.375rem var(--space-6) 1.25rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:box-shadow var(--ease),transform var(--ease);border-top:3px solid var(--border)}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card--paid{border-top-color:var(--paid)}.kpi-card--planned{border-top-color:var(--planned)}.kpi-card--danger{border-top-color:var(--danger)}.kpi-card--accent{border-top-color:var(--brand-teal)}.kpi-card__icon-wrap{width:34px;height:34px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--surface-3);color:var(--text-3);margin-bottom:var(--space-4)}.kpi-card--paid .kpi-card__icon-wrap{background:var(--paid-bg);color:var(--paid)}.kpi-card--planned .kpi-card__icon-wrap{background:var(--planned-bg);color:var(--planned)}.kpi-card--danger .kpi-card__icon-wrap{background:var(--danger-bg);color:var(--danger)}.kpi-card--accent .kpi-card__icon-wrap{background:var(--brand-teal-bg);color:var(--brand-teal-2)}.kpi-card__label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:var(--space-1)}.kpi-card__value{font-size:1.875rem;font-weight:800;letter-spacing:-.04em;color:var(--text-1);line-height:1.1;font-variant-numeric:tabular-nums;margin-bottom:var(--space-2)}.kpi-card--paid .kpi-card__value{color:var(--paid)}.kpi-card--danger .kpi-card__value{color:var(--danger)}.kpi-card--muted .kpi-card__value{font-size:1.25rem;font-weight:500;color:var(--text-3);letter-spacing:-.01em}.kpi-card__meta{font-size:.775rem;color:var(--text-3);line-height:1.45}.kpi-card__trend{display:inline-flex;align-items:center;gap:.25rem;font-size:.72rem;font-weight:600;padding:.2rem .5rem;border-radius:999px;margin-top:var(--space-2)}.kpi-card__trend--positive{background:var(--paid-bg);color:var(--paid);border:1px solid var(--paid-border)}.kpi-card__trend--negative{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.kpi-card__trend--neutral{background:var(--surface-3);color:var(--text-3);border:1px solid var(--border)}.budget-status{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--space-6);box-shadow:var(--shadow-sm)}.budget-status__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.375rem;flex-wrap:wrap;gap:var(--space-2);border-bottom:none!important;padding-bottom:0!important}.budget-status__bar-wrap{margin-bottom:1.375rem}.budget-status__bar-labels{display:flex;justify-content:space-between;margin-bottom:var(--space-2)}.budget-status__bar-legend{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-3);font-weight:500}.budget-status__bar-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.budget-status__track{height:10px;background:var(--surface-3);border:1px solid var(--border);border-radius:5px;overflow:hidden;display:flex;position:relative}.budget-status__fill-paid{background:linear-gradient(90deg,#1B9060,var(--paid));height:100%;border-radius:5px 0 0 5px;transition:width .7s var(--ease-slow);position:relative;z-index:2}.budget-status__fill-paid--full{border-radius:5px}.budget-status__fill-planned{background:var(--planned);opacity:.5;height:100%;transition:width .7s var(--ease-slow);position:relative;z-index:1}.budget-status__fill-over{background:var(--danger);opacity:.75;height:100%}.budget-status__pct{margin-top:var(--space-2);font-size:.75rem;color:var(--text-3);text-align:right}.budget-status__metrics{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.budget-status__metric{background:var(--surface);padding:var(--space-4) var(--space-5);border-right:1px solid var(--border);border-bottom:1px solid var(--border)}.budget-status__metric:nth-child(3n){border-right:none}.budget-status__metric:nth-last-child(-n+3){border-bottom:none}.budget-status__metric-label{font-size:.72rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.065em;margin-bottom:var(--space-1)}.budget-status__metric-value{font-size:1.0625rem;font-weight:700;color:var(--text-1);letter-spacing:-.025em;font-variant-numeric:tabular-nums}.budget-status__metric-value--paid{color:var(--paid)}.budget-status__metric-value--planned{color:var(--planned)}.budget-status__metric-value--over{color:var(--danger)}.budget-status__alert{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--r-md);font-size:.875rem;color:var(--danger);display:flex;align-items:center;gap:var(--space-2);font-weight:500}.budget-status--empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2.5rem var(--space-8);gap:var(--space-3)}.budget-empty-state{display:flex;align-items:center;gap:var(--space-5);padding:1.625rem var(--space-6)}.budget-empty-state__icon{width:48px;height:48px;flex-shrink:0;background:var(--brand-teal-bg);border:1px solid rgba(29,175,144,.2);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;color:var(--brand-teal-2)}.budget-empty-state__body{flex:1;min-width:0}.budget-empty-state__title{font-size:.9375rem;font-weight:700;color:var(--text-1);letter-spacing:-.015em;margin-bottom:.25rem}.budget-empty-state__desc{font-size:.8375rem;color:var(--text-3);line-height:1.6;max-width:460px}@media (max-width: 600px){.budget-empty-state{flex-direction:column;text-align:center}.budget-empty-state__desc{max-width:100%}}.area-overview__list{display:flex;flex-direction:column;gap:1rem}.area-overview__item{display:flex;flex-direction:column;gap:.3rem}.area-overview__item-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.area-overview__item-left{display:flex;align-items:center;gap:var(--space-2);min-width:0;flex:1}.area-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.area-overview__name{font-size:.875rem;font-weight:500;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.area-overview__amount{font-size:.875rem;font-weight:700;color:var(--text-1);font-variant-numeric:tabular-nums;white-space:nowrap}.area-overview__pct{font-size:.75rem;color:var(--text-3);white-space:nowrap}.area-overview__bar{height:4px;background:var(--surface-3);border-radius:2px;overflow:hidden}.area-overview__bar-fill{height:100%;border-radius:2px;transition:width .5s var(--ease-slow)}.recent-items__list{display:flex;flex-direction:column}.recent-item{display:flex;align-items:center;justify-content:space-between;padding:.8125rem 0;border-bottom:1px solid var(--border);gap:var(--space-3);text-decoration:none;transition:background var(--ease);margin:0 calc(-1 * var(--space-3));padding-left:var(--space-3);padding-right:var(--space-3);border-radius:var(--r-md)}.recent-item:last-child{border-bottom:none}.recent-item:hover{background:var(--surface-2)}.recent-item__left{display:flex;flex-direction:column;gap:.1rem;min-width:0;flex:1}.recent-item__title{font-size:.875rem;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-item__meta{font-size:.75rem;color:var(--text-3)}.recent-item__right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.recent-item__amount{font-size:.9375rem;font-weight:700;color:var(--text-1);font-variant-numeric:tabular-nums;white-space:nowrap}.status-badge{display:inline-flex;align-items:center;gap:.3125rem;padding:.2rem .575rem;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.01em;white-space:nowrap;border:1px solid transparent}.status-badge--paid{background:var(--paid-bg);color:var(--paid);border-color:var(--paid-border)}.status-badge--planned{background:var(--planned-bg);color:var(--planned);border-color:var(--planned-border)}.status-badge--open{background:var(--open-bg);color:var(--open);border-color:var(--open-border)}.status-badge--danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}.status-badge__dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}.badge{display:inline-flex;align-items:center;padding:.2rem .575rem;border-radius:999px;font-size:.7rem;font-weight:700;white-space:nowrap;border:1px solid transparent}.badge--paid{background:var(--paid-bg);color:var(--paid);border-color:var(--paid-border)}.badge--planned,.badge--info{background:var(--planned-bg);color:var(--planned);border-color:var(--planned-border)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2.5rem var(--space-6);gap:var(--space-3)}.empty-state__icon{width:52px;height:52px;background:linear-gradient(145deg,var(--surface-3),var(--bg));border:1px solid var(--border);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;color:var(--text-3);box-shadow:var(--shadow-xs);margin-bottom:var(--space-1)}.empty-state__title{font-size:.9375rem;font-weight:700;color:var(--text-1);letter-spacing:-.015em}.empty-state__desc{font-size:.8375rem;color:var(--text-3);max-width:300px;line-height:1.6}.empty-state--compact{padding:1.5rem var(--space-4);gap:var(--space-2)}.empty-state--compact .empty-state__icon{width:40px;height:40px}.empty-state__text{display:flex;flex-direction:column;gap:.25rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4375rem;font-weight:600;border-radius:var(--r-md);white-space:nowrap;letter-spacing:-.01em;outline:none;position:relative;transition:background var(--ease),box-shadow var(--ease),border-color var(--ease),opacity var(--ease),transform var(--ease)}.btn:focus-visible{box-shadow:0 0 0 3px #1daf904d}.btn:active:not(:disabled){transform:scale(.98)}.btn--sm{padding:.3125rem .75rem;font-size:.8rem}.btn--md{padding:.5rem 1rem;font-size:.875rem}.btn--lg{padding:.625rem 1.25rem;font-size:.9375rem}.btn--primary{background:var(--brand-navy);color:#fff;box-shadow:0 1px 2px #0e162033}.btn--primary:hover:not(:disabled){background:var(--brand-navy-2);box-shadow:0 3px 10px #0e162038}.btn--secondary{background:var(--surface);color:var(--text-1);border:1.5px solid var(--border-2);box-shadow:var(--shadow-xs)}.btn--secondary:hover:not(:disabled){background:var(--bg);border-color:var(--text-3);box-shadow:var(--shadow-sm)}.btn--danger{background:var(--surface);color:var(--danger);border:1.5px solid var(--danger-border)}.btn--danger:hover:not(:disabled){background:var(--danger-bg);box-shadow:0 2px 8px #a8200a1f}.btn--ghost{background:transparent;color:var(--text-2)}.btn--ghost:hover:not(:disabled){background:var(--bg);color:var(--text-1)}.btn--accent{background:var(--brand-teal);color:#fff;box-shadow:0 1px 2px #1daf9040}.btn--accent:hover:not(:disabled){background:var(--brand-teal-2);box-shadow:0 3px 10px #1daf904d}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--loading{opacity:.7;cursor:wait}.btn__spinner{width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:#ffffffe6;border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}.field{display:flex;flex-direction:column;gap:.375rem}.field__label{font-size:.8125rem;font-weight:600;color:var(--text-2);letter-spacing:.01em}.field__input{padding:.5625rem .875rem;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text-1);transition:border-color var(--ease),box-shadow var(--ease);width:100%;font-size:.875rem}.field__input::placeholder{color:var(--text-4)}.field__input:focus{outline:none;border-color:var(--brand-navy);box-shadow:0 0 0 3px #0f1e2d1a}.field--error .field__input{border-color:var(--danger)}.field--error .field__input:focus{box-shadow:0 0 0 3px #a8200a1f}.field__error{font-size:.8rem;color:var(--danger)}.field__hint{font-size:.8rem;color:var(--text-3)}.field__textarea{resize:vertical;min-height:80px;line-height:1.6}.field__select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238A929E' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center;padding-right:2.25rem;cursor:pointer}.form{display:flex;flex-direction:column;gap:1.125rem}.form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form__row--inline{display:flex;align-items:flex-end;gap:.875rem}.form__actions{display:flex;justify-content:flex-end;gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--border);margin-top:.25rem}.form-card{max-width:700px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080f1885;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-4);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .15s ease}.modal{background:var(--surface);border-radius:var(--r-2xl);box-shadow:var(--shadow-overlay);display:flex;flex-direction:column;max-height:90vh;width:100%;animation:slideUp .18s cubic-bezier(.2,0,0,1)}.modal--sm{max-width:440px}.modal--md{max-width:600px}.modal--lg{max-width:820px}.modal__header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem var(--space-6);border-bottom:1px solid var(--border)}.modal__title{font-size:.9375rem;font-weight:700;letter-spacing:-.015em}.modal__close{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--text-3);font-size:1rem;transition:background var(--ease),color var(--ease)}.modal__close:hover{background:var(--bg);color:var(--text-1)}.modal__body{padding:var(--space-6);overflow-y:auto;flex:1}.table th,.table td{padding:.625rem .875rem;text-align:left;border-bottom:1px solid var(--border);font-size:.875rem}.table th{font-size:.7rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.065em;background:var(--surface-2);padding-top:.5rem;padding-bottom:.5rem}.table tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--surface-2)}.table--compact th,.table--compact td{padding:.5rem .75rem}.table__link{color:var(--text-1);font-weight:600}.table__link:hover{color:var(--brand-navy);text-decoration:underline}.table__text-muted{color:var(--text-3)}.table__amount{font-weight:700;font-variant-numeric:tabular-nums}.table-card{overflow:auto}.area-assign{display:flex;flex-direction:column;gap:var(--space-4)}.area-assign__areas{display:flex;flex-direction:column;gap:var(--space-2);max-height:360px;overflow-y:auto}.area-assign__row{padding:.75rem;border-radius:var(--r-md);border:1.5px solid var(--border);transition:border-color var(--ease),background var(--ease)}.area-assign__row--selected{border-color:var(--brand-navy);background:var(--surface-2)}.area-assign__check{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:.875rem;font-weight:500}.area-assign__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.area-assign__slider-group{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.area-assign__slider{flex:1;accent-color:var(--brand-teal)}.area-assign__percent-input{width:54px;text-align:center}.area-assign__total{font-size:.875rem;font-weight:600;color:var(--text-2)}.area-assign__total--invalid{color:var(--danger)}.area-assign__total-warn{font-weight:400;font-size:.8125rem}.area-assign__actions{display:flex;gap:var(--space-2);align-items:center}.area-chips{display:flex;flex-wrap:wrap;gap:.25rem}.area-chip{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border);border-radius:var(--r-md);padding:.1875rem .5625rem;font-size:.75rem;font-weight:500}.area-chip--small{font-size:.6875rem;padding:.125rem .4375rem}.area-chips--compact{flex-wrap:nowrap;overflow:hidden}.area-row{display:flex;align-items:center;gap:var(--space-2)}.color-picker{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.color-picker__swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform var(--ease),box-shadow var(--ease)}.color-picker__swatch:hover{transform:scale(1.15)}.color-picker__swatch--selected{box-shadow:0 0 0 2px var(--surface),0 0 0 4px currentColor}.color-picker__custom{width:26px;height:26px;border:none;border-radius:50%;cursor:pointer;padding:0}.filters{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:flex-end}.filters__search{min-width:220px}.filters .field{margin:0}.filters .field__input{padding:.4375rem .75rem;font-size:.8125rem}.entry-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.entry-type-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:2rem var(--space-6);text-align:center;cursor:pointer;transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease-slow)}.entry-type-card:hover{border-color:var(--brand-teal);box-shadow:var(--shadow-md);transform:translateY(-2px)}.entry-type-card__icon{width:48px;height:48px;background:var(--brand-teal-bg);border:1px solid rgba(29,175,144,.2);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:var(--brand-teal-2)}.entry-type-card__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:.375rem}.entry-type-card__title{font-size:.9375rem;font-weight:700;color:var(--text-1);letter-spacing:-.015em}.entry-type-card__badge{font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:var(--brand-teal-bg);color:var(--brand-teal-2);border:1px solid rgba(29,175,144,.25);border-radius:999px;padding:.1rem .5rem}.entry-type-card__desc{font-size:.8125rem;color:var(--text-3);line-height:1.6;text-align:left}.upload-zone{border:2px dashed var(--border-2);border-radius:var(--r-xl);padding:3rem;text-align:center;cursor:pointer;transition:border-color var(--ease),background var(--ease)}.upload-zone:hover{border-color:var(--brand-teal);background:var(--brand-teal-bg)}.upload-zone__icon{font-size:2.5rem;margin-bottom:.875rem}.upload-zone__title{font-size:1rem;font-weight:600;margin-bottom:.375rem;color:var(--text-1)}.upload-zone__hint{color:var(--text-3);font-size:.875rem}.upload-zone__formats{font-size:.75rem;color:var(--text-3);margin-top:var(--space-2)}.upload-zone__processing{display:flex;flex-direction:column;align-items:center;gap:.875rem}.upload-alternatives{text-align:center;color:var(--text-3);font-size:.875rem}.ocr-review{max-width:700px}.ocr-review__hint{margin-bottom:1.375rem}.ocr-review__raw{margin-top:.875rem}.ocr-review__raw summary{cursor:pointer;font-size:.8125rem;color:var(--text-3);margin-bottom:.5rem}.ocr-review__raw-text{font-size:.75rem;white-space:pre-wrap;background:var(--bg);padding:.75rem;border-radius:var(--r-md);max-height:200px;overflow-y:auto;font-family:var(--font-mono)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.definition-list{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1.125rem;font-size:.875rem}.definition-list dt{font-weight:600;color:var(--text-3);white-space:nowrap;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.amount{font-size:1.125rem;font-weight:700;color:var(--text-1);font-variant-numeric:tabular-nums}.area-summary{display:flex;justify-content:space-between;align-items:center;padding:.5625rem .875rem;border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;gap:var(--space-3);background:var(--surface);transition:border-color var(--ease)}.area-summary:hover{border-color:var(--brand-navy)}.reports-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.chart-card{min-height:340px}.chart-card--wide{grid-column:1 / -1}.budget-summary{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.budget-row{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--border)}.budget-row:last-child{border-bottom:none}.budget-row--highlight{font-size:1rem}.budget-row--danger strong{color:var(--danger)}.alert{padding:.75rem var(--space-4);border-radius:var(--r-md);margin-top:.75rem;font-size:.875rem}.alert--danger{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.action-group{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:center}.action-group--compact{flex-wrap:nowrap}.spacer{flex:1}.list-summary{font-size:.8125rem;color:var(--text-3)}.link{color:var(--brand-teal-2);font-weight:500;cursor:pointer}.link:hover{text-decoration:underline}.text-muted{color:var(--text-3)}.text-sm{font-size:.8125rem}.text-warning{color:var(--open);font-size:.875rem}.spinner{width:28px;height:28px;border:2.5px solid var(--border);border-top-color:var(--brand-teal);border-radius:50%;animation:spin .65s linear infinite}.toggle-group{display:flex;gap:.25rem}.toggle-btn{padding:.3rem .7rem;border-radius:var(--r-sm);font-size:.75rem;font-weight:600;color:var(--text-3);transition:all var(--ease);border:1px solid transparent}.toggle-btn--active{background:var(--surface);color:var(--text-1);border-color:var(--border);box-shadow:var(--shadow-xs)}.toggle-btn:hover:not(.toggle-btn--active){color:var(--text-1)}.area-bar-stack{height:20px;border-radius:var(--r-sm);overflow:hidden;display:flex;background:var(--bg);margin-bottom:.875rem}.area-bar-stack--detail{height:12px}.area-bar-segment{height:100%;transition:width .3s ease}.area-legend{display:flex;flex-direction:column;gap:var(--space-2)}.area-legend__item{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem}.area-legend__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.area-legend__name{flex:1}.area-legend__value{font-weight:600}.area-empty{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-2) 0 var(--space-2)}.area-empty__hint{font-size:.8375rem;color:var(--text-3);line-height:1.6}.area-empty__suggestions{display:flex;flex-wrap:wrap;gap:var(--space-2)}.area-suggestion-chip{display:inline-flex;align-items:center;padding:.3rem .75rem;border-radius:999px;font-size:.8rem;font-weight:600;color:var(--brand-teal-2);background:var(--brand-teal-bg);border:1px solid rgba(29,175,144,.25);transition:background var(--ease),border-color var(--ease),transform var(--ease);cursor:pointer;letter-spacing:-.005em}.area-suggestion-chip:hover{background:#1daf902e;border-color:#1daf9080;transform:translateY(-1px)}.area-empty__link{font-size:.8125rem;align-self:flex-start}.recent-empty{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-2) 0}.recent-empty__headline{font-size:.9375rem;font-weight:700;color:var(--text-1);letter-spacing:-.015em}.recent-empty__desc{font-size:.8375rem;color:var(--text-3);line-height:1.6;margin-top:-.25rem}.recent-empty__actions{display:flex;flex-direction:column;gap:var(--space-2)}.recent-empty__action{display:flex;align-items:center;gap:var(--space-3);padding:.75rem var(--space-4);background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r-lg);cursor:pointer;text-align:left;transition:border-color var(--ease),background var(--ease),transform var(--ease)}.recent-empty__action:hover{border-color:var(--brand-teal);background:var(--brand-teal-bg);transform:translate(2px)}.recent-empty__action-icon{width:34px;height:34px;flex-shrink:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--text-2)}.recent-empty__action:hover .recent-empty__action-icon{background:#1daf901a;border-color:#1daf904d;color:var(--brand-teal-2)}.recent-empty__action>span:last-child{display:flex;flex-direction:column;gap:1px}.recent-empty__action strong{font-size:.875rem;font-weight:600;color:var(--text-1);display:block}.recent-empty__action span span{font-size:.775rem;color:var(--text-3)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:1rem}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);box-shadow:var(--shadow-lg);padding:2.5rem;width:100%;max-width:400px;display:flex;flex-direction:column;gap:2rem}.login-brand{display:flex;flex-direction:column;align-items:center;gap:.625rem;text-align:center}.login-brand__logo{background:var(--brand-navy);border-radius:var(--r-lg);padding:10px 14px;display:inline-flex;align-items:center;margin-bottom:.25rem}.login-brand__logo img{height:32px;width:auto;filter:brightness(0) invert(1)}.login-brand__app{font-size:1.5rem;font-weight:800;color:var(--text-1);letter-spacing:-.03em}.login-brand__sub{font-size:.8125rem;color:var(--text-3)}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form__title{font-size:1rem;font-weight:700;color:var(--text-1);letter-spacing:-.015em;margin-bottom:.25rem}.login-form__hint{font-size:.8375rem;color:var(--text-3);line-height:1.5;margin-top:-.5rem}.login-form__error{padding:.625rem .875rem;background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--r-md);font-size:.8375rem;color:var(--danger);font-weight:500}.login-form__submit{width:100%;margin-top:.25rem;justify-content:center}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.sidebar{position:fixed;left:calc(-1 * var(--sidebar-w));transition:left var(--ease-slow),box-shadow var(--ease-slow)}.sidebar--open{left:0;box-shadow:var(--shadow-overlay)}.sidebar-overlay{display:block}.mobile-bar{display:flex}.app-main{padding:1.375rem 1.25rem}.page{gap:1.25rem}}@media (max-width: 768px){.dashboard-grid,.reports-grid,.settings-grid,.detail-grid{grid-template-columns:1fr}.kpi-grid{grid-template-columns:1fr 1fr}.entry-type-grid,.form__row{grid-template-columns:1fr}.budget-status__metrics{grid-template-columns:1fr 1fr}.budget-status__metric:nth-child(3n){border-right:1px solid var(--border)}.budget-status__metric:nth-child(2n){border-right:none}.budget-status__metric:nth-last-child(-n+2){border-bottom:none}}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr}.app-main{padding:1rem}.card{padding:var(--space-4)}}
