*{box-sizing:border-box}body{margin:0;font-family:-apple-system,Segoe UI,Roboto,sans-serif;background:#f1f5f9;color:#0f172a}a{color:inherit;text-decoration:none}.shell{display:flex;min-height:100vh}.sidebar{width:220px;background:#0f172a;color:#e2e8f0;padding:18px 12px;position:-webkit-sticky;position:sticky;top:0;height:100vh;flex-shrink:0}.brand{font-weight:700;font-size:16px;padding:6px 10px 16px;color:#fff}.sidebar nav{display:flex;flex-direction:column;gap:2px}.nav-item{display:block;padding:9px 12px;border-radius:8px;font-size:14px;color:#cbd5e1}.nav-item:hover{background:#1e293b;color:#fff}.nav-item.active{background:#2563eb;color:#fff}.nav-item.disabled{color:#64748b;cursor:default}.content{flex:1 1;padding:28px 32px;max-width:1200px}h1{font-size:22px;margin:0 0 18px}.count{font-size:14px;color:#64748b;font-weight:500}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));grid-gap:14px;gap:14px}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px 18px;font-size:13px;color:#64748b}.card span{display:block;font-size:26px;font-weight:700;color:#0f172a;margin-bottom:4px}.toolbar{display:flex;gap:8px;margin-bottom:14px}.input{padding:9px 12px;border:1px solid #cbd5e1;border-radius:8px;min-width:260px}.btn,.input{font-size:14px}.btn{background:#2563eb;color:#fff;border:0;border-radius:8px;padding:9px 16px;cursor:pointer}.btn.sm{padding:6px 12px;font-size:13px;background:#0f172a}.btn:hover{opacity:.92}.link{color:#2563eb;font-weight:600}table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}td,th{text-align:left;padding:12px 14px;font-size:14px;border-bottom:1px solid #f1f5f9}th{background:#f8fafc;color:#64748b}.badge,th{font-weight:600}.badge{color:#fff;padding:3px 10px;border-radius:999px;font-size:12px}.err{color:#dc2626;margin-top:12px}.page-head{display:flex;align-items:center;justify-content:space-between}.sidebar{display:flex;flex-direction:column}.nav-item.logout{margin-top:auto;background:none;border:0;text-align:left;cursor:pointer;color:#f87171;font-size:14px}.nav-item.logout:hover{background:#1e293b}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f172a}.login-card{background:#fff;border-radius:16px;padding:32px;width:360px;box-shadow:0 10px 40px rgba(0,0,0,.3)}.login-card h2{margin:0 0 18px;font-size:20px}.muted{color:#64748b;font-size:13px;line-height:1.5;margin:0 0 14px}.input.full{width:100%;margin-bottom:12px}.btn.full{width:100%;padding:11px}.link-btn{display:block;margin:12px auto 0;background:none;border:0;color:#2563eb;cursor:pointer;font-size:13px}.group-meta{display:flex;flex-wrap:wrap;gap:16px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px 18px;font-size:13px;color:#64748b;margin-bottom:18px}.group-meta b{color:#0f172a}.att-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.att-head h2{font-size:16px;margin:0}.month-nav{display:flex;align-items:center;gap:8px;font-size:14px}.att-wrap{overflow-x:auto;background:#fff;border:1px solid #e2e8f0;border-radius:12px}.att-table{border-collapse:collapse;min-width:100%}.att-table td,.att-table th{border:1px solid #f1f5f9;padding:9px 12px;font-size:13px;text-align:center;white-space:nowrap}.att-table th{background:#f8fafc;color:#64748b;font-weight:600}.att-table td.sticky,.att-table th.sticky{position:-webkit-sticky;position:sticky;left:0;background:#fff;text-align:left;min-width:170px;font-weight:500}.att-table th.sticky{background:#f8fafc}.att-cell{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-size:15px}.att-cell:hover{background:#eff6ff}.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px;align-items:flex-start}.kcol{min-width:235px;max-width:235px;background:#eef2f7;border-radius:12px;padding:10px;flex-shrink:0}.kcol-head{font-weight:700;font-size:13px;margin-bottom:8px;display:flex;justify-content:space-between;color:#334155}.kcol-head .count{background:#cbd5e1;color:#334155;border-radius:999px;padding:0 8px;font-size:11px}.kadd{width:100%;background:#dbe3ec;border:0;border-radius:8px;padding:6px;font-size:12px;color:#475569;cursor:pointer;margin-bottom:8px}.kadd:hover{background:#cbd5e1}.kcard{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:10px;margin-bottom:8px;cursor:-webkit-grab;cursor:grab}.kcard:active{cursor:-webkit-grabbing;cursor:grabbing}.kname{font-weight:600;font-size:13px}.kphone{color:#64748b;font-size:12px;margin-top:2px}.kdate{color:#94a3b8;font-size:11px;margin-top:4px}.kconv{margin-top:8px;width:100%;background:#16a34a;color:#fff;border:0;border-radius:6px;padding:5px;font-size:12px;cursor:pointer}.kconv:hover{opacity:.9}.fin-tables{display:grid;grid-template-columns:1fr 1fr;grid-gap:18px;gap:18px;margin-top:20px}.fin-tables h2{font-size:15px;margin:0 0 10px}@media (max-width:1000px){.fin-tables{grid-template-columns:1fr}}.report-cols{display:grid;grid-template-columns:1fr 1fr;grid-gap:18px;gap:18px;margin-top:20px}@media (max-width:1000px){.report-cols{grid-template-columns:1fr}}.report-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px 18px}.report-card h2{font-size:15px;margin:0 0 14px}.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:9px;font-size:13px}.bar-label{width:140px;flex-shrink:0;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-track{flex:1 1;background:#f1f5f9;border-radius:6px;height:18px;overflow:hidden}.bar-fill{height:100%;border-radius:6px;min-width:2px}.bar-val{width:28px;text-align:right;color:#64748b;font-weight:600}.settings-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.settings-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569}.settings-grid .input{min-width:0;width:100%}@media (max-width:700px){.settings-grid{grid-template-columns:1fr}}.tabs{display:flex;gap:4px;border-bottom:2px solid #e2e8f0;margin:18px 0}.tab{background:none;border:0;padding:9px 16px;font-size:14px;cursor:pointer;color:#64748b;border-bottom:2px solid transparent;margin-bottom:-2px}.tab.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.assignment-item{display:flex;justify-content:space-between;align-items:center;width:100%;text-align:left;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:9px 12px;margin-bottom:6px;cursor:pointer;font-size:13px}.assignment-item:hover{background:#eff6ff}.assignment-item.active{border-color:#2563eb;background:#eff6ff}.note-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:10px 12px;margin-bottom:8px;font-size:13px}.ma{max-width:480px;margin:0 auto;padding:16px;min-height:100vh}.ma-hi{font-size:18px;margin:4px 0 14px}.ma-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:14px 16px;margin-bottom:12px}.ma-name{font-weight:700;font-size:15px;margin-bottom:8px}.ma-enr{border-top:1px solid #f1f5f9;padding:10px 0}.ma-enr:first-of-type{border-top:0}.ma-enr-top{display:flex;justify-content:space-between;align-items:center;gap:8px}.ma-pay{margin-top:8px}.today-row{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid #f1f5f9;font-size:13px}.today-row:last-of-type{border-bottom:0}.pager{display:flex;align-items:center;gap:12px;justify-content:center;margin-top:16px;font-size:14px;color:#64748b}.btn:disabled{opacity:.4;cursor:not-allowed}