:root{--bg: #f7f8fa;--bg-soft: #f1f3f6;--paper: #ffffff;--paper-2: #fbfcfe;--line: #e7eaf0;--line-2: #d5dae3;--ink: #111318;--text: #3a404c;--muted: #737b8c;--muted-2: #a4abba;--primary: #4f46e5;--primary-hover: #4338ca;--primary-soft: #eef2ff;--primary-edge: #c7d2fe;--emerald: #059669;--emerald-soft: #d1fae5;--amber: #d97706;--amber-soft: #fef3c7;--rose: #e11d48;--rose-soft: #ffe4e6;--sky: #0284c7;--sky-soft: #e0f2fe;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--bg)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg)}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}.page-loader{min-height:100vh;display:grid;place-items:center;color:var(--muted)}.login-screen{min-height:100vh;display:grid;place-items:center;background:var(--bg);padding:24px}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),#7168ff);color:#fff;font-weight:800;box-shadow:0 10px 22px -12px #4f46e5cc}.brand strong{display:block;color:var(--ink);font-size:16px}.brand span{display:block;margin-top:2px;color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.eyebrow{margin:0 0 10px;color:var(--primary);font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.setup-screen{display:grid;place-items:center;min-width:0;padding:54px;background:linear-gradient(180deg,var(--paper),var(--paper-2))}.login-card,.password-card{width:100%;max-width:410px;border:1px solid var(--line);border-radius:8px;background:var(--paper);padding:34px;box-shadow:0 26px 58px -38px #4f46e5b3}.login-card h1,.password-card h1{margin:0 0 8px;color:var(--ink);font-size:30px}.muted{color:var(--muted)}.field{display:grid;gap:7px;margin:14px 0}.field span{color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.field input,.field select,.field textarea{width:100%;min-height:42px;border:1.5px solid var(--line-2);border-radius:7px;background:var(--bg-soft);color:var(--ink);padding:10px 12px}.field textarea{min-height:90px;resize:vertical}.styled-select{position:relative;width:100%}.select-trigger{width:100%;min-height:42px;display:flex;align-items:center;justify-content:space-between;gap:12px;border:1.5px solid var(--line-2);border-radius:7px;background:var(--bg-soft);color:var(--ink);padding:10px 12px;text-align:left}.select-trigger svg{color:var(--muted);flex:0 0 auto}.styled-select.open .select-trigger,.select-trigger:focus{border-color:var(--primary);background:var(--paper);box-shadow:0 0 0 3px #4f46e51f;outline:0}.select-menu{position:absolute;z-index:30;top:calc(100% + 6px);left:0;right:0;max-height:260px;overflow:auto;border:1px solid var(--line);border-radius:8px;background:var(--paper);box-shadow:0 18px 45px -28px #111318a6;padding:6px}.select-option{width:100%;min-height:36px;display:flex;align-items:center;justify-content:space-between;gap:10px;border:0;border-radius:6px;background:transparent;color:var(--text);padding:8px 10px;text-align:left}.select-option:hover,.select-option.active{background:var(--primary-soft);color:var(--primary)}.select-option svg{flex:0 0 auto}.field small{color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;border:1px solid var(--line-2);border-radius:7px;background:var(--paper);color:var(--ink);padding:8px 12px;font-weight:700}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 8px 18px -10px #4f46e5e6}.btn.primary:hover{background:var(--primary-hover)}.btn.danger{border-color:#fecdd3;background:#fff1f2;color:var(--rose)}.btn.full{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed}.form-error{margin:12px 0;border:1px solid #f6c7d0;border-radius:7px;background:#fff8fa;color:var(--rose);padding:10px 12px}.form-success{margin:12px 0;border:1px solid #bbf7d0;border-radius:7px;background:#f0fdf4;color:var(--emerald);padding:10px 12px}.login-note{margin:20px 0 0;padding-top:16px;border-top:1px solid var(--line);color:var(--muted);font-size:12px;text-align:center}.form-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.form-hint{color:var(--muted);font-size:13px;font-weight:700}.view-switch{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.app-shell{min-height:100vh;display:grid;grid-template-columns:244px minmax(0,1fr);background:var(--bg)}.sidebar{min-height:100vh;display:flex;flex-direction:column;background:var(--paper);border-right:1px solid var(--line);padding:20px 14px}.nav-section{padding:18px 12px 8px;color:var(--muted-2);font-size:9px;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.side-link{display:flex;align-items:center;gap:10px;border-radius:7px;color:var(--text);padding:9px 12px}.side-link.active{background:var(--primary-soft);color:var(--primary);font-weight:800}.sidebar-user{margin-top:auto;padding:14px 10px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}.sidebar-user strong,.sidebar-user span{display:block}.sidebar-user span{color:var(--muted);font-size:12px}.avatar{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;font-size:11px;font-weight:800}.main{min-width:0;display:flex;flex-direction:column}.topbar{min-height:68px;display:flex;align-items:center;justify-content:space-between;gap:18px;background:var(--paper);border-bottom:1px solid var(--line);padding:0 30px}.topbar h1{margin:2px 0 0;color:var(--ink);font-size:18px}.crumb{color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.content{padding:28px 32px}.stack{display:grid;gap:18px}.card{border:1px solid var(--line);border-radius:8px;background:var(--paper);padding:20px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.page-head h2{margin:0 0 8px;color:var(--ink);font-size:30px}.page-head.split{align-items:center}.section-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.section-title h3{margin:0;color:var(--ink);font-size:18px}.text-link{color:var(--primary);font-size:13px;font-weight:800}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.stat-card{display:grid;gap:8px;min-height:112px}.stat-card span{color:var(--muted);font-size:12px;font-weight:800}.stat-card strong{color:var(--ink);font-size:26px}.stat-card.success strong,.stat-icon.success{color:var(--emerald)}.stat-card.warning strong,.stat-icon.warning{color:var(--amber)}.stat-card.danger strong,.stat-icon.danger{color:var(--rose)}.stat-card.info strong,.stat-icon.info{color:var(--sky)}.stat-icon{width:32px;height:32px;display:grid;place-items:center;border-radius:8px;background:var(--bg-soft);color:var(--primary)}.two-column{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.recent-list{display:grid;gap:10px}.recent-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid var(--line);padding-top:10px}.recent-row:first-child{border-top:0;padding-top:0}.recent-row strong,.recent-row span{display:block}.recent-row strong{color:var(--ink)}.recent-row span{color:var(--muted);font-size:12px}.attendance-form{display:grid;max-width:620px;gap:14px}.attendance-status-field{margin-bottom:0}.attendance-status-options{display:flex;gap:8px;overflow-x:auto}.attendance-status-button{min-height:38px;min-width:118px;border:1.5px solid var(--line-2);border-radius:7px;background:var(--paper);color:var(--text);padding:8px 12px;font-weight:800}.attendance-status-button.active{border-color:var(--primary);background:var(--primary-soft);color:var(--primary)}.attendance-status-button:disabled{opacity:.6;cursor:not-allowed}.attendance-notes-field{max-width:100%;margin:0}.attendance-notes-input{min-height:38px;max-height:60px}.filter-bar{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:12px;margin-bottom:18px}.filter-bar.compact{grid-template-columns:repeat(2,minmax(180px,280px));margin-bottom:0}.table-wrap{width:100%;overflow-x:auto}.inline-edit-panel{display:grid;grid-template-columns:minmax(180px,.8fr) minmax(160px,.5fr) minmax(220px,1fr) auto;align-items:end;gap:14px;margin-bottom:18px;border:1px solid var(--line);border-radius:8px;background:var(--paper-2);padding:14px}.inline-edit-meta{display:grid;gap:4px;padding-bottom:4px}.inline-edit-meta span{color:var(--primary);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.inline-edit-meta strong{color:var(--ink)}.inline-edit-meta small{color:var(--muted)}.inline-edit-actions,.inline-field-action{display:flex;align-items:center;gap:10px}.inline-field-action input{flex:1 1 auto}table{width:100%;border-collapse:collapse;min-width:720px}th,td{border-bottom:1px solid var(--line);padding:12px 10px;text-align:left;vertical-align:top}th{color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}td{color:var(--text);font-size:14px}.table-subtext{display:block;margin-top:3px;color:var(--muted);font-size:12px}.empty-state{border:1px dashed var(--line-2);border-radius:8px;color:var(--muted);padding:18px;text-align:center}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.summary-item{border:1px solid var(--line);border-radius:8px;padding:16px;display:grid;gap:10px}.summary-item strong{color:var(--ink);font-size:34px}.summary-item span{color:var(--muted);font-size:12px;font-weight:800}.toolbar{max-width:520px}.input-with-icon{position:relative}.input-with-icon svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted)}.input-with-icon input{padding-left:36px}.vault-group{padding-bottom:10px}.credential-list,.access-list{display:grid;gap:0}.credential-row{display:flex;align-items:center;justify-content:space-between;gap:16px;border-top:1px solid var(--line);padding:13px 0}.credential-row:first-child{border-top:0}.credential-main,.row-actions{display:flex;align-items:center;gap:12px}.credential-main strong,.credential-main span{display:block}.credential-main strong{color:var(--ink)}.credential-main span{margin-top:3px;color:var(--muted);font-size:12px}.icon-link{width:32px;height:32px;display:grid;place-items:center;border:1px solid var(--line-2);border-radius:7px;color:var(--muted)}.credential-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 16px}.user-form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px 16px}.credential-form .field:last-of-type,.credential-form .form-actions,.user-form .form-section-title,.user-form .form-actions{grid-column:1 / -1}.form-section-title{margin:10px 0 -4px}.form-section-title .eyebrow{margin-bottom:0}.detail-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:18px}.detail-list{display:grid;gap:18px}.detail-list span{display:block;color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.detail-list strong{display:block;margin-top:5px;color:var(--ink);overflow-wrap:anywhere}.secret-box{display:grid;gap:18px}.secret-box strong{display:block;color:var(--ink);font-size:22px;overflow-wrap:anywhere}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;background:#11131861;padding:20px}.modal{width:min(460px,100%);border:1px solid var(--line);border-radius:8px;background:var(--paper);padding:20px;box-shadow:0 24px 60px -30px #111318bf}.checkbox-list{display:grid;gap:10px;margin-bottom:18px}.check-row{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:8px;padding:10px}.check-row input{width:16px;height:16px}.check-row span,.check-row small{display:block}.check-row strong{color:var(--ink)}.check-row small{color:var(--muted)}.action-strip{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.metadata-box{max-width:340px;max-height:120px;overflow:auto;margin:0;border:1px solid var(--line);border-radius:7px;background:var(--bg-soft);color:var(--text);padding:8px;font-size:12px}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:800;background:var(--bg-soft)}.pill.success{color:var(--emerald);background:var(--emerald-soft)}.pill.warning{color:var(--amber);background:var(--amber-soft)}.pill.danger{color:var(--rose);background:var(--rose-soft)}.pill.info{color:var(--sky);background:var(--sky-soft)}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{min-height:auto}.content{padding:20px}.stat-grid,.two-column,.attendance-form,.inline-edit-panel,.filter-bar,.filter-bar.compact,.summary-grid,.credential-form,.user-form,.detail-grid{grid-template-columns:1fr}.credential-row,.row-actions{align-items:flex-start;flex-direction:column}}
