:root{--color-bg:#f5f7fb;--color-surface:#fff;--color-border:#d9e0ea;--color-border-strong:#b5c1d1;--color-text:#152033;--color-text-soft:#5c6b82;--color-primary:#0d5fb8;--color-primary-soft:#e7f0fd;--color-success:#197a48;--color-danger:#c0392b;--color-warning:#d18d14;--shadow-card:0 12px 30px #14203314;--radius-card:18px;--radius-input:12px;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem}*{box-sizing:border-box}body{color:var(--color-text);background:radial-gradient(circle at top left, #0d5fb814, transparent 28%), linear-gradient(180deg, #f9fbff 0%, var(--color-bg) 100%);margin:0;font-family:Inter,ui-sans-serif,system-ui,sans-serif}button,input,select{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}.app-shell{grid-template-columns:260px minmax(0,1fr);min-height:100vh;display:grid}.app-shell-sidebar{padding:var(--space-6);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffb8;border-right:1px solid #15203314}.app-shell-brand{margin-bottom:var(--space-8)}.app-shell-brand-title{margin:0;font-size:1.25rem;font-weight:700}.app-shell-brand-subtitle{margin:var(--space-2) 0 0;color:var(--color-text-soft);font-size:.95rem}.app-shell-nav{gap:var(--space-2);flex-direction:column;display:flex}.app-shell-logout{margin-top:var(--space-8);width:100%}.app-shell-nav-link{color:var(--color-text-soft);border:1px solid #0000;border-radius:14px;padding:.9rem 1rem;transition:background-color .16s,border-color .16s,color .16s}.app-shell-nav-link.router-link-active{color:var(--color-primary);background:var(--color-primary-soft);border-color:#0d5fb82e;font-weight:600}.app-shell-main{padding:var(--space-6)}.page-stack{gap:var(--space-6);flex-direction:column;display:flex}.page-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.page-header h1{margin:0;font-size:2rem}.page-header p{margin:var(--space-2) 0 0;color:var(--color-text-soft)}.page-header-actions{gap:var(--space-3);align-items:center;display:flex}.card-grid{gap:var(--space-4);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.dashboard-grid{gap:var(--space-4);grid-template-columns:1.4fr 1fr;display:grid}.section-card,.kpi-card{border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-card);border:1px solid #15203314}.section-card{padding:var(--space-5)}.section-card-header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.section-card-title{margin:0;font-size:1.1rem}.section-card-subtitle{margin:var(--space-1) 0 0;color:var(--color-text-soft);font-size:.92rem}.kpi-card{padding:var(--space-5)}.kpi-card-label{margin:0 0 var(--space-3);color:var(--color-text-soft);font-size:.9rem}.kpi-card-value{margin:0;font-size:1.6rem;font-weight:700}.kpi-card-hint{margin-top:var(--space-2);color:var(--color-text-soft);font-size:.9rem}.form-grid{gap:var(--space-4);display:grid}.form-grid-columns{gap:var(--space-4);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.field-stack{gap:var(--space-2);flex-direction:column;display:flex}.field-label{color:var(--color-text-soft);font-size:.92rem}.text-input,.money-input,.select-input{border:1px solid var(--color-border);border-radius:var(--radius-input);background:#fff;width:100%;padding:.8rem .95rem}.text-input:focus,.money-input:focus,.select-input:focus{border-color:var(--color-primary);outline:2px solid #0d5fb829}.button-row{gap:var(--space-3);flex-wrap:wrap;display:flex}.button-primary,.button-secondary,.button-danger{border:1px solid #0000;border-radius:12px;padding:.8rem 1rem}.button-primary{color:#fff;background:var(--color-primary)}.button-secondary{border-color:var(--color-border);background:#fff}.button-danger{color:var(--color-danger);background:#c0392b14}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{vertical-align:top;border-bottom:1px solid #15203314;padding:.8rem}.compact-table th,.compact-table td{padding:.45rem .5rem}.compact-table th{font-size:.82rem}.compact-table td{font-size:.92rem}.compact-table .text-input,.compact-table .money-input{border-radius:10px;padding:.45rem .6rem;font-size:.92rem}.compact-table .button-row{gap:var(--space-2)}.compact-table .button-primary,.compact-table .button-secondary,.compact-table .button-danger{border-radius:10px;padding:.5rem .75rem;font-size:.88rem}.compact-table-tight .money-input{min-width:6.5rem}.data-table th{color:var(--color-text-soft);text-align:left;font-size:.9rem;font-weight:600}.month-grid{gap:var(--space-3);grid-template-columns:repeat(6,minmax(0,1fr));display:grid}.mini-card-grid,.scenario-grid{gap:var(--space-4);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.metric-strip{gap:var(--space-3);flex-direction:column;display:flex}.metric-bar{background:#edf2f8;border-radius:999px;height:14px;overflow:hidden}.metric-bar-fill{border-radius:inherit;background:linear-gradient(90deg,#0d5fb8 0%,#4e91d7 100%);height:100%}.waterfall-list,.breakdown-list{gap:var(--space-3);flex-direction:column;display:flex}.waterfall-item,.breakdown-item{gap:var(--space-3);grid-template-columns:1fr auto;align-items:center;display:grid}.waterfall-item-label,.breakdown-item-label{gap:var(--space-1);flex-direction:column;display:flex}.waterfall-item-caption,.breakdown-item-caption{color:var(--color-text-soft);font-size:.85rem}.pill{background:var(--color-primary-soft);color:var(--color-primary);border-radius:999px;align-items:center;padding:.35rem .7rem;font-size:.85rem;font-weight:600;display:inline-flex}.empty-state{padding:var(--space-5);border:1px dashed var(--color-border-strong);color:var(--color-text-soft);text-align:center;border-radius:14px}.loader-box{padding:var(--space-8);text-align:center;color:var(--color-text-soft)}.login-page{min-height:100vh;padding:var(--space-6);place-items:center;display:grid}.login-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffdb;border:1px solid #15203314;border-radius:24px;width:min(100%,28rem);padding:clamp(1.5rem,3vw,2.5rem);box-shadow:0 20px 60px #1420331f}.login-card-header{margin-bottom:var(--space-6)}.login-eyebrow{margin:0 0 var(--space-2);color:var(--color-primary);letter-spacing:.08em;text-transform:uppercase;font-size:.85rem;font-weight:700}.login-title{margin:0;font-size:clamp(1.8rem,4vw,2.35rem)}.login-subtitle{margin:var(--space-3) 0 0;color:var(--color-text-soft);line-height:1.55}.login-form{gap:var(--space-4);flex-direction:column;display:flex}.login-error{color:var(--color-danger);margin:0;font-size:.92rem}.login-button{width:100%}@media (width<=1200px){.card-grid,.scenario-grid,.mini-card-grid,.dashboard-grid,.form-grid-columns{grid-template-columns:1fr}.month-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=920px){.app-shell{grid-template-columns:1fr}.app-shell-sidebar{border-bottom:1px solid #15203314;border-right:0}}
