@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.dashboard-container{gap:var(--space-6);flex-direction:column;max-width:1400px;margin:0 auto;display:flex}.dashboard-header-bar{justify-content:space-between;align-items:flex-end;gap:var(--space-4);display:flex}.dashboard-header{gap:var(--space-1);flex-direction:column;display:flex}.dashboard-filters{align-items:center;gap:var(--space-3);border-radius:var(--radius-full);padding:8px 16px;display:flex}.dashboard-filters select{appearance:none;color:var(--color-text-primary);cursor:pointer;background-color:#0000;border:none;outline:none;font-size:14px;font-weight:500}.dashboard-title{color:var(--color-text-primary);letter-spacing:-.04em;margin:0;font-size:38px}.dashboard-subtitle{color:var(--color-text-secondary);font-size:16px;font-weight:500}.kpi-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));display:grid}.kpi-card{padding:var(--space-5);border-radius:var(--radius-lg);gap:var(--space-3);background:linear-gradient(135deg,#ffffffb3 0%,#ffffff4d 100%);flex-direction:column;display:flex}.kpi-icon-wrapper{color:var(--color-accent);border-radius:var(--radius-full);width:54px;height:54px;margin-bottom:var(--space-2);background:#0071e31a;justify-content:center;align-items:center;display:flex}.kpi-icon-wrapper.destructive{color:#ff3b30;background:#ff3b301a}.kpi-value{font-family:var(--font-display);letter-spacing:-.03em;color:var(--color-text-primary);font-size:42px;font-weight:700}.kpi-label{color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.1em;font-size:12px;font-weight:600}.charts-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(500px,1fr));display:grid}.chart-card{padding:var(--space-5);border-radius:var(--radius-lg);flex-direction:column;display:flex}.chart-header{flex-direction:column;display:flex}.chart-header h2{margin:0;font-size:20px}.chart-subtitle{color:var(--color-text-secondary);margin-top:4px;font-size:14px}.budget-health{padding:var(--space-6);border-radius:var(--radius-lg);gap:var(--space-4);flex-direction:column;display:flex}.budget-health h2{font-size:24px}.progress-bar-container{border-radius:var(--radius-full);background-color:#0000000d;width:100%;height:16px;overflow:hidden;box-shadow:inset 0 1px 3px #0000001a}.progress-bar-fill{background-color:var(--color-accent);border-radius:var(--radius-full);height:100%;transition:width 1s}.progress-bar-fill.danger{background-color:#ff3b30}.progress-labels{font-family:var(--font-mono);color:var(--color-text-secondary);justify-content:space-between;font-size:14px;font-weight:500;display:flex}.text-danger{color:#ff3b30;font-weight:600}.settings-container{gap:var(--space-6);max-width:900px;padding-bottom:var(--space-8);flex-direction:column;margin:0 auto;display:flex}.settings-header{gap:var(--space-1);flex-direction:column;display:flex}.settings-title{color:var(--color-text-primary);letter-spacing:-.04em;margin:0;font-size:38px}.settings-subtitle{color:var(--color-text-secondary);font-size:16px;font-weight:500}.settings-sections{gap:var(--space-6);flex-direction:column;display:flex}.settings-card{padding:var(--space-5);border-radius:var(--radius-lg);gap:var(--space-4);background:linear-gradient(135deg,#ffffffb3 0%,#ffffff4d 100%);flex-direction:column;display:flex}.card-header{align-items:center;gap:var(--space-2);display:flex}.card-header h2{margin:0;font-size:22px}.section-icon{color:var(--color-accent)}.section-description{color:var(--color-text-secondary);margin-top:-8px;font-size:14px}.add-form{gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);background:#00000005;border:1px solid #0000000a;align-items:center;display:flex}.input-field{border-radius:var(--radius-sm);transition:all var(--transition-fast);background-color:#fff;border:1px solid #0000001a;outline:none;padding:10px 14px;font-size:14px}.input-field:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #0071e326}.input-field.grow{flex:1}.data-table{border-radius:var(--radius-md);background-color:#fff;border:1px solid #00000014;overflow:hidden}.table-header{color:var(--color-text-secondary);letter-spacing:.5px;background-color:#f5f5f7;border-bottom:1px solid #00000014;grid-template-columns:1fr auto;padding:12px 16px;font-size:11px;font-weight:600;display:grid}.table-header.three-col{grid-template-columns:2fr 1.5fr auto}.table-body{flex-direction:column;display:flex}.table-row{color:var(--color-text-primary);transition:background-color var(--transition-fast);border-bottom:1px solid #0000000a;grid-template-columns:1fr auto;align-items:center;padding:12px 16px;font-size:14px;display:grid}.table-row.three-col{grid-template-columns:2fr 1.5fr auto}.table-row:last-child{border-bottom:none}.table-row:hover{background-color:#f9f9fb}.pill{border-radius:var(--radius-full);color:var(--color-text-primary);background-color:#0000000d;align-items:center;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.btn-icon{color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;padding:6px;display:flex}.btn-icon:hover{color:#ff3b30;background-color:#ffeaea}.align-right{justify-self:end}.empty-row{text-align:center;color:var(--color-text-tertiary);padding:24px;font-size:14px}.events-container{gap:var(--space-6);flex-direction:column;max-width:1400px;margin:0 auto;display:flex}.events-header{justify-content:space-between;align-items:flex-end;display:flex}.header-text{gap:var(--space-1);flex-direction:column;display:flex}.events-title{color:var(--color-text-primary);letter-spacing:-.04em;margin:0;font-size:38px}.events-subtitle{color:var(--color-text-secondary);font-size:16px;font-weight:500}.events-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.event-card{padding:var(--space-5);border-radius:var(--radius-lg);gap:var(--space-4);cursor:pointer;background:linear-gradient(135deg,#ffffffb3 0%,#ffffff4d 100%);flex-direction:column;display:flex;position:relative;overflow:hidden}.event-card:before{content:"";opacity:0;height:4px;transition:opacity var(--transition-fast);background:linear-gradient(90deg,#0071e3,#42a1ff);position:absolute;top:0;left:0;right:0}.event-card:hover:before{opacity:1}.card-top{justify-content:space-between;align-items:center;display:flex}.event-card h3{color:#1d1d1f;margin:0;font-size:22px;font-weight:700}.chevron-icon{color:var(--color-text-tertiary);transition:transform var(--transition-fast), color var(--transition-fast)}.event-card:hover .chevron-icon{color:var(--color-accent);transform:translate(4px)}.event-details{gap:var(--space-2);color:var(--color-text-secondary);flex-direction:column;font-size:14px;display:flex}.budget-comparison{padding-top:var(--space-3);gap:var(--space-2);flex-direction:column;margin-top:auto;display:flex}.stat-block{flex-direction:column;display:flex}.budget-value.text-muted{color:var(--color-text-secondary);font-size:18px}.modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:100;background:#0003;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{width:100%;max-width:440px;padding:var(--space-6);gap:var(--space-4);flex-direction:column;display:flex;background-color:#fff!important}.modal-form{gap:var(--space-3);flex-direction:column;display:flex}.modal-form .input-field{width:100%;padding:14px 16px;font-size:16px}.modal-actions{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-4);display:flex}.btn-secondary{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;padding:12px 20px;font-size:14px;font-weight:500}.btn-secondary:hover{border-radius:var(--radius-full);background:#0000000d}.empty-state{text-align:center;padding:var(--space-8);color:var(--color-text-secondary);grid-column:1/-1;font-size:18px}.entry-container{gap:var(--space-6);flex-direction:column;max-width:1000px;display:flex}.entry-header{gap:var(--space-1);flex-direction:column;display:flex}.entry-title{color:var(--color-text-primary);margin:0;font-size:32px}.entry-subtitle{color:var(--color-text-secondary);font-size:16px}.entry-controls{padding:var(--space-4);border-radius:var(--radius-lg);flex-direction:column;display:flex}.form-label{gap:var(--space-2);flex-direction:column;font-size:14px;font-weight:500;display:flex}.event-summary{padding:var(--space-5);border-radius:var(--radius-lg);animation:fadeIn var(--transition-smooth) forwards;background:linear-gradient(135deg,#ffffffb3 0%,#ffffff4d 100%)}.budget-comparison{gap:var(--space-4);flex-direction:column;display:flex}.budget-stats{justify-content:space-between;align-items:flex-end;display:flex}.stat-block{gap:var(--space-1);flex-direction:column;display:flex}.stat-block.right-align{align-items:flex-end}.budget-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);font-size:12px;font-weight:600}.budget-value{font-family:var(--font-display);color:var(--color-text-primary);letter-spacing:-.02em;font-size:32px;font-weight:700}.budget-value.text-muted{color:var(--color-text-secondary);font-size:20px;font-weight:600}.text-danger{color:#ff3b30}.event-progress-bg{border-radius:var(--radius-full);background-color:#0000000f;width:100%;height:8px;overflow:hidden}.event-progress-fill{background-color:var(--color-accent);border-radius:var(--radius-full);height:100%;transition:width 1.2s}.event-progress-fill.danger{background-color:#ff3b30}.ledger-section{padding:var(--space-5);border-radius:var(--radius-lg);gap:var(--space-4);animation:fadeIn var(--transition-smooth) forwards;flex-direction:column;display:flex}.expense-form{gap:var(--space-3);flex-wrap:wrap;align-items:center;display:flex}.expense-form .input-field{width:auto;min-width:150px}.expense-form .input-field.grow{flex:1}@media (width<=768px){.expense-form{flex-direction:column;align-items:stretch}}.table-container{margin-top:var(--space-4);border-radius:var(--radius-md);background-color:#fff;border:1px solid #00000014;overflow-x:auto}.transactions-table{border-collapse:collapse;text-align:left;width:100%}.transactions-table th,.transactions-table td{border-bottom:1px solid #0000000a;padding:12px 16px}.transactions-table th{color:var(--color-text-secondary);letter-spacing:.5px;background-color:#f5f5f7;font-size:11px;font-weight:600}.transactions-table tr{transition:background-color var(--transition-fast)}.transactions-table tr:hover{background-color:#f9f9fb}.transactions-table td{color:var(--color-text-primary);font-size:14px}.transactions-table td.amount{font-weight:600;font-family:var(--font-mono)}.pill.cost-type{color:var(--color-accent);border-radius:var(--radius-full);background-color:#0071e31a;align-items:center;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.btn-icon.danger{color:#ff3b30;opacity:.7}.btn-icon.danger:hover{opacity:1;background-color:#ff3b301a}.event-management-actions{padding-bottom:var(--space-3);margin-bottom:var(--space-2);border-bottom:1px solid #0000000d;justify-content:space-between;align-items:center;display:flex}.event-management-actions h3{margin:0;font-size:18px;font-weight:600}.danger-text{align-items:center;gap:6px;display:flex;color:#ff3b30!important;padding:6px 12px!important}.danger-text:hover{background-color:#ffeaea!important}.budget-edit-group{align-items:center;gap:8px;display:flex}.btn-icon.muted{color:var(--color-text-tertiary);opacity:0;transform:translateY(2px)}.stat-block.right-align:hover .btn-icon.muted{opacity:1;transform:translateY(0)}.edit-budget-form{border-radius:var(--radius-sm);background:#fff;border:1px solid #0071e34d;align-items:center;padding-left:10px;display:flex;box-shadow:0 0 0 3px #0071e31a}.currency-symbol{color:var(--color-text-secondary);font-weight:600}.input-field.compact{width:120px;color:var(--color-text-primary);background:0 0;border:none;outline:none;padding:4px 8px;font-size:18px;font-weight:600}.input-field.compact:focus{box-shadow:none}.text-success{color:#34c759}.btn-icon.text-success:hover{background-color:#34c7591a}.login-container{min-height:100vh;padding:var(--space-4);background:var(--color-background);justify-content:center;align-items:center;display:flex}.login-card{width:100%;max-width:400px;padding:var(--space-6) var(--space-5);border-radius:var(--radius-lg);gap:var(--space-5);background:linear-gradient(135deg,#ffffffe6 0%,#fff9 100%);flex-direction:column;display:flex;box-shadow:0 20px 40px #00000014}.login-header{text-align:center;align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.logo-stub{background:linear-gradient(135deg, var(--color-accent) 0%, #00b4d8 100%);width:48px;height:48px;margin-bottom:var(--space-2);border-radius:12px}.login-header h1{color:var(--color-text-primary);letter-spacing:-.02em;margin:0;font-size:24px}.login-header p{color:var(--color-text-secondary);margin:0;font-size:14px}.login-form{gap:var(--space-4);flex-direction:column;display:flex}.input-group{align-items:center;display:flex;position:relative}.input-icon{color:var(--color-text-tertiary);pointer-events:none;position:absolute;left:14px}.input-group input{border-radius:var(--radius-md);width:100%;transition:all var(--transition-fast);background-color:#fffc;border:1px solid #0000001a;outline:none;padding:12px 14px 12px 42px;font-size:15px}.input-group input:focus{border-color:var(--color-accent);background-color:#fff;box-shadow:0 0 0 3px #0071e326}.input-group input:focus+.input-icon{color:var(--color-accent)}.login-btn{width:100%;margin-top:var(--space-2);justify-content:center;padding:14px;font-size:16px}.login-error-toast{color:#ff3b30;border-radius:var(--radius-sm);text-align:center;background-color:#ff3b301a;border:1px solid #ff3b3033;padding:12px;font-size:13px;font-weight:500}:root{--color-bg-primary:#f0f0f5;--color-text-primary:#1d1d1f;--color-text-secondary:#86868b;--color-text-tertiary:#a1a1a6;--color-accent:#0071e3;--color-accent-hover:#0077ed;--color-surface:#ffffffa6;--color-border:#fff6;--font-system:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-display:-apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono:"SF Mono", "SF Pro", "Menlo", monospace;--space-1:4px;--space-2:8px;--space-3:16px;--space-4:24px;--space-5:32px;--space-6:48px;--space-8:64px;--radius-sm:10px;--radius-md:16px;--radius-lg:24px;--radius-full:9999px;--shadow-sm:0 4px 14px #0000000a;--shadow-md:0 10px 30px #00000014;--shadow-lg:0 20px 40px #0000001f;--transition-fast:.2s cubic-bezier(.2, 0, 0, 1);--transition-smooth:.4s cubic-bezier(.25, .1, .25, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-system);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f7;background-image:radial-gradient(circle at 15%,#e0e8f5,#0000 25%),radial-gradient(circle at 85% 30%,#f0f4ff,#0000 25%),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:auto,auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.03em;font-weight:600}a{color:var(--color-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-accent-hover)}.glass-panel{background-color:var(--color-surface);-webkit-backdrop-filter:blur(40px)saturate(180%);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-smooth), transform var(--transition-smooth)}.glass-panel:hover{box-shadow:var(--shadow-md)}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn var(--transition-smooth) forwards}.app-container{height:100vh;display:flex;overflow:hidden}.sidebar{width:260px;padding:var(--space-4) var(--space-3);z-index:10;background-color:#f5f5f7d9;border-right:1px solid #0000000d;border-radius:0;flex-direction:column;display:flex}.sidebar-header{margin-bottom:var(--space-6);padding:0 var(--space-2)}.nav-links{gap:var(--space-1);flex-direction:column;display:flex}.nav-link{align-items:center;gap:var(--space-3);padding:12px var(--space-3);border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:background-color var(--transition-fast), color var(--transition-fast);font-size:15px;font-weight:500;display:flex}.nav-link:hover{color:var(--color-text-primary);background-color:#00000008}.nav-link.active{color:var(--color-text-primary);background-color:#fff;font-weight:600;box-shadow:0 2px 10px #0000000d}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{height:72px;padding:0 var(--space-6);z-index:5;background-color:#fff6;border-bottom:1px solid #0000000d;border-radius:0;justify-content:flex-end;align-items:center;display:flex}.filters{gap:var(--space-3);display:flex}.filters select{appearance:none;border-radius:var(--radius-full);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);background-color:#fffc;border:1px solid #00000014;outline:none;padding:8px 18px;font-size:14px;font-weight:500}.filters select:hover{box-shadow:var(--shadow-md);background-color:#fff;transform:translateY(-1px)}.filters select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #0071e326}.route-content{padding:var(--space-6);flex:1;padding-left:5%;padding-right:5%;overflow-y:auto}.btn-primary{background-color:var(--color-text-primary);color:#fff;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);border:none;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:500;display:inline-flex}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-md);background-color:#000;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}
