@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Roboto:wght@300;400;500;700&display=swap";:root{--color-primary:#588157;--color-primary-hover:#6b8e5d;--color-primary-light:#a3b18a;--color-primary-dark:#3a5a40;--color-secondary:#8b6f47;--color-secondary-hover:#a9825e;--color-secondary-light:#c19875;--color-accent:#c67b5c;--color-accent-hover:#d4956c;--color-accent-light:#e0a87d;--color-success:#6b8e5d;--color-info:#7fa167;--color-warning:#c19875;--color-error:#c67b5c;--color-chart-1:#588157;--color-chart-2:#a3b18a;--color-chart-3:#8b6f47;--color-chart-4:#c67b5c;--color-chart-5:#b5bf9d;--color-chart-6:#9caf88;--color-chart-7:#a9825e;--color-chart-8:#d4956c;--color-surface-light:#f9fafb;--color-surface-dark:#1e1e1e;--color-card-bg-light:#fffc;--color-card-bg-dark:#1e1e1ecc;--color-text-primary-light:#2c3e2d;--color-text-primary-dark:#e5e7eb;--color-text-secondary-light:#6b7565;--color-text-secondary-dark:#9ca3af;--spacing-1:4px;--spacing-2:8px;--spacing-3:12px;--spacing-4:16px;--spacing-5:24px;--spacing-6:32px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #00000026;--font-sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;--font-mono:"Roboto Mono",monospace}html,body{font-family:var(--font-sans);background-color:var(--color-surface-light);color:var(--color-text-primary-light);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}.flex-center{justify-content:center;align-items:center;display:flex}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}:root,:host{--color-cream:#f7f7f2;--color-sage:#a3b18a;--color-terracotta:#bb8066;--font-sans:"Inter","Roboto",system-ui,sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--color-cream);font-family:var(--font-sans);color:#111827;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600}h1{font-size:2.25rem;line-height:2.5rem}@media(min-width:1024px){h1{font-size:3rem;line-height:1}}h2{font-size:1.875rem;line-height:2.25rem}@media(min-width:1024px){h2{font-size:2.25rem;line-height:2.5rem}}h3{font-size:1.5rem;line-height:2rem}@media(min-width:1024px){h3{font-size:1.875rem;line-height:2.25rem}}.btn-primary{background-color:var(--color-sage);color:#fff;border-radius:.5rem;padding:.625rem 1.5rem;font-weight:500;transition:background-color .2s;box-shadow:0 1px 2px #0000000d}.btn-primary:hover{background-color:#939f7c}@supports (color:color-mix(in lab,red,red)){.btn-primary:hover{background-color:color-mix(in srgb,var(--color-sage)90%,black)}}.btn-primary:hover{box-shadow:0 4px 6px -1px #0000001a}.btn-secondary{background-color:var(--color-terracotta);color:#fff;border-radius:.5rem;padding:.625rem 1.5rem;font-weight:500;transition:background-color .2s;box-shadow:0 1px 2px #0000000d}.btn-secondary:hover{background-color:#a8735c}@supports (color:color-mix(in lab,red,red)){.btn-secondary:hover{background-color:color-mix(in srgb,var(--color-terracotta)90%,black)}}.btn-secondary:hover{box-shadow:0 4px 6px -1px #0000001a}.card{background-color:#fff;border-radius:.5rem;padding:1.5rem;transition:box-shadow .2s;box-shadow:0 4px 6px -1px #0000001a}.card:hover{box-shadow:0 10px 15px -3px #0000001a}.input{border:1px solid #d1d5db;border-radius:.5rem;width:100%;padding:.5rem 1rem;transition:all .2s}.input:focus{ring:2px;ring-color:var(--color-sage);border-color:#0000;outline:none}.max-w-7xl{max-width:80rem}.mx-auto{margin-left:auto;margin-right:auto}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.space-y-6>*+*{margin-top:1.5rem}.space-y-8>*+*{margin-top:2rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mr-2{margin-right:.5rem}.h-16{height:4rem}.w-6{width:1.5rem}.h-6{height:1.5rem}.w-4{width:1rem}.h-4{height:1rem}.w-5{width:1.25rem}.h-5{height:1.25rem}.min-h-screen{min-height:100vh}.text-white{color:#fff}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-full{border-radius:9999px}.border-l-4{border-left-width:4px}.animate-fade-in{animation:.3s ease-in fadeIn}.animate-spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(min-width:640px){.sm\\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media(min-width:768px){.md\\:flex{display:flex}.md\\:hidden{display:none}.md\\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1024px){.lg\\:px-8{padding-left:2rem;padding-right:2rem}.lg\\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\\:col-span-2{grid-column:span 2/span 2}}.layout-container{min-height:100vh;background-color:var(--color-surface-light);color:var(--color-text-primary-light)}.layout-header{background-color:var(--color-surface-light);border-bottom:1px solid rgba(0,0,0,.05);position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffe6}.layout-header-content{max-width:80rem;margin:0 auto;padding:0 1rem}.layout-header-inner{display:flex;justify-content:space-between;align-items:center;height:4rem}.layout-logo{display:flex;align-items:center;gap:.75rem}.layout-logo-icon{width:40px;height:40px;border-radius:50%;background-color:var(--color-primary);display:flex;align-items:center;justify-content:center}.layout-logo-text{font-size:1.25rem;font-weight:700;color:var(--color-text-primary-light)}.layout-nav{display:none;align-items:center;gap:.25rem}@media(min-width:768px){.layout-nav{display:flex}}.layout-nav-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius-md);font-weight:500;transition:all .2s;text-decoration:none;cursor:pointer}.layout-nav-item:not(.active){color:var(--color-text-secondary-light)}.layout-nav-item.active{color:#fff;background:var(--color-primary)}.layout-nav-item:not(.active):hover{background:#0000000d;color:var(--color-text-primary-light)}.layout-mobile-toggle{display:flex;align-items:center;justify-content:center;padding:.5rem;border-radius:.375rem;color:var(--color-text-secondary-light);cursor:pointer;transition:background-color .2s}.layout-mobile-toggle:hover{background:#0000000d}@media(min-width:768px){.layout-mobile-toggle{display:none}}.layout-user-menu{display:flex;align-items:center;gap:.75rem}.layout-user-email{display:none;font-size:.875rem;color:var(--color-text-secondary-light)}@media(min-width:768px){.layout-user-email{display:block}}.layout-signout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:transparent;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-md);color:var(--color-text-secondary-light);font-weight:500;cursor:pointer;transition:all .2s}.layout-signout-btn:hover{background:#0000000d;border-color:#0003}.layout-main{max-width:80rem;margin:0 auto;padding:2rem 1rem}@media(min-width:640px){.layout-header-content{padding:0 1.5rem}}@media(min-width:1024px){.layout-header-content{padding:0 2rem}.layout-main{padding:2rem}}.layout-mobile-menu{position:fixed;top:4rem;left:0;right:0;bottom:0;background:#fff;padding:1rem;display:flex;flex-direction:column;gap:.5rem;z-index:40}@media(min-width:768px){.layout-mobile-menu{display:none!important}}.login-container{min-height:100dvh;width:100%;display:flex;align-items:center;justify-content:center;position:relative}.login-overlay{position:absolute;inset:0;background-color:#0006;z-index:0}.login-card-wrapper{position:relative;z-index:10;width:100%;max-width:28rem;padding:1rem}.login-card{background-color:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);border-radius:1.5rem;box-shadow:0 25px 50px -12px #00000040;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.login-card:hover{transform:translateY(-2px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.login-content{padding:2.5rem;display:flex;flex-direction:column;gap:2rem}.login-header{text-align:center}.login-icon{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;border-radius:9999px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;margin-bottom:1.5rem;box-shadow:0 10px 15px -3px #3b82f64d}.login-title{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:.5rem;letter-spacing:-.025em}.login-subtitle{color:#4b5563;font-size:1.125rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-welcome{text-align:center;margin-bottom:.5rem}.welcome-title{font-size:1.25rem;font-weight:600;color:#111827;margin-bottom:.25rem}.welcome-text{color:#6b7280;font-size:.875rem}.login-error{background-color:#fef2f2;border:1px solid #fecaca;color:#b91c1c;padding:.75rem;border-radius:.5rem;font-size:.875rem;text-align:center}.google-button{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1.5rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;color:#374151;font-weight:500;font-size:1rem;transition:all .2s ease;cursor:pointer;box-shadow:0 1px 2px #0000000d}.google-button:hover:not(:disabled){background-color:#f9fafb;border-color:#d1d5db;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.google-button:active:not(:disabled){transform:translateY(0)}.google-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{background-color:#f9fafb80;padding:1rem;text-align:center;border-top:1px solid rgba(229,231,235,.5)}.login-footer p{color:#6b7280;font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}@media(max-width:640px){.login-card-wrapper{padding:1rem}.login-content{padding:2rem 1.5rem}.login-title{font-size:1.5rem}}.card{background-color:var(--color-card-bg-light);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--spacing-5);transition:transform .2s ease,box-shadow .2s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}@media(prefers-color-scheme:dark){.card{background-color:var(--color-card-bg-dark);border-color:#ffffff0d}}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;line-height:1;white-space:nowrap}.badge-default{background-color:#a3b18a26;color:var(--color-primary)}.badge-success{background-color:#6b8e5d26;color:var(--color-success)}.badge-warning{background-color:#c1987526;color:var(--color-warning)}.badge-error{background-color:#c67b5c26;color:var(--color-error)}.badge-info{background-color:#7fa16726;color:var(--color-info)}.badge-secondary{background-color:#8b6f4726;color:var(--color-secondary)}.dashboard-container{animation:fadeIn .5s ease-out;display:flex;flex-direction:column;gap:2rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem}.dashboard-title{font-size:1.875rem;font-weight:700;color:var(--color-text-primary-light);margin-bottom:.5rem;line-height:1.2}.dashboard-subtitle{color:var(--color-text-secondary-light);font-size:1rem}.dashboard-filters{display:flex;gap:.5rem}.filter-btn{padding:.375rem 1rem;border-radius:var(--radius-md);font-weight:500;font-size:.875rem;transition:all .2s;border:none;cursor:pointer;background-color:var(--color-surface-hover);color:var(--color-text-secondary-light)}.filter-btn:hover{background-color:#0000000d}.filter-btn.active{background-color:var(--color-primary);color:#fff}.metrics-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:768px){.metrics-grid{grid-template-columns:repeat(3,1fr)}}.metric-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.metric-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary-light)}.metric-value{font-size:1.875rem;font-weight:700;margin-top:.25rem;color:var(--color-text-primary-light)}.metric-value.positive{color:var(--color-text-primary-light)}.metric-value.negative{color:var(--color-error)}.metric-icon-wrapper{padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.metric-icon-wrapper.primary{background-color:#3b82f61a;color:var(--color-primary)}.metric-icon-wrapper.success{background-color:#10b9811a;color:var(--color-success)}.metric-icon-wrapper.error{background-color:#ef44441a;color:var(--color-error)}.metric-footer{display:flex;align-items:center;font-size:.875rem;color:var(--color-text-secondary-light)}.metric-footer strong{font-weight:600;margin-right:.25rem}.charts-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:1024px){.charts-grid{grid-template-columns:repeat(3,1fr)}.chart-card{grid-column:span 2}}.chart-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary-light);margin-bottom:1.5rem}.chart-container{height:300px;width:100%}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.view-all-btn{font-size:.875rem;font-weight:500;color:var(--color-primary);background:none;border:none;cursor:pointer}.view-all-btn:hover{text-decoration:underline}.transactions-list{display:flex;flex-direction:column;gap:1rem}.transaction-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:var(--radius-md);transition:background-color .2s}.transaction-item:hover{background-color:#00000005}.transaction-info{display:flex;align-items:center;gap:.75rem}.transaction-icon{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.transaction-details p:first-child{font-size:.875rem;font-weight:500;color:var(--color-text-primary-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.transaction-details p:last-child{font-size:.75rem;color:var(--color-text-secondary-light)}.transaction-amount{text-align:right}.transaction-value{font-size:.875rem;font-weight:600;display:block;margin-bottom:.25rem}.transaction-value.positive{color:var(--color-success)}.transaction-value.negative{color:var(--color-text-primary-light)}.empty-state{text-align:center;padding:2rem 0;color:var(--color-text-secondary-light);font-size:.875rem}.loading-container{display:flex;align-items:center;justify-content:center;min-height:400px}.spinner{width:3rem;height:3rem;border:2px solid rgba(0,0,0,.1);border-left-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.button{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .2s ease-in-out;font-family:inherit;outline:none}.button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.button:disabled{opacity:.5;cursor:not-allowed}.button.primary{background:var(--color-primary);color:#fff}.button.primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #5881574d}.button.primary:active:not(:disabled){transform:translateY(0)}.button.secondary{background:var(--color-secondary);color:#fff;border:none}.button.secondary:hover:not(:disabled){background:var(--color-secondary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #8b6f474d}.button.ghost{background:transparent;color:var(--color-text-secondary-light);border:1px solid transparent}.button.ghost:hover:not(:disabled){background:#a3b18a1a;color:var(--color-primary)}.button.danger{background:var(--color-error);color:#fff}.button.danger:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #c67b5c4d}.expenses-container{animation:fadeIn .5s ease-out;display:flex;flex-direction:column;gap:2rem}.expenses-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.expenses-title{font-size:1.875rem;font-weight:700;color:var(--color-text-primary-light);margin-bottom:.5rem;line-height:1.2}.expenses-subtitle{color:var(--color-text-secondary-light);font-size:1rem}.summary-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:768px){.summary-grid{grid-template-columns:repeat(3,1fr)}}.summary-card-content{display:flex;justify-content:space-between;align-items:center}.summary-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary-light);margin-bottom:.25rem}.summary-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary-light)}.summary-value.positive{color:var(--color-success)}.summary-value.negative{color:var(--color-error)}.summary-icon-wrapper{padding:.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.summary-icon-wrapper.success{background-color:#10b9811a;color:var(--color-success)}.summary-icon-wrapper.error{background-color:#ef44441a;color:var(--color-error)}.summary-icon-wrapper.primary{background-color:#3b82f61a;color:var(--color-primary)}.expenses-content-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:1024px){.expenses-content-grid{grid-template-columns:repeat(3,1fr)}.chart-section{grid-column:span 1}.transactions-section{grid-column:span 2}}.section-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary-light);margin-bottom:1.5rem}.filter-bar{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.filter-select{padding:.5rem 2rem .5rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:#fff;font-size:.875rem;color:var(--color-text-primary-light);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em}.filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f61a}.table-container{overflow-x:auto}.transactions-table{width:100%;border-collapse:collapse}.transactions-table th{text-align:left;font-size:.75rem;font-weight:500;color:var(--color-text-secondary-light);text-transform:uppercase;letter-spacing:.05em;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.transactions-table td{padding:1rem 0;border-bottom:1px solid rgba(0,0,0,.05);vertical-align:middle}.transactions-table tr:last-child td{border-bottom:none}.transactions-table tr:hover td{background-color:#00000003}.cell-date{font-size:.875rem;color:var(--color-text-secondary-light)}.cell-counterparty{font-size:.875rem;font-weight:500;color:var(--color-text-primary-light)}.cell-description{font-size:.75rem;color:var(--color-text-secondary-light);max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cell-amount{font-size:.875rem;font-weight:600;text-align:right}.cell-amount.positive{color:var(--color-success)}.cell-amount.negative{color:var(--color-text-primary-light)}.empty-state{text-align:center;padding:3rem 0;color:var(--color-text-secondary-light)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.modal-container{background-color:var(--color-surface-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:scaleIn .2s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4);border-bottom:1px solid rgba(0,0,0,.05)}.modal-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary-light);margin:0}.modal-close{background:transparent;border:none;cursor:pointer;color:var(--color-text-secondary-light);padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.modal-close:hover{background-color:#0000000d}.modal-content{padding:var(--spacing-4)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@media(prefers-color-scheme:dark){.modal-container{background-color:var(--color-surface-dark);border:1px solid rgba(255,255,255,.1)}.modal-header{border-bottom-color:#ffffff1a}.modal-title{color:var(--color-text-primary-dark)}.modal-close{color:var(--color-text-secondary-dark)}.modal-close:hover{background-color:#ffffff1a}}.toast{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:12px;padding:16px;background:var(--color-surface-light);border:1px solid rgba(0,0,0,.05);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;min-width:300px;animation:slideIn .3s ease-out}.toast-success{border-left:4px solid var(--color-success)}.toast-error{border-left:4px solid var(--color-error)}.toast-info{border-left:4px solid var(--color-primary)}.toast-message{flex:1;font-size:.875rem;color:var(--color-text-primary-light)}.toast-close{background:transparent;border:none;cursor:pointer;color:var(--color-text-secondary-light);padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.toast-close:hover{background-color:#0000000d}@keyframes slideIn{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media(prefers-color-scheme:dark){.toast{background:var(--color-surface-dark);border-color:#ffffff1a}.toast-message{color:var(--color-text-primary-dark)}.toast-close{color:var(--color-text-secondary-dark)}.toast-close:hover{background-color:#ffffff1a}}.upload-container{animation:fadeIn .5s ease-out;display:flex;flex-direction:column;gap:2rem}.upload-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.upload-title{font-size:1.875rem;font-weight:700;color:var(--color-text-primary-light);margin-bottom:.5rem;line-height:1.2}.upload-subtitle{color:var(--color-text-secondary-light);font-size:1rem}.upload-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:1024px){.upload-grid{grid-template-columns:repeat(3,1fr)}.upload-section{grid-column:span 2}}.drop-zone{border:2px dashed var(--color-border);border-radius:.75rem;padding:3rem;text-align:center;transition:all .2s;cursor:pointer;background-color:#fff}.drop-zone:hover{border-color:#3b82f680;background-color:#00000003}.drop-zone.dragging{border-color:var(--color-primary);background-color:#3b82f60d;transform:scale(1.02)}.drop-zone.processing{opacity:.5;cursor:wait}.drop-zone-content{display:flex;flex-direction:column;gap:1.5rem;align-items:center}.upload-icon-wrapper{width:5rem;height:5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:#0000000d;transition:background-color .2s}.drop-zone.dragging .upload-icon-wrapper{background-color:#3b82f61a}.drop-zone-text h3{font-size:1.25rem;font-weight:600;color:var(--color-text-primary-light);margin-bottom:.5rem}.drop-zone-text p{color:var(--color-text-secondary-light)}.file-input-label{display:inline-block}.file-support-text{font-size:.75rem;color:var(--color-text-secondary-light)}.status-messages{margin-top:1.5rem;display:flex;flex-direction:column;gap:1rem}.status-card{border-radius:.5rem;padding:1rem;display:flex;align-items:flex-start;gap:.75rem}.status-card.warning{background-color:#fffbeb;border:1px solid #FCD34D}.status-card.success{background-color:#ecfdf5;border:1px solid #6EE7B7}.status-content h4{font-weight:600;margin-bottom:.5rem}.status-card.warning h4{color:#92400e}.status-card.success h4{color:#065f46}.status-list{font-size:.875rem;margin-top:.5rem;padding-left:0;list-style:none;max-height:10rem;overflow-y:auto}.status-card.warning .status-list{color:#b45309}.status-card.success .status-text{color:#047857;font-size:.875rem}.help-card{background-color:#3b82f60d;border:1px solid rgba(59,130,246,.2);height:-moz-fit-content;height:fit-content}.help-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.help-header h3{font-size:1.125rem;font-weight:600;color:var(--color-text-primary-light)}.help-content{display:flex;flex-direction:column;gap:1rem}.help-section h4{font-size:.875rem;font-weight:500;color:var(--color-text-primary-light);margin-bottom:.5rem}.help-list{font-size:.875rem;color:var(--color-text-secondary-light);padding-left:1.25rem;margin:0}.help-list li{margin-bottom:.25rem}.help-note{padding-top:1rem;border-top:1px solid rgba(59,130,246,.2)}.help-note p{font-size:.875rem;color:var(--color-text-secondary-light)}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.preview-title h3{font-size:1.25rem;font-weight:600;color:var(--color-text-primary-light)}.preview-title p{font-size:.875rem;color:var(--color-text-secondary-light);margin-top:.25rem}.preview-table{width:100%;border-collapse:collapse}.preview-table th{text-align:left;font-size:.75rem;font-weight:500;color:var(--color-text-secondary-light);text-transform:uppercase;letter-spacing:.05em;padding:.75rem 1rem;border-bottom:1px solid var(--color-border)}.preview-table td{padding:1rem;border-bottom:1px solid rgba(0,0,0,.05);vertical-align:middle}.preview-table tr:hover td{background-color:#00000003}.cell-amount{font-weight:600;text-align:right;white-space:nowrap}.projections-container{padding:2rem;max-width:1400px;margin:0 auto}.projections-header{margin-bottom:2rem}.projections-grid{display:grid;grid-template-columns:350px 1fr;gap:2rem;align-items:start}@media(max-width:1024px){.projections-grid{grid-template-columns:1fr}}.controls-card{padding:1.5rem;background:#fff;height:-moz-fit-content;height:fit-content}.control-group{margin-bottom:1.5rem}.control-group label{display:flex;justify-content:space-between;align-items:center;font-weight:500;color:#374151;margin-bottom:.5rem}.value-badge{background:#f3f4f6;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;color:#111827;font-weight:600}.control-group input[type=range]{width:100%;height:6px;background:#e5e7eb;border-radius:3px;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--color-primary);border-radius:50%;cursor:pointer;-webkit-transition:transform .1s;transition:transform .1s}.control-group input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}.help-text{font-size:.75rem;color:#6b7280;margin-top:.5rem}.results-column{display:flex;flex-direction:column;gap:1.5rem}.metrics-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}@media(max-width:640px){.metrics-row{grid-template-columns:1fr}}.metric-card{padding:1.5rem;text-align:center}.metric-label{font-size:.875rem;color:#6b7280;margin-bottom:.5rem;font-weight:500}.metric-value{font-size:2rem;font-weight:700;margin-bottom:.25rem}.metric-sub{font-size:.75rem;color:#9ca3af}.chart-card-projections{padding:1.5rem;min-height:400px}
