:root{--navy-950: #0c1424;--navy-900: #111c30;--navy-800: #182545;--navy-700: #22305a;--ink: #1b2436;--ink-soft: #5c6478;--border: #e4e7ee;--green: #1a8f5e;--green-bg: #e5f6ee;--red: #c23b3b;--red-bg: #fbe9e9;--gray-bg: #eef0f4;--accent: #3b6df0;--page-bg: #f6f7fb}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--page-bg)}#app{display:flex;min-height:100vh}.loading.full-page{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%;color:var(--ink-soft);background:var(--navy-950)}.auth-wrap{flex:1;display:flex;align-items:center;justify-content:center;background:var(--navy-950);min-height:100vh;width:100%}.auth-card{background:#fff;border-radius:14px;padding:32px;width:360px;box-shadow:0 20px 60px #00000059}.brand-auth{font-size:19px;font-weight:800;margin-bottom:18px;text-align:center}.auth-tabs{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:18px}.auth-tab-btn{flex:1;padding:9px;border:none;background:#fff;cursor:pointer;font-size:13.5px;font-weight:600;color:var(--ink-soft)}.auth-tab-btn.active{background:var(--accent);color:#fff}.auth-error{background:var(--red-bg);color:var(--red);padding:8px 10px;border-radius:7px;font-size:12.5px;margin-bottom:12px}.sidebar{width:250px;flex-shrink:0;background:var(--navy-950);color:#cfd8ee;display:flex;flex-direction:column;padding:18px 14px}.brand{font-size:18px;font-weight:700;color:#fff;padding:4px 8px;letter-spacing:.2px}.brand-user{font-size:11.5px;color:#8a93ad;padding:0 8px 14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-item{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;color:#cfd8ee;margin-bottom:2px}.nav-item:hover{background:var(--navy-800)}.nav-item.active{background:var(--navy-700);color:#fff}.sidebar-section-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#7d88a6;margin:18px 10px 6px;font-weight:700}.account-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:13.5px;margin-bottom:1px}.account-row:hover{background:var(--navy-800)}.account-row.active{background:var(--navy-700);color:#fff}.account-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-bal{font-variant-numeric:tabular-nums;font-weight:600;color:#a9b4d0;flex-shrink:0;margin-left:8px}.account-row.active .account-bal{color:#fff}.account-del{opacity:0;margin-left:6px;color:#8a93ad;font-size:12px}.account-row:hover .account-del{opacity:1}.add-account-btn{margin:10px 10px 0;padding:8px 10px;border-radius:8px;border:1px dashed #3a4568;color:#9aa5c4;background:transparent;cursor:pointer;font-size:13px;text-align:left}.add-account-btn:hover{background:var(--navy-800);color:#fff}.logout-btn{margin-top:auto;padding:8px 10px;border-radius:8px;border:none;background:transparent;color:#8a93ad;cursor:pointer;font-size:12.5px;text-align:left}.logout-btn:hover{background:var(--navy-800);color:#fff}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;border-bottom:1px solid var(--border);background:#fff;gap:16px;flex-wrap:wrap}.page-title{font-size:20px;font-weight:700}.month-nav{display:flex;align-items:center;gap:10px}.month-nav button{width:30px;height:30px;border-radius:6px;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:14px}.month-nav button:hover{background:var(--gray-bg)}.month-label{font-size:15px;font-weight:600;min-width:150px;text-align:center}.rta-card{padding:10px 18px;border-radius:10px;text-align:right;min-width:170px}.rta-card .rta-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:700;opacity:.75}.rta-card .rta-amt{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums}.rta-pos{background:var(--green-bg);color:var(--green)}.rta-neg{background:var(--red-bg);color:var(--red)}.rta-zero{background:var(--gray-bg);color:var(--ink-soft)}.content{flex:1;overflow-y:auto;padding:20px 28px 60px}.banner{padding:10px 14px;border-radius:8px;background:var(--red-bg);color:var(--red);font-size:13px;margin-bottom:14px}.col-headers{display:grid;grid-template-columns:1fr 130px 130px 130px 34px;padding:8px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-weight:700}.group{margin-bottom:14px;border:1px solid var(--border);border-radius:10px;background:#fff;overflow:hidden}.group-header{display:grid;grid-template-columns:1fr 130px 130px 130px 34px;align-items:center;padding:10px 12px;background:#fafbfd;cursor:pointer;font-weight:700;font-size:13.5px}.group-header:hover{background:#f2f4f9}.group-name-wrap{display:flex;align-items:center;gap:8px}.caret{display:inline-block;transition:transform .12s;color:var(--ink-soft);width:10px}.caret.collapsed{transform:rotate(-90deg)}.cat-row{display:grid;grid-template-columns:1fr 130px 130px 130px 34px;align-items:center;padding:8px 12px;border-top:1px solid var(--border);font-size:13.5px}.cat-row:hover{background:#fafbfd}.cat-name{padding-left:22px;color:var(--ink)}.assigned-input{width:100%;padding:5px 7px;border:1px solid var(--border);border-radius:6px;font-size:13.5px;font-variant-numeric:tabular-nums;text-align:right}.assigned-input:focus{outline:2px solid var(--accent);border-color:var(--accent)}.activity-val{text-align:right;padding-right:8px;color:var(--ink-soft);font-variant-numeric:tabular-nums}.avail-pill{text-align:right;font-weight:700;font-variant-numeric:tabular-nums;padding:4px 8px;border-radius:6px}.icon-btn{background:none;border:none;color:#b6bccb;cursor:pointer;font-size:14px;padding:4px;border-radius:5px}.icon-btn:hover{background:var(--gray-bg);color:var(--red)}.add-row-btn{background:none;border:none;color:var(--accent);font-size:12.5px;font-weight:600;cursor:pointer;padding:2px 4px}.add-row-btn:hover{text-decoration:underline}.new-cat-form{display:flex;gap:8px;padding:8px 12px 8px 34px;border-top:1px solid var(--border)}.btn{padding:6px 12px;border-radius:6px;border:1px solid var(--border);background:#fff;font-size:12.5px;font-weight:600;cursor:pointer}.btn:hover{background:var(--gray-bg)}.btn:disabled{opacity:.6;cursor:default}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:#2f5ad1}.register-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}table.register{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden;font-size:13.5px}table.register th{text-align:left;font-size:11px;text-transform:uppercase;color:var(--ink-soft);letter-spacing:.05em;padding:9px 10px;background:#fafbfd;border-bottom:1px solid var(--border)}table.register td{padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:middle}table.register tr:last-child td{border-bottom:none}.num-cell{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.cleared-badge{display:inline-block;width:20px;height:20px;border-radius:5px;border:1px solid var(--border);cursor:pointer;text-align:center;line-height:18px;font-size:12px}.cleared-badge.on{background:var(--green-bg);color:var(--green);border-color:var(--green)}.newtx-row td{background:#fbfcfe}.newtx-row input,.newtx-row select{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px}.empty-msg{color:var(--ink-soft);font-size:13.5px;padding:24px;text-align:center}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a101e73;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:12px;padding:24px;width:360px;box-shadow:0 20px 60px #00000040}.modal h3{margin:0 0 16px;font-size:17px}.field{margin-bottom:12px}.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:4px}.field input,.field select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:7px;font-size:13.5px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}
