:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.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}.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:#3b82f6;color:#fff;font-weight:600}.calendar-day.today{color:#3b82f6;font-weight:700;text-decoration:underline}.calendar-day.empty{cursor:default}.dashboard-container{display:flex;flex-direction:column;gap:1.5rem}.dashboard-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.dashboard-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(300px,1fr);gap:2rem;align-items:start}.dashboard-card{background-color:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.dashboard-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.125rem;border-bottom:1px solid #f3f4f6;padding-bottom:.75rem}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}}.month-selector{position:relative;display:flex;align-items:center;justify-content:space-between;background-color:#fff;padding:1rem 2rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.movements-list{display:flex;flex-direction:column;gap:.5rem}.movement-item{display:flex;align-items:center;padding:.75rem 1rem;border-radius:10px;background-color:#fff;border:1px solid #f3f4f6;transition:all .2s}.movement-item:hover{border-color:#e5e7eb;background-color:#f9fafb;transform:translate(4px)}.movement-date{font-size:.8rem;font-weight:600;color:#6b7280;min-width:50px;text-align:center}.movement-main{flex:1;padding-left:1rem;display:flex;flex-direction:column;gap:.2rem}.movement-desc{font-weight:600;font-size:.9375rem;color:#111827;display:flex;align-items:center;gap:.5rem}.movement-installment{font-size:.75rem;font-weight:700}.movement-details{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#6b7280}.movement-category-tag{font-size:.625rem;padding:.1rem .5rem;border-radius:100px;color:#fff;text-transform:uppercase;font-weight:700;letter-spacing:.025em}.movement-user{font-weight:500}.movement-split{color:#9ca3af;font-style:italic}.movement-amount-actions{display:flex;align-items:center;gap:1.5rem}.movement-amount{font-weight:700;font-size:1rem;color:#111827;min-width:80px;text-align:right}.movement-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .2s}.movement-item:hover .movement-actions{opacity:1}.movement-actions button{background:none;border:none;cursor:pointer;padding:.4rem;border-radius:6px;color:#9ca3af;display:flex;align-items:center;justify-content:center;transition:all .2s}.movement-actions button:hover{background-color:#f3f4f6;color:#4b5563}.movement-actions button:first-child:hover{color:#3b82f6}.movement-actions button:last-child:hover{color:#ef4444}.settlement-item{background-color:#f0fdf4;border-color:#bcf0da}.settlement-item:hover{background-color:#ecfdf5;border-color:#86efac}.balances-column{display:flex;flex-direction:column;gap:1.5rem}:root{--primary: #3b82f6;--primary-hover: #2563eb;--bg: #f3f4f6;--card: #ffffff;--text-main: #111827;--text-muted: #6b7280;--border: #e5e7eb;--sidebar-width: 260px;--header-height: 64px}*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,sans-serif;background-color:var(--bg);color:var(--text-main)}.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;transition:transform .3s ease}.logo{padding:1.5rem;font-size:1.5rem;font-weight:800;color:var(--primary);border-bottom:1px solid var(--border)}.workspace-selector-container{padding:1rem}.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}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;text-decoration:none;color:var(--text-muted);border-radius:8px;font-weight:500;transition:all .2s}.nav-link:hover,.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)}.main-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-width:0}.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}.main-header h1{font-size:1.25rem;margin:0}.user-greeting{font-weight:600;color:var(--text-muted)}.content-area{padding:2rem;max-width:1600px;width:100%;margin:0 auto}select,input{font-size:16px!important;color:var(--text-main);background-color:var(--card)}@media(max-width:768px){.workspace-select,.nav-link span{font-size:.9rem}}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-wrapper{margin-left:0}.hamburger{display:block}.main-header{padding:0 1rem}.content-area{padding:1rem}.overlay{position:fixed;inset:0;background:#0006;z-index:95}}
