*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#f3f4f6;color:#0f172a}.app-shell{min-height:100%;display:flex;flex-direction:column}.app-header,.app-footer{background:#0f172a;color:#e5e7eb;padding:.75rem 1.25rem}.title-row{display:flex;align-items:center;gap:.75rem}.brand{font-weight:700}.spacer{flex:1}.content-grid{flex:1;display:grid;gap:12px;padding:12px 16px;grid-template-columns:minmax(280px,360px) minmax(0,1fr)}.list-pane,.detail-pane{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0f172a1f;overflow:hidden}.loading-shell{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem}.loading-spinner{width:18px;height:18px;border:2px solid #d1d5db;border-top-color:#2563eb;border-radius:999px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.employee-list{display:flex;flex-direction:column;height:100%}.list-header{padding:10px 12px;border-bottom:1px solid #e5e7eb;display:flex;gap:8px;align-items:center}.list-header h2{margin:0 auto 0 0;font-size:1.05rem}.input{border:1px solid #d1d5db;border-radius:999px;padding:.35rem .7rem;font-size:.9rem}.list-table{overflow:auto;max-height:calc(100vh - 140px)}.list-row{display:grid;grid-template-columns:1.3fr .9fr .9fr 1.4fr;gap:8px;align-items:center;padding:8px 12px;border-bottom:1px solid #f1f5f9;font-size:.9rem}.list-head{background:#f8fafc;font-weight:600;position:sticky;top:0;z-index:1}.list-row-btn{width:100%;text-align:left;background:#fff;border:0;cursor:pointer}.list-row-btn:hover{background:#f9fafb}.list-row.active{background:#eef2ff}.cell .name{font-weight:600}.cell .nickname{opacity:.7}.monospace{font-family:ui-monospace,Consolas,monospace}.card{display:grid;grid-template-columns:220px minmax(0,1fr);gap:16px;padding:16px}.photo{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px;border:1px solid #e5e7eb}.title h3{margin:0;font-size:1.3rem}.subtitle{opacity:.75;margin-top:4px}.section{margin-top:12px;padding-top:10px;border-top:1px dashed #e5e7eb;font-size:.9rem}.meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.meta .item{background:#f8fafc;border-radius:10px;padding:8px;border:1px solid #e5e7eb}.label{opacity:.7;font-size:.82rem;margin-bottom:2px}.value{font-size:.9rem}.empty-card{padding:16px}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center}.auth-card{background:#fff;padding:24px 20px;border-radius:14px;box-shadow:0 10px 40px #0f172a2e;width:100%;max-width:360px;display:flex;flex-direction:column;gap:12px}.auth-card h1{margin:0 0 8px;font-size:1.3rem}.field{display:flex;flex-direction:column;gap:4px;font-size:.9rem}.btn{border-radius:999px;padding:.45rem .9rem;border:1px solid #cbd5f5;cursor:pointer;background:#fff}.btn.primary{background:#2563eb;border-color:#2563eb;color:#fff}.btn.primary:disabled{opacity:.7;cursor:default}.error-box{background:#fef2f2;color:#991b1b;border-radius:10px;padding:6px 8px;font-size:.85rem}
