:root{--brand: #3A4ADF;--brand-hover: #2e3cbf;--bg: #E3E0E7;--surface: #ffffff;--text: #1f2937;--text-muted: #6b7280;--border: #d1d5db;--danger: #dc2626;--success: #16a34a;--radius: 8px}*,*:before,*:after{box-sizing:border-box;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:1rem}.auth-card{background:var(--surface);padding:2.5rem 2rem;border-radius:12px;box-shadow:0 4px 24px #00000014;width:100%;max-width:420px;display:flex;flex-direction:column;gap:.5rem}.auth-title{text-align:center;color:var(--brand);font-size:1.6rem;margin-bottom:0}.auth-subtitle{text-align:center;color:var(--text-muted);font-size:.9rem;margin-bottom:.75rem}.auth-label{font-size:.85rem;font-weight:600;margin-top:.25rem}.auth-input{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;transition:border-color .15s}.auth-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #3a4adf26}.auth-error{background:#fef2f2;color:var(--danger);border:1px solid #fecaca;border-radius:var(--radius);padding:.5rem .75rem;font-size:.85rem}.auth-btn{margin-top:.75rem;padding:.7rem;background:var(--brand);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:44px;transition:background .15s}.auth-btn:hover:not(:disabled){background:var(--brand-hover)}.auth-btn:disabled{opacity:.65;cursor:not-allowed}.auth-footer{text-align:center;font-size:.85rem;color:var(--text-muted);margin-top:.5rem}.auth-footer a{color:var(--brand);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 2rem;background:var(--surface);border-bottom:1px solid var(--border)}.app-nav{display:flex;gap:1.5rem;align-items:center}.user-badge{width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}.logout-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);padding:.35rem .75rem;font-size:.85rem;cursor:pointer;color:var(--text-muted);transition:border-color .15s,color .15s}.logout-btn:hover{border-color:var(--danger);color:var(--danger)}.user-badge{cursor:pointer;border:none;font-family:inherit}.dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0000001a;min-width:200px;z-index:100;overflow:hidden}.dropdown-user{padding:.75rem 1rem;font-weight:600;font-size:.9rem;border-bottom:1px solid var(--border)}.dropdown-item{display:block;width:100%;text-align:left;padding:.6rem 1rem;background:none;border:none;font-size:.9rem;cursor:pointer;color:var(--text)}.dropdown-item:hover{background:#f3f4f6}.dropdown-item-danger{color:var(--danger)}.dropdown-item-danger:hover{background:#fef2f2}.org-card{background:var(--surface);border-radius:12px;padding:1.25rem;box-shadow:0 1px 4px #0000000f;border:1px solid #e5e7eb;transition:box-shadow .15s}.org-card:hover{box-shadow:0 4px 16px #00000014}.card-btn{padding:.4rem 1rem;border-radius:var(--radius);font-size:.85rem;font-weight:600;cursor:pointer;border:none;background:var(--brand);color:#fff;transition:background .15s}.card-btn:hover{background:var(--brand-hover)}.card-btn-outline{background:transparent;color:var(--brand);border:1px solid var(--brand)}.card-btn-outline:hover{background:#3a4adf0f}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal-card{background:var(--surface);border-radius:12px;width:100%;max-width:420px;box-shadow:0 12px 40px #00000026;outline:none}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:1.05rem}.modal-close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text-muted);padding:.25rem}.modal-close:hover{color:var(--text)}.modal-body{padding:1.25rem}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:300}.toast{padding:.75rem 1.25rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;box-shadow:0 4px 16px #0000001f;animation:slideIn .25s ease-out}.toast-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.toast-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.widget-grid{display:flex;flex-direction:column;gap:1.25rem}.widget{background:var(--surface);border-radius:1rem;box-shadow:0 2px 12px #0000000f;overflow:hidden}.widget-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #f3f4f6}.widget-title{display:flex;align-items:center;gap:.5rem;color:var(--text)}.widget-title h3{margin:0;font-size:1rem}.widget-add{display:flex;align-items:center;gap:.3rem;padding:.35rem .85rem;border:none;border-radius:2rem;background:var(--brand);color:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.widget-add:hover{background:var(--brand-hover)}.widget-body{padding:.75rem 1.25rem 1.25rem}.widget-empty{color:var(--text-muted);font-size:.9rem;text-align:center;padding:1rem 0}.widget-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}.widget-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid #f9fafb}.widget-row:last-child{border-bottom:none}.widget-row-name{font-weight:600;font-size:.9rem}.widget-row-sub{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.1rem}.widget-row-meta{display:flex;align-items:center;gap:.4rem}.freq-badge{font-size:.7rem;background:#f3f4f6;color:var(--text-muted);padding:.1rem .4rem;border-radius:4px}.widget-highlight{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f9fafb;border-radius:.75rem;margin-bottom:.5rem}.widget-highlight-label{font-size:.8rem;color:var(--text-muted);font-weight:500}.widget-highlight-value{font-size:1.2rem;font-weight:700;font-family:monospace}.amount-positive{color:var(--success);font-weight:600;font-family:monospace}.amount-negative{color:var(--danger);font-weight:600;font-family:monospace}.amount-neutral{font-weight:600;font-family:monospace;color:var(--text)}.row-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:.15rem .3rem;border-radius:4px;transition:color .15s,background .15s}.row-delete:hover{color:var(--danger);background:#fef2f2}.back-link{color:var(--brand);text-decoration:none;font-size:.85rem}.back-link:hover{text-decoration:underline}.modal-form{display:flex;flex-direction:column;gap:.5rem}.form-hint{font-size:.8rem;color:var(--danger);margin:0}.form-hint-info{font-size:.8rem;color:var(--brand);background:#eff0fd;padding:.4rem .6rem;border-radius:6px;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:var(--surface);border-radius:1rem;padding:1.25rem;box-shadow:0 2px 12px #0000000f;display:flex;flex-direction:column;gap:.5rem}.stat-icon{width:36px;height:36px;border-radius:.6rem;display:flex;align-items:center;justify-content:center}.stat-label{font-size:.8rem;color:var(--text-muted);font-weight:500}.stat-value{font-size:1.3rem;font-weight:700;font-family:monospace;word-break:break-word}.paid-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.75rem;font-weight:600;color:var(--success);background:#ecfdf5;padding:.2rem .5rem;border-radius:2rem}.text-paid{text-decoration:line-through;opacity:.5}.pay-btn{padding:.25rem .7rem;border:1px solid var(--brand);border-radius:2rem;background:transparent;color:var(--brand);font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.pay-btn:hover{background:var(--brand);color:#fff}.btn-danger{background:var(--danger)}.btn-danger:hover:not(:disabled){background:#b91c1c}.confirm-warning{font-size:.9rem;line-height:1.6;color:var(--text)}.confirm-warning p{margin:0 0 .5rem}
