*{box-sizing:border-box}body{color:#0f172a;background:#f3f6fb;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea,select{font:inherit}.login-shell{background:linear-gradient(135deg,#e0f2fe,#f8fafc);place-items:center;min-height:100vh;padding:22px;display:grid}.login-card{background:#fff;border-radius:24px;width:min(440px,100%);padding:28px;box-shadow:0 20px 60px #0f172a1f}.brand-row{align-items:center;gap:13px;display:flex}.brand-row.center{justify-content:center;margin-bottom:24px}.brand-row svg{color:#2563eb}h1{margin:0;font-size:24px}h2{margin:0;font-size:18px}h3,p{margin:0}.brand-row p,.topbar p{color:#64748b;margin-top:3px;font-size:14px}.form-stack{flex-direction:column;gap:14px;display:flex}label{color:#334155;flex-direction:column;gap:7px;font-size:13px;font-weight:800;display:flex}input,textarea,select{color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:13px;outline:none;width:100%;padding:12px 13px}input:focus,textarea:focus,select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}input:disabled{color:#64748b;cursor:not-allowed;background:#f1f5f9}.primary-btn,.secondary-btn,.icon-btn{cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;font-weight:800;display:inline-flex}.primary-btn{color:#fff;background:#2563eb;border-radius:14px;padding:13px 16px;box-shadow:0 10px 24px #2563eb40}.primary-btn:disabled{opacity:.55;cursor:wait}.secondary-btn{color:#0f172a;background:#e2e8f0;border-radius:13px;padding:10px 13px}.icon-btn{color:#0f172a;background:#e2e8f0;border-radius:10px;width:34px;height:34px}.icon-btn.danger{color:#dc2626;background:#fee2e2}.error-message{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:13px;padding:11px 12px;font-size:13px;font-weight:700}.info-message{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:13px;padding:10px 12px;font-size:13px;font-weight:700}.required{color:#dc2626}.app-shell{min-height:100vh;padding:22px}.topbar{background:#fff;border-radius:22px;justify-content:space-between;align-items:center;gap:14px;max-width:1440px;margin:0 auto 20px;padding:18px;display:flex;box-shadow:0 14px 40px #0f172a14}.grid-layout{grid-template-columns:390px 1fr;align-items:start;gap:18px;max-width:1440px;margin:0 auto;display:grid}.panel{background:#fff;border-radius:22px;padding:18px;box-shadow:0 14px 40px #0f172a14}.section-title{align-items:center;gap:10px;margin-bottom:16px;display:flex}.section-title svg{color:#2563eb}.list-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.search-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;align-items:center;gap:10px;margin-bottom:14px;padding:0 12px;display:flex}.search-box input{box-shadow:none;background:0 0;border:none}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:900px}th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.04em;background:#f8fafc;font-size:12px}th,td{vertical-align:middle;border-bottom:1px solid #e2e8f0;padding:12px}td small{color:#64748b;max-width:360px;margin-top:5px;display:block}.thumb{object-fit:cover;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:14px;width:70px;height:70px}.thumb-btn,.photo-preview-btn,.current-photo-btn{cursor:pointer;text-align:left;background:0 0;border:none;padding:0}.action-row{gap:8px;display:flex}.no-photo{color:#94a3b8;font-size:13px}.empty-state{text-align:center;color:#64748b;border:1px dashed #cbd5e1;border-radius:18px;place-items:center;gap:9px;padding:32px;display:grid}.photo-preview-card{background:#eff6ff;border:1px dashed #93c5fd;border-radius:16px;padding:10px}.photo-preview-btn{color:#1d4ed8;flex-direction:column;gap:9px;width:100%;font-weight:800;display:flex}.photo-preview-btn img{object-fit:contain;background:#fff;border:1px solid #dbeafe;border-radius:12px;width:100%;max-height:260px}.photo-preview-btn span,.current-photo-btn span{align-items:center;gap:7px;display:inline-flex}.current-photo-btn{color:#64748b;align-items:center;gap:10px;width:100%;font-size:13px;display:flex}.current-photo-btn img{object-fit:cover;border:1px solid #e2e8f0;border-radius:12px;width:72px;height:72px}.photo-modal{z-index:100;background:#0f172ab8;justify-content:center;align-items:center;padding:22px;display:flex;position:fixed;inset:0}.photo-modal-content{background:#fff;border-radius:20px;flex-direction:column;gap:12px;width:min(96vw,980px);max-height:92vh;padding:18px;display:flex;position:relative;box-shadow:0 25px 80px #0000004d}.photo-modal-content img{object-fit:contain;background:#f8fafc;border-radius:14px;width:100%;max-height:78vh}.photo-modal-content p{color:#334155;word-break:break-word;font-weight:800}.modal-close{color:#fff;cursor:pointer;background:#0f172ad6;border:none;border-radius:999px;justify-content:center;align-items:center;width:40px;height:40px;display:inline-flex;position:absolute;top:10px;right:10px}.full-message,.mini-message{color:#64748b;place-items:center;display:grid}.full-message{min-height:100vh}.mini-message{padding:32px}@media (width<=980px){.grid-layout{grid-template-columns:1fr}.topbar,.list-header{flex-direction:column;align-items:stretch}}@media (width<=560px){.app-shell{padding:12px}.panel,.topbar{border-radius:18px;padding:14px}.brand-row{align-items:flex-start}}
