:root{color-scheme:light}#root{width:100%}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f3f4f6;padding:1rem}.auth-card{background-color:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;width:100%;max-width:400px}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:2rem;color:#111827;margin-bottom:.5rem;font-weight:700}.auth-header p{color:#6b7280;font-size:.875rem}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:#374151}.form-group input{padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;outline:none;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.auth-button{background-color:#3b82f6;color:#fff;border:none;padding:.75rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:.5rem}.auth-button:hover{background-color:#2563eb}.auth-button:disabled{background-color:#9ca3af;cursor:not-allowed}.auth-error{background-color:#fee2e2;color:#dc2626;padding:.75rem;border-radius:8px;font-size:.875rem;margin-bottom:1rem;text-align:center}.auth-footer{text-align:center;margin-top:1.5rem;font-size:.875rem;color:#6b7280}.auth-link{color:#3b82f6;text-decoration:none;font-weight:500;margin-left:.25rem}.auth-link:hover{text-decoration:underline}.dashboard-container{display:flex;flex-direction:column;gap:1.5rem}.dashboard-grid{display:grid;grid-template-columns:minmax(300px,3fr) minmax(320px,1fr);gap:1.5rem;align-items:start}.dashboard-card{background-color:var(--card);padding:1.25rem;border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.dashboard-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:1rem;font-weight:700;color:var(--text-main);border-bottom:1px solid var(--border);padding-bottom:.75rem}.month-selector{display:flex;align-items:center;justify-content:center;gap:1.5rem;background-color:var(--card);padding:.75rem 1.5rem;border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-sm);position:relative}.movements-list{display:flex;flex-direction:column}.movement-item{display:flex;align-items:center;padding:.6rem 1rem;border-bottom:1px solid var(--border);transition:all .2s;background-color:var(--card)}.movement-item:last-child{border-bottom:none}.movement-item:hover{background-color:#f8fafc}.movement-date{font-size:.75rem;font-weight:700;color:var(--text-muted);min-width:45px;text-align:left}.movement-main{flex:1;padding-left:.75rem;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:1rem}.movement-desc{font-weight:600;font-size:.9rem;color:var(--text-main);flex:1;word-break:break-word;max-width:450px;line-height:1.3}.movement-details{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.movement-category-tag{font-size:.65rem;padding:.15rem .5rem;border-radius:4px;color:#fff;font-weight:700}.movement-user{font-size:.75rem;font-weight:600;color:var(--text-muted);min-width:80px}.movement-amount-actions{display:flex;align-items:center;gap:1rem;padding-left:1rem}.movement-amount{font-weight:700;font-size:.95rem;color:var(--text-main);min-width:90px;text-align:right;font-variant-numeric:tabular-nums}.movement-actions{display:flex;gap:.1rem}.movement-actions button{background:none;border:none;cursor:pointer;padding:.4rem;border-radius:6px;color:#cbd5e1;transition:all .2s}.movement-actions button:hover{background-color:#f1f5f9}.movement-actions button.edit:hover{color:var(--primary)}.movement-actions button.delete:hover{color:var(--danger)}.settlement-item{background-color:#f0fdf4}@media(max-width:1200px){.dashboard-grid{grid-template-columns:1fr}.movement-main{flex-direction:column;align-items:flex-start;gap:.2rem}.movement-user{min-width:auto}}.calendar-container{border:1px solid #e5e7eb;border-radius:12px;padding:1rem;background:#fff;width:100%;max-width:320px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-month-name{font-weight:600;font-size:.95rem;color:#111827;text-transform:capitalize}.calendar-nav-btn{background:none;border:none;padding:.4rem;border-radius:6px;cursor:pointer;color:#6b7280;display:flex;align-items:center;transition:background-color .2s}.calendar-nav-btn:hover{background-color:#f3f4f6;color:#111827}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-weekday{text-align:center;font-size:.75rem;font-weight:600;color:#9ca3af;padding-bottom:.5rem}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.875rem;border-radius:8px;cursor:pointer;transition:all .2s;color:#374151}.calendar-day:hover:not(.empty):not(.selected){background-color:#eff6ff;color:#3b82f6}.calendar-day.selected{background-color:var(--primary);color:#fff!important;font-weight:700}.calendar-day.today{color:#3b82f6;font-weight:700;text-decoration:underline}.calendar-day.empty{cursor:default}:root{--primary: #3b82f6;--primary-hover: #2563eb;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg: #f8fafc;--card: #ffffff;--text-main: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--sidebar-width: 260px;--sidebar-collapsed-width: 70px;--header-height: 64px;--max-content-width: 1600px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--transition-base: .3s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased}.app-container{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:100;box-shadow:var(--shadow-sm);transition:width var(--transition-base),transform var(--transition-base);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.logo{padding:1.5rem;font-size:1.5rem;font-weight:800;color:var(--primary);border-bottom:1px solid var(--border);letter-spacing:-.025em;white-space:nowrap}.sidebar.collapsed .logo{padding:1.5rem 0;text-align:center}.workspace-selector-container{padding:1rem}.sidebar.collapsed .workspace-selector-container{padding:1rem .5rem}.workspace-select{width:100%;padding:.6rem;border-radius:8px;border:1px solid var(--border);background-color:#f9fafb;font-size:.9rem;cursor:pointer}.nav-links{padding:1rem;display:flex;flex-direction:column;gap:.25rem;flex:1}.sidebar.collapsed .nav-links{padding:1rem .5rem;align-items:center}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;text-decoration:none;color:var(--text-muted);border-radius:8px;font-weight:600;font-size:.9375rem;transition:all .2s;white-space:nowrap}.sidebar.collapsed .nav-link{padding:.75rem;justify-content:center;width:100%}.nav-link:hover{background:#f1f5f9;color:var(--text-main)}.nav-link.active{background:#eff6ff;color:var(--primary)}.logout-btn{margin:1rem;padding:.75rem;border:1px solid var(--border);background:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-weight:600;transition:all .2s}.sidebar.collapsed .logout-btn{margin:1rem .5rem;padding:.75rem;justify-content:center}.main-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-width:0;transition:margin-left var(--transition-base)}.app-container.sidebar-collapsed .main-wrapper{margin-left:var(--sidebar-collapsed-width)}.main-header{height:var(--header-height);background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;position:sticky;top:0;z-index:90}.hamburger{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;padding:.5rem;border-radius:8px;transition:background .2s}.hamburger:hover{background:#f1f5f9;color:var(--text-main)}.content-area{padding:2rem;max-width:var(--max-content-width);width:100%;margin:0 auto}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-wrapper{margin-left:0!important}.content-area{padding:1rem}.overlay{position:fixed;inset:0;background:#0006;z-index:95}}
