:root{--color-primary: #21304e;--color-primary-hover: #18243a;--color-primary-light: rgba(33, 48, 78, .1);--color-secondary: #5b86a6;--color-accent: #ef6a4d;--color-accent-light: rgba(239, 106, 77, .14);--color-success: #3f8f6e;--color-success-light: rgba(63, 143, 110, .13);--color-danger: #c0473b;--color-danger-hover: #a63a30;--color-danger-light: rgba(192, 71, 59, .1);--color-warning: #c98a36;--color-warning-light: rgba(201, 138, 54, .13);--color-text: #1b2438;--color-text-muted: #6b7589;--color-text-light: #9aa1b0;--color-bg: #f4f2ec;--color-bg-raised: #faf8f3;--color-surface: #ffffff;--color-surface-hover: #eeece4;--color-border: #e3ded4;--color-text-on-bright: #f6f4ee;--font-family: "Schibsted Grotesk", system-ui, -apple-system, sans-serif;--font-display: "Newsreader", Georgia, "Times New Roman", serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-16: 4rem;--radius-sm: .25rem;--radius-md: .4rem;--radius-xl: .625rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(27, 36, 56, .05);--shadow-card: 0 1px 3px rgba(27, 36, 56, .04), 0 8px 24px rgba(27, 36, 56, .07);--shadow-card-hover: 0 2px 6px rgba(27, 36, 56, .06), 0 16px 36px rgba(27, 36, 56, .11);--shadow-md: 0 12px 40px rgba(27, 36, 56, .14);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 300;--z-modal: 400;--header-height: 4rem;--content-max-width: 1100px;--focus-ring-color: rgba(33, 48, 78, .3);--focus-ring-width: 3px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);font-size:var(--text-base);font-weight:var(--font-normal);line-height:1.6;color:var(--color-text);background-color:var(--color-bg);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;caret-color:transparent}h1,h2,h3,h4,h5,h6{font-weight:var(--font-bold);line-height:1.3;color:var(--color-text)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}h1,h2{font-family:var(--font-display);font-weight:var(--font-semibold);letter-spacing:-.01em}.section-header{display:flex;flex-direction:column;gap:var(--space-1)}.subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:0}.help-text{font-size:var(--text-sm);color:var(--color-text-muted)}.app-shell{display:flex;min-height:100vh;background-color:var(--color-bg)}.app-main{flex:1;min-width:0}.app-content{max-width:1600px;padding:var(--space-6) var(--space-8)}.page{display:flex;flex-direction:column;gap:var(--space-8)}.page-header{display:flex;align-items:center;justify-content:space-between}.page-title{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-3xl);letter-spacing:-.02em;color:var(--color-text);margin-bottom:var(--space-1)}.form-column{max-width:540px;margin-top:var(--space-6)}.stack{display:flex;flex-direction:column;gap:var(--space-4)}.stack-lg{display:flex;flex-direction:column;gap:var(--space-5)}.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);align-items:start}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:var(--space-5)}.split-row{display:grid;grid-template-columns:1.6fr 1fr;gap:var(--space-6);align-items:stretch}.panel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-5);align-items:stretch}.panel-grid>.panel{display:flex;flex-direction:column}.button-row{display:flex;gap:var(--space-3)}.field-inline{display:flex;gap:var(--space-2)}.field-inline>select{flex:1}.field-narrow{width:6rem}.field-grow{flex:1;min-width:0}.self-start{align-self:flex-start}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-4);text-align:center}.empty-state-title{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-2xl);letter-spacing:-.01em;color:var(--color-text);margin-bottom:var(--space-2)}.empty-state-text{font-size:var(--text-sm);color:var(--color-text-muted);max-width:340px;margin-bottom:var(--space-6)}p{margin-bottom:var(--space-4);color:var(--color-text)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}a:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color);border-radius:var(--radius-sm)}ul,ol{list-style:none}img{max-width:100%;display:block}input,select,textarea,[contenteditable=true]{caret-color:auto}input,select,textarea{font-family:var(--font-family);font-size:var(--text-base);color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);width:100%;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}input::placeholder,textarea::placeholder{color:var(--color-text-light)}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}input[type=date]::-webkit-calendar-picker-indicator{opacity:.55;cursor:pointer}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8)}textarea{resize:vertical;min-height:5rem}label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);margin-bottom:var(--space-1)}.form-group{display:flex;flex-direction:column}.label-optional{font-weight:var(--font-normal);color:var(--color-text-muted);font-size:var(--text-xs)}.form-error{font-size:var(--text-xs);color:var(--color-danger);margin-top:var(--space-1)}.form-hint{font-size:var(--text-xs);color:var(--color-warning);margin-top:var(--space-1)}.form-success{font-size:var(--text-xs);color:var(--color-success);margin-top:var(--space-1)}.password-wrapper{position:relative}.password-wrapper input{padding-right:var(--space-10)}.password-toggle{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:0;display:flex;align-items:center;transition:color var(--transition-fast)}.password-toggle:hover{color:var(--color-text)}button{font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;border:none;border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);transition:background-color var(--transition-fast),box-shadow var(--transition-fast)}button:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}button:disabled{opacity:.5;cursor:not-allowed}input:disabled,select:disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-bg-raised)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-light)}::selection{background-color:#3568592e}.field-row{display:flex;gap:var(--space-2)}@media(max-width:1000px){.split-row,.panel-grid{grid-template-columns:1fr}}@media(max-width:860px){.app-shell{flex-direction:column}.app-content{padding:var(--space-5) var(--space-4)}}@media(max-width:768px){.cols-2,.card-grid{grid-template-columns:1fr}}@media(max-width:480px){.app-content{padding:var(--space-4) var(--space-3)}.page{gap:var(--space-6)}.page-title{font-size:var(--text-2xl)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}}@media(max-width:360px){.app-content{padding:var(--space-4) var(--space-2)}}.field-row input{flex:1}.field-row select{width:auto;flex-shrink:0}.list{display:flex;flex-direction:column;gap:var(--space-1)}.list-row{display:flex;align-items:center;gap:var(--space-4)}.list-row--divided{padding:var(--space-2) 0;border-bottom:1px solid var(--color-border)}.list-row--divided:last-child{border-bottom:none}.list-row-main{flex:1;min-width:0}.list-row-main--stacked{display:flex;flex-direction:column;gap:var(--space-1)}.list-row-title{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.list-row-sub{font-size:var(--text-xs);color:var(--color-text-muted)}.list-row-amount{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);font-variant-numeric:tabular-nums;white-space:nowrap;min-width:70px;text-align:right}.list-row-amount.is-pos{color:var(--color-success)}.list-row-delete{border-radius:var(--radius-full);font-size:var(--text-lg);transition:color var(--transition-fast)}.list-row-delete:hover{color:var(--color-danger)}.list-more{margin-top:var(--space-4);padding:0;background:none;border:none;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-primary);cursor:pointer;transition:color var(--transition-fast)}.list-more:hover{color:var(--color-primary-hover)}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-base),transform var(--transition-base)}.card:hover{box-shadow:var(--shadow-card-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-weight:var(--font-semibold);text-decoration:none;cursor:pointer;transition:transform var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast)}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-block{width:100%}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-md{padding:var(--space-2) var(--space-5);font-size:var(--text-sm)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base)}.btn-primary{background-color:var(--color-primary);color:var(--color-text-on-bright)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);color:var(--color-text-on-bright)}.btn-danger{background-color:var(--color-danger);color:var(--color-text-on-bright)}.btn-danger:hover:not(:disabled){background-color:var(--color-danger-hover);color:var(--color-text-on-bright)}.btn-outline{background:none;border:1px solid var(--color-border);color:var(--color-text)}.btn-outline:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.icon-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;padding:0;cursor:pointer;color:var(--color-text-light);transition:color var(--transition-fast)}.icon-btn:hover{color:var(--color-primary)}.icon-btn-danger:hover{color:var(--color-danger)}.icon-btn-sm{width:1.5rem;height:1.5rem}.icon-btn-md{width:2rem;height:2rem}.icon-btn-lg{width:2.25rem;height:2.25rem}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full)}.badge-info{background-color:var(--color-primary-light);color:var(--color-primary)}.badge-success{background-color:var(--color-success-light);color:var(--color-success)}.badge-danger{background-color:var(--color-danger-light);color:var(--color-danger)}.badge-muted{background-color:var(--color-surface-hover);color:var(--color-text-muted)}.message{font-size:var(--text-sm);border-radius:var(--radius-md);padding:var(--space-3);text-align:center;margin-bottom:var(--space-4)}.message-error{color:var(--color-danger);background-color:var(--color-danger-light)}.message-success{color:var(--color-success);background-color:var(--color-success-light)}.modal-backdrop{position:fixed;inset:0;background-color:#00000080;z-index:var(--z-modal-backdrop);animation:modal-fade-in .2s ease}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100% - var(--space-8));max-width:420px;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);z-index:var(--z-modal);animation:modal-fade-in .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border)}.modal-title{font-size:var(--text-lg);font-weight:var(--font-semibold)}.modal-close{color:var(--color-text-muted)}.modal-close:hover{color:var(--color-text)}.modal-body{padding:var(--space-6)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-5)}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@media(max-width:380px){.modal-header,.modal-body{padding:var(--space-4)}}.auth-backdrop{position:fixed;inset:0;z-index:var(--z-modal-backdrop);background-color:#0c1220b8;backdrop-filter:blur(6px)}.auth-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:var(--z-modal);width:calc(100% - 2 * var(--space-6));max-width:860px;max-height:calc(100vh - 2 * var(--space-6));overflow:hidden;display:grid;grid-template-columns:1fr 1fr;background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.auth-close{position:absolute;top:var(--space-4);right:var(--space-4);z-index:1;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;background:none;color:var(--color-text-muted);border-radius:var(--radius-full)}.auth-close:hover{color:var(--color-text);background-color:var(--color-surface-hover)}.auth-panel{position:relative;overflow:hidden;background-color:var(--color-primary);background-image:url(/auth-panel.jpg);background-size:cover;background-position:center 72%;color:var(--color-text-on-bright)}.auth-panel-scrim{position:absolute;inset:0;background:linear-gradient(180deg,#0c122033,#0c122073 45%,#0c1220d1)}.auth-panel-content{position:relative;z-index:1;height:100%;padding:var(--space-8);display:flex;flex-direction:column;justify-content:space-between;gap:var(--space-8)}.auth-brand{display:flex;align-items:center;gap:var(--space-2)}.auth-brand-logo{height:2rem;width:auto}.auth-panel-title{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-3xl);line-height:1.1;color:var(--color-text-on-bright);margin-bottom:var(--space-3)}.auth-panel-text{color:#f6f4eee0;line-height:1.6;margin:0;max-width:22rem}.auth-form-side{padding:var(--space-8);display:flex;flex-direction:column;justify-content:center;overflow-y:auto}.auth-form-inner{width:100%}.auth-form-title{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-2xl);color:var(--color-text);margin-bottom:var(--space-1)}.auth-form-sub{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-5)}.auth-google{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);transition:background-color var(--transition-fast),border-color var(--transition-fast)}.auth-google:hover{background-color:var(--color-surface-hover);border-color:var(--color-text-light)}.auth-google-icon{flex-shrink:0}.auth-divider{display:flex;align-items:center;gap:var(--space-3);margin:var(--space-5) 0;font-size:var(--text-xs);color:var(--color-text-light)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-form .btn{width:100%;justify-content:center;margin-top:var(--space-2)}.auth-forgot{align-self:flex-end;margin-top:calc(-1 * var(--space-2));padding:0;background:none;font-size:var(--text-xs);color:var(--color-text-muted);transition:color var(--transition-fast)}.auth-forgot:hover{color:var(--color-primary)}.auth-back{align-self:flex-start;margin-bottom:var(--space-4);padding:0;background:none;font-size:var(--text-sm);color:var(--color-text-muted);transition:color var(--transition-fast)}.auth-back:hover{color:var(--color-primary)}.auth-terms{margin-top:var(--space-4);margin-bottom:0;font-size:var(--text-xs);line-height:1.5;color:var(--color-text-light)}.auth-terms a{color:var(--color-text-muted);text-decoration:underline}.auth-terms a:hover{color:var(--color-primary)}.auth-switch{margin-top:var(--space-5);margin-bottom:0;text-align:center;font-size:var(--text-sm);color:var(--color-text-muted)}.auth-switch-btn{padding:0;background:none;color:var(--color-primary);font-weight:var(--font-semibold)}.auth-switch-btn:hover{color:var(--color-primary-hover)}@media(max-width:720px){.auth-modal{grid-template-columns:1fr;max-width:440px}.auth-panel{display:none}}.slideover-backdrop{position:fixed;inset:0;background-color:#00000080;z-index:var(--z-modal-backdrop);opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.slideover-backdrop.is-open{opacity:1;pointer-events:auto}.slideover{position:fixed;top:0;right:0;bottom:0;width:360px;background-color:var(--color-surface);border-left:1px solid var(--color-border);z-index:var(--z-modal);display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--transition-slow)}.slideover.is-open{transform:translate(0)}.slideover-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border)}.slideover-title{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text)}.slideover-close{color:var(--color-text-muted);font-size:var(--text-xl);border-radius:var(--radius-md);transition:color var(--transition-fast),background-color var(--transition-fast)}.slideover-close:hover{color:var(--color-text);background-color:var(--color-surface-hover)}.slideover-form{display:flex;flex-direction:column;gap:var(--space-5);padding:var(--space-6);overflow-y:auto;flex:1}@media(max-width:768px){.slideover{width:100%}}.spinner-container{display:flex;align-items:center;justify-content:center;padding:var(--space-8)}.spinner{width:2rem;height:2rem;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2);z-index:var(--z-modal)}.toast{padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);animation:toast-in .3s ease,toast-out .3s ease 3.7s forwards;box-shadow:var(--shadow-md)}.toast-error{background-color:var(--color-danger-light);color:var(--color-danger);border:1px solid var(--color-danger)}.toast-success{background-color:var(--color-success-light);color:var(--color-success);border:1px solid var(--color-success)}@keyframes toast-in{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(1rem)}}.progress-track{width:100%;height:8px;background-color:var(--color-surface-hover);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background-color:var(--color-accent);border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--space-2)}.progress-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.progress-value{font-size:var(--text-xs);color:var(--color-text-muted);font-variant-numeric:tabular-nums}.sidebar{position:sticky;top:0;align-self:flex-start;height:100vh;width:260px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-4) var(--space-5) var(--space-6);background-color:var(--color-primary);color:var(--color-text-on-bright)}.sidebar-brand{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3)}.sidebar-logo{height:3.5rem;width:auto}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-3);background:none;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);text-align:left;color:#f6f4ee9e;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.sidebar-link:hover{background-color:#f6f4ee12;color:var(--color-text-on-bright)}.sidebar-link.is-active{background-color:#f6f4ee21;color:var(--color-text-on-bright)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-3);padding-top:var(--space-4);border-top:1px solid rgba(246,244,238,.12)}.sidebar-avatar{display:flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;flex-shrink:0;border-radius:var(--radius-full);background-color:var(--color-accent);color:var(--color-text-on-bright);font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-base)}.sidebar-user-info{display:flex;flex-direction:column;min-width:0}.sidebar-user-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-on-bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-mail{font-size:var(--text-xs);color:#f6f4ee80;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-topbar{display:none}@media(max-width:860px){.sidebar-topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--color-primary);color:var(--color-text-on-bright);position:sticky;top:0;z-index:var(--z-sticky)}.sidebar-topbar .sidebar-logo{height:1.5rem}.sidebar-burger{display:flex;align-items:center;justify-content:center;padding:var(--space-1);background:none;color:var(--color-text-on-bright)}.sidebar{position:fixed;top:0;left:0;bottom:0;height:100%;z-index:var(--z-modal);transform:translate(-100%);transition:transform var(--transition-slow)}.sidebar.is-open{transform:translate(0)}.sidebar-backdrop{position:fixed;inset:0;z-index:var(--z-modal-backdrop);background-color:#0c122080;opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.sidebar-backdrop.is-open{opacity:1;pointer-events:auto}}.ledger-page{display:flex;flex-direction:column;gap:var(--space-8)}.panel{background-color:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-5) var(--space-6)}.panel-lg{padding:var(--space-8)}.panel-title{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-xl);letter-spacing:-.01em;color:var(--color-text)}.panel-intro{margin-bottom:var(--space-6)}.panel-intro .subtitle{margin-top:var(--space-2)}.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.panel-empty{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;min-height:5rem;padding:var(--space-5) 0;font-size:var(--text-sm);color:var(--color-text-muted)}.stat-strip{display:grid;grid-template-columns:repeat(3,1fr);background-color:var(--color-surface);border-radius:var(--radius-xl);overflow:hidden}.stat-cell{padding:var(--space-5) var(--space-6);border-right:1px solid var(--color-border)}.stat-cell:last-child{border-right:none}.stat-cell-label{font-size:var(--text-sm);color:var(--color-text-muted)}.stat-cell-value{display:block;margin-top:var(--space-1);font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-2xl);color:var(--color-text)}.stat-cell-value.is-accent{color:var(--color-accent)}.group{display:flex;flex-direction:column;gap:var(--space-2)}.group-label{font-size:var(--text-sm);font-weight:var(--font-semibold);letter-spacing:.02em;color:var(--color-text)}.group-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin:0 calc(-1 * var(--space-6));padding:var(--space-2) var(--space-6);background-color:var(--color-primary-light)}.group-head .group-label{font-weight:var(--font-semibold);color:var(--color-text)}.groups>.group:first-child .group-head{margin-top:calc(-1 * var(--space-5))}.group-total{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);font-variant-numeric:tabular-nums}.groups{display:flex;flex-direction:column;overflow:hidden}.panel .group+.group{margin-top:var(--space-5)}.year-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;background:none;border:none;cursor:pointer;color:var(--color-text)}.year-toggle-label{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-lg)}.year-toggle-chevron{color:var(--color-text-muted);transition:transform var(--transition-fast)}.year-toggle-chevron.is-open{transform:rotate(180deg)}.year-section+.year-section{margin-top:var(--space-6)}.year-toggle+.group{margin-top:var(--space-4)}.ledger{display:flex;flex-direction:column}.ledger-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.ledger-row:last-child{border-bottom:none}.ledger-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.ledger-name{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text)}.ledger-icon{color:var(--color-text-light);flex-shrink:0}.ledger-sub{font-size:var(--text-sm);color:var(--color-text-light)}.ledger-amount{font-weight:var(--font-semibold);color:var(--color-text);font-variant-numeric:tabular-nums;white-space:nowrap}.ledger-actions{display:flex;gap:var(--space-1)}.ledger-row.is-paused .ledger-name{color:var(--color-text-light)}.ledger-row.is-paused .ledger-amount{color:var(--color-text-light);text-decoration:line-through}.recurring{padding:var(--space-5) var(--space-6);background-color:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-xl)}.recurring-head{display:flex;align-items:center;gap:var(--space-3)}.recurring-badge{display:flex;align-items:center;justify-content:center;width:1.85rem;height:1.85rem;flex-shrink:0;border-radius:var(--radius-full);background-color:var(--color-accent-light);color:var(--color-accent)}.recurring-title{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-lg);color:var(--color-text)}.recurring-hint{margin-top:var(--space-2);margin-bottom:var(--space-3);font-size:var(--text-sm);color:var(--color-text-muted)}.recurring .ledger-row{padding:var(--space-3) 0}.recurring .ledger-row:first-child{padding-top:var(--space-2)}@media(max-width:700px){.stat-strip{grid-template-columns:1fr}.stat-cell{border-right:none;border-bottom:1px solid var(--color-border)}.stat-cell:last-child{border-bottom:none}}@media(max-width:480px){.stat-cell{padding:var(--space-4) var(--space-5)}.recurring{padding:var(--space-5)}}.tabs{display:flex;gap:var(--space-1);border-bottom:1px solid var(--color-border)}.tabs button{padding:var(--space-3) var(--space-4);background:none;border:none;border-radius:0;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.tabs button:hover{color:var(--color-text)}.tabs button.is-active{color:var(--color-text);border-bottom-color:var(--color-accent)}@media(max-width:380px){.tabs button{padding:var(--space-3) var(--space-2)}}.goal-card{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-6);background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:0 4px 18px #1b24380f;transition:box-shadow var(--transition-base),transform var(--transition-base)}.goal-card:hover{box-shadow:0 8px 28px #1b243817}.goal-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.goal-card-name{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-lg);letter-spacing:-.01em;margin-bottom:0}.goal-card-amount{display:flex;align-items:baseline;flex-wrap:wrap;gap:var(--space-2)}.goal-card-saved{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-2xl);letter-spacing:-.01em;color:var(--color-text)}.goal-card-target{font-size:var(--text-sm);color:var(--color-text-muted)}.goal-card .progress-track{height:10px}.goal-card-meta{font-size:var(--text-sm);color:var(--color-text-light);margin-bottom:0}.goal-card-actions{display:flex;align-items:center;gap:var(--space-3);margin-top:auto;padding-top:var(--space-2)}.goal-card-deposit{display:flex;align-items:stretch;gap:var(--space-2);width:100%}.goal-card-icons{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}@media(max-width:480px){.goal-card{padding:var(--space-5)}.goal-card-deposit{flex-wrap:wrap}.goal-card-deposit .field-grow{flex-basis:100%}}.metric-card{display:flex;flex-direction:column;justify-content:center;gap:var(--space-5);padding:var(--space-6);border-radius:var(--radius-xl);background-color:var(--color-primary);color:var(--color-text-on-bright);box-shadow:var(--shadow-card)}.metric-card-top{display:flex;flex-direction:column;align-items:flex-start}.metric-card-label{font-size:var(--text-base);color:#f6f4eeb3}.metric-card-amount{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:clamp(2.6rem,4.4vw,3.7rem);line-height:1.05;letter-spacing:-.025em;margin-top:var(--space-2)}.metric-card-trend{display:inline-flex;align-items:center;gap:var(--space-1);align-self:flex-start;margin-top:var(--space-2);padding:2px var(--space-3);border-radius:var(--radius-full);background-color:#f6f4ee24;font-size:var(--text-xs);color:var(--color-text-on-bright)}.metric-card-calc{display:flex;flex-direction:column;gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid rgba(246,244,238,.14)}.metric-card-calc-row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3);font-size:var(--text-sm)}.metric-card-calc-label{color:#f6f4ee99}.metric-card-calc-val{font-weight:var(--font-medium);color:#f6f4eeeb;font-variant-numeric:tabular-nums}.metric-card-bar{height:8px;border-radius:var(--radius-full);background-color:#f6f4ee29;overflow:hidden}.metric-card-bar-fill{height:100%;border-radius:var(--radius-full);background-color:var(--color-accent)}.metric-card-foot{margin-top:var(--space-2);font-size:var(--text-xs);color:#f6f4ee99}@media(max-width:480px){.metric-card{padding:var(--space-5)}}.stat-list{display:flex;flex-direction:column;justify-content:center;padding:0 var(--space-6);background-color:var(--color-surface);border-radius:var(--radius-xl)}.stat-list-item{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4) 0;border-bottom:1px solid var(--color-border)}.stat-list-item:last-child{border-bottom:none}.stat-list-label{font-size:var(--text-sm);color:var(--color-text-muted)}.stat-list-value{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-2xl);color:var(--color-text)}.segmented{display:inline-flex;gap:2px;padding:3px;background-color:var(--color-surface-hover);border-radius:var(--radius-full)}.segmented button{padding:var(--space-1) var(--space-3);background:none;border:none;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.segmented button.is-active{background-color:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}.chart{padding:var(--space-5) 0 0;border-top:1px solid var(--color-border)}.chart-head{display:flex;align-items:center;gap:var(--space-4)}.chart-wrap{max-width:1120px;margin:0 auto;padding:var(--space-4) 0 var(--space-3)}.chart-svg{width:100%;height:160px;display:block}.chart-labels{display:flex;margin-top:var(--space-3);padding:0 2.4%}.chart-labels span{flex:1;text-align:center;font-size:var(--text-xs);color:var(--color-text-light)}.chart-grid{stroke:var(--color-border);stroke-width:1}.chart-area{fill:var(--color-primary);opacity:.07}.chart-line{fill:none;stroke-width:2;stroke-linejoin:round;stroke-linecap:round}.chart-line-inc{stroke:var(--color-primary)}.chart-line-exp{stroke:var(--color-accent)}.chart-line-dashed{stroke-dasharray:5 4;opacity:.5}.legend{display:flex;gap:var(--space-4)}.legend-item{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted)}.dot{width:9px;height:9px;border-radius:var(--radius-full)}.dot-primary{background-color:var(--color-primary)}.dot-accent{background-color:var(--color-accent)}@media(max-width:600px){.chart .panel-head,.chart-head{flex-wrap:wrap;gap:var(--space-2) var(--space-3)}}@media(max-width:380px){.chart-labels span{font-size:.625rem}}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-4)}.auth-card{width:100%;max-width:480px;padding:var(--space-16) var(--space-8);box-shadow:var(--shadow-md)}.auth-card:hover{border-color:var(--color-border)}.auth-card-logo{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-2)}.auth-card-logo-img{width:3rem;height:3rem}.auth-card-title{font-size:var(--text-3xl);color:var(--color-primary);margin-bottom:0}.auth-card-subtitle{text-align:center;font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-6)}@media(max-width:480px){.auth-card{padding:var(--space-6)}}.landing{--landing-max: 1320px;min-height:100vh;background-color:var(--color-bg);overflow-x:hidden}.landing-header{max-width:var(--landing-max);margin:0 auto;padding:var(--space-5) var(--space-6);display:flex;align-items:center;justify-content:space-between}.landing-logo{display:flex;align-items:center}.landing-logo-full{height:2.1rem;width:auto}.landing-nav{display:flex;align-items:center;gap:var(--space-5)}.landing-nav-login{background:none;padding:0;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);transition:color var(--transition-fast)}.landing-nav-login:hover{color:var(--color-primary)}.landing-eyebrow{display:inline-block;font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-accent);background-color:var(--color-accent-light);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full)}.landing-hero{max-width:var(--landing-max);margin:0 auto;padding:var(--space-16) var(--space-6);display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:var(--space-16);align-items:center}.landing-top{position:relative;padding-bottom:var(--space-16)}.landing-hero-chart{position:absolute;left:50%;bottom:0;transform:translate(-50%);width:116vw;height:auto;opacity:.13;z-index:0;pointer-events:none}.landing-hero-text{position:relative;z-index:1}.landing-hero-text .landing-eyebrow{margin-bottom:var(--space-5)}.landing-hero-title{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:clamp(2.5rem,4.6vw,4.25rem);line-height:1.05;letter-spacing:-.02em;color:var(--color-text);margin-bottom:var(--space-5)}.landing-hero-script{font-family:Caveat,cursive;font-weight:700;font-size:1.14em;color:var(--color-primary);position:relative;white-space:nowrap}.landing-hero-script:after{content:"";position:absolute;left:0;right:0;bottom:-.02em;height:.28em;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 16' preserveAspectRatio='none'%3E%3Cpath d='M4 11 C 70 3 130 3 180 8 S 270 13 296 6' fill='none' stroke='%23ef6a4d' stroke-width='4' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center;background-size:100% 100%}.landing-hero-lead{font-size:var(--text-lg);color:var(--color-text-muted);line-height:1.6;max-width:30rem;margin-bottom:var(--space-6)}.landing-hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-4)}.landing-hero-fineprint{font-size:var(--text-sm);color:var(--color-text-light)}.landing-hero-visual{position:relative;z-index:1}.landing-window{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;transform:rotate(.6deg)}.landing-window-bar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--color-bg-raised);border-bottom:1px solid var(--color-border)}.landing-window-dot{width:10px;height:10px;border-radius:var(--radius-full);background-color:var(--color-border)}.landing-window-name{margin-left:var(--space-2);font-size:var(--text-xs);color:var(--color-text-light)}.landing-window-shot{display:block;width:100%;height:auto}.landing-phone{position:absolute;right:-22px;bottom:-46px;width:198px;padding:10px;border-radius:44px;background:linear-gradient(150deg,#3c4453,#141a24 44%,#05080d);box-shadow:0 32px 60px #0c122061,inset 0 0 0 2px #ffffff0f;transform:rotate(3.5deg);z-index:2}.landing-phone:before{content:"";position:absolute;left:-2px;top:88px;width:3px;height:86px;border-radius:3px 0 0 3px;background-color:#2b323d}.landing-phone:after{content:"";position:absolute;right:-2px;top:104px;width:3px;height:58px;border-radius:0 3px 3px 0;background-color:#2b323d}.landing-phone-screen{position:relative;border-radius:34px;overflow:hidden;background-color:#000}.landing-phone-screen:before{content:"";position:absolute;top:9px;left:50%;transform:translate(-50%);width:52px;height:15px;border-radius:var(--radius-full);background-color:#05080d;z-index:2}.landing-phone-shot{display:block;width:100%;height:auto}.landing-steps{background-color:var(--color-primary);padding:var(--space-16) 0}.landing-steps-inner{max-width:var(--landing-max);margin:0 auto;padding:0 var(--space-6);display:grid;grid-template-columns:.8fr 1.2fr;gap:var(--space-16);align-items:center}.landing-steps-intro .landing-eyebrow{margin-bottom:var(--space-5)}.landing-steps-intro h2{color:var(--color-text-on-bright);margin-bottom:var(--space-3)}.landing-steps-intro p{font-size:var(--text-lg);color:#f6f4eec7;max-width:26rem;margin-bottom:0}.landing-steps-list{list-style:none;display:flex;flex-direction:column}.landing-step{position:relative;display:grid;grid-template-columns:auto 1fr;gap:var(--space-5);padding-bottom:var(--space-8)}.landing-step:last-child{padding-bottom:0}.landing-step:not(:last-child):before{content:"";position:absolute;left:21px;top:46px;bottom:-2px;width:2px;background-color:#ef6a4d59}.landing-step-num{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-full);border:2px solid var(--color-accent);background-color:var(--color-primary);font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--color-accent)}.landing-step-body{padding-top:var(--space-1)}.landing-step-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-on-bright);margin-bottom:var(--space-2)}.landing-step-text{color:#f6f4eeb8;line-height:1.6;margin-bottom:0;max-width:30rem}.landing-showcase{max-width:var(--landing-max);margin:0 auto;padding:var(--space-16) var(--space-6)}.landing-showcase-intro{max-width:38rem;margin:0 auto var(--space-8);text-align:center}.landing-showcase-intro .landing-eyebrow{margin-bottom:var(--space-4)}.landing-showcase-intro h2{margin-bottom:var(--space-3)}.landing-showcase-intro p{font-size:var(--text-lg);color:var(--color-text-muted);margin:0}.landing-showcase-stage{position:relative;width:100%;max-width:1040px;margin:0 auto}.landing-window-flat{transform:none}.landing-callout{position:absolute;font-family:Caveat,cursive;font-weight:600;font-size:1.5rem;color:var(--color-primary);white-space:nowrap}.landing-callout-1{top:26%;left:-96px}.landing-callout-2{bottom:18%;right:-104px}.landing-values{max-width:var(--landing-max);margin:0 auto;padding:var(--space-16) var(--space-6)}.landing-values-intro{margin-bottom:var(--space-8)}.landing-values-intro .landing-eyebrow{margin-bottom:var(--space-4)}.landing-values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8)}.landing-value{padding-top:var(--space-4);border-top:2px solid var(--color-accent)}.landing-value-title{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-xl);letter-spacing:-.01em;color:var(--color-text);margin-bottom:var(--space-2)}.landing-value-body{font-size:var(--text-base);color:var(--color-text-muted);line-height:1.6;margin-bottom:0}.landing-cta{background-color:var(--color-primary);padding:var(--space-16) 0}.landing-cta-inner{max-width:var(--landing-max);margin:0 auto;padding:0 var(--space-6);color:var(--color-text-on-bright);text-align:center}.landing-cta-title{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:clamp(1.75rem,3vw,2.5rem);color:var(--color-text-on-bright);margin-bottom:var(--space-3)}.landing-cta-text{font-size:var(--text-lg);color:#f6f4eed9;margin-bottom:var(--space-6)}.landing-cta .btn-primary{background-color:var(--color-text-on-bright);color:var(--color-primary)}.landing-cta .btn-primary:hover:not(:disabled){background-color:#fff}.landing-footer{padding-top:var(--space-8)}.landing-footer-main{max-width:var(--landing-max);margin:0 auto;padding:0 var(--space-6) var(--space-8);display:grid;grid-template-columns:1.5fr 2fr;gap:var(--space-8)}.landing-footer-tagline{margin-top:var(--space-3);font-size:var(--text-sm);color:var(--color-text-muted);max-width:18rem}.landing-footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.landing-footer-col{display:flex;flex-direction:column;gap:var(--space-2)}.landing-footer-heading{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-light);margin-bottom:var(--space-1)}.landing-footer-col a,.landing-footer-col button{background:none;padding:0;text-align:left;font-size:var(--text-sm);font-weight:var(--font-normal);color:var(--color-text-muted);transition:color var(--transition-fast)}.landing-footer-col a:hover,.landing-footer-col button:hover{color:var(--color-primary)}.landing-footer-bottom{border-top:1px solid var(--color-border)}.landing-footer-bottom-inner{max-width:var(--landing-max);margin:0 auto;padding:var(--space-5) var(--space-6) var(--space-8);display:flex;justify-content:space-between;font-size:var(--text-sm);color:var(--color-text-light)}.landing-footer-made{display:inline-flex;align-items:center;gap:var(--space-2)}.landing-flag{width:18px;height:auto;border-radius:1px}@media(max-width:1200px){.landing-callout{display:none}}@media(max-width:900px){.landing-hero{grid-template-columns:1fr;gap:var(--space-8);padding:var(--space-8) var(--space-6)}.landing-steps-inner,.landing-values-grid{grid-template-columns:1fr;gap:var(--space-8)}.landing-steps,.landing-values,.landing-showcase{padding-top:var(--space-8);padding-bottom:var(--space-8)}.landing-phone{display:none}.landing-footer-main{grid-template-columns:1fr;gap:var(--space-6)}}@media(max-width:520px){.landing-nav-login{display:none}.landing-footer-cols{grid-template-columns:repeat(2,1fr)}}
