:root{
  --ink:#0B1220;--muted:#6B7280;--blue:#0D63EA;--blue-dark:#0A4FC0;--blue-tint:#EAF1FE;
  --bg:#F7F8FA;--surface:#FFFFFF;--line:#E5E5E7;
  --ok:#1B8A5A;--ok-tint:#E7F6EE;--danger:#D64545;--danger-tint:#FCEAEA;
  --radius:14px;--shadow:0 1px 2px rgba(15,23,42,.04),0 10px 28px rgba(15,23,42,.07);
}
*{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;min-height:100vh;-webkit-font-smoothing:antialiased;}

/* ---- Login ---- */
.login-body{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;min-height:100vh;}
.login-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:32px;width:100%;max-width:340px;text-align:center;box-shadow:var(--shadow);}
.login-card img{height:81px;margin:0 auto 18px;display:block;}
.login-card h1{font-size:18px;margin-bottom:4px;}
.login-card .sub{color:var(--muted);font-size:12px;margin-bottom:22px;}
.login-error{color:var(--danger);font-size:12.5px;min-height:18px;margin-bottom:6px;}
.login-notice{max-width:340px;margin:16px auto 60px;text-align:center;font-size:11px;line-height:1.5;color:var(--muted);}
.login-copyright{position:fixed;bottom:0;left:0;right:0;padding:14px;text-align:center;font-size:11px;color:var(--muted);background:var(--bg);}

/* ---- Shared ---- */
.field{display:flex;flex-direction:column;gap:6px;text-align:left;margin-bottom:14px;}
.field label{font-size:12px;color:var(--muted);font-weight:600;}
.field input{background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:10px 12px;color:var(--ink);font-size:13px;}
.field input:focus{outline:none;border-color:var(--blue);background:var(--surface);box-shadow:0 0 0 3px var(--blue-tint);}

.btn{font-weight:600;font-size:13px;padding:10px 16px;border-radius:9px;border:1px solid var(--line);background:var(--surface);color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:7px;}
.btn:hover{border-color:var(--blue);color:var(--blue);}
.btn.primary{background:var(--blue);color:#fff;border:none;box-shadow:0 1px 2px rgba(13,99,234,.25),0 6px 16px rgba(13,99,234,.18);}
.btn.primary:hover{background:var(--blue-dark);color:#fff;}
.btn.ghost{background:transparent;border-color:transparent;}
.btn.danger{color:var(--danger);}
.btn.sm{padding:7px 11px;font-size:12px;}

/* ---- Layout ---- */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:14px 24px;background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:24px;width:auto;display:block;}
.brand-divider{width:1px;height:24px;background:var(--line);}
.brand-sub{font-size:12px;color:var(--muted);font-weight:500;}
.tabs{display:flex;gap:3px;background:var(--bg);padding:4px;border-radius:11px;border:1px solid var(--line);}
.tab{padding:9px 15px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;user-select:none;white-space:nowrap;}
.tab.active{background:var(--blue);color:#fff;}
.wrap{max-width:1140px;margin:0 auto;padding:30px 20px 90px;}
.view{display:none;}
.view.active{display:block;}
.page-title{font-size:22px;font-weight:700;margin-bottom:5px;}
.page-sub{color:var(--muted);font-size:13.5px;margin-bottom:22px;}

.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px;}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);}
.stat .num{font-size:25px;font-weight:700;color:var(--blue);}
.stat .lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:3px;font-weight:600;}

.toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:20px;}
.emp-list{display:flex;flex-direction:column;gap:10px;}
.emp-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;box-shadow:var(--shadow);}
.emp-card.disabled{opacity:.55;}
.avatar{width:46px;height:46px;border-radius:11px;background:var(--blue-tint);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--blue);flex-shrink:0;overflow:hidden;}
.avatar img{width:100%;height:100%;object-fit:cover;}
.emp-info{flex:1;min-width:170px;}
.emp-name{font-weight:600;font-size:14px;}
.emp-meta{font-size:12.5px;color:var(--muted);margin-top:1px;}
.emp-id{font-family:ui-monospace,Menlo,monospace;font-size:11px;color:var(--blue);margin-top:4px;}
.status-pill{font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase;}
.status-pill.off{background:var(--danger-tint);color:var(--danger);}
.emp-actions{display:flex;gap:6px;flex-wrap:wrap;}
.empty-state{text-align:center;padding:54px 20px;color:var(--muted);border:1.5px dashed var(--line);border-radius:var(--radius);background:var(--surface);}

.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px;max-width:660px;box-shadow:var(--shadow);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field.full{grid-column:1/-1;}
.section-label{font-family:ui-monospace,Menlo,monospace;font-size:11px;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;margin:18px 0 4px;grid-column:1/-1;border-top:1px solid var(--line);padding-top:18px;font-weight:600;}
.design-pick{display:flex;gap:10px;grid-column:1/-1;}
.design-opt{flex:1;border:1.5px solid var(--line);border-radius:10px;padding:12px;cursor:pointer;text-align:center;font-size:12.5px;font-weight:600;color:var(--muted);}
.design-opt.active{border-color:var(--blue);background:var(--blue-tint);color:var(--blue);}
.photo-row{display:flex;align-items:center;gap:14px;grid-column:1/-1;}
.photo-preview{width:64px;height:64px;border-radius:12px;background:var(--blue-tint);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;color:var(--muted);font-size:10px;text-align:center;}
.photo-preview img{width:100%;height:100%;object-fit:cover;}
.photo-hint{font-size:11.5px;color:var(--muted);}
.form-actions{display:flex;gap:10px;margin-top:22px;grid-column:1/-1;}
.form-msg{grid-column:1/-1;font-size:12.5px;min-height:16px;}
.form-msg.error{color:var(--danger);}
@media(max-width:560px){.form-grid{grid-template-columns:1fr;}}

.success-panel{background:var(--surface);border:1px solid var(--line);border-top:3px solid var(--blue);border-radius:var(--radius);padding:26px;max-width:480px;margin-top:22px;box-shadow:var(--shadow);}
.success-panel .tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:var(--ok);text-transform:uppercase;margin-bottom:10px;background:var(--ok-tint);padding:4px 9px;border-radius:20px;}
.url-box{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:11px 12px;margin:14px 0;}
.url-box span{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--blue);word-break:break-all;flex:1;}
.qr-box img{background:#fff;padding:10px;border-radius:10px;width:140px;height:140px;border:1px solid var(--line);}

.log-table{width:100%;border-collapse:collapse;font-size:12.5px;background:var(--surface);}
.log-table th{text-align:left;padding:10px 12px;color:var(--muted);font-weight:600;border-bottom:1px solid var(--line);font-size:11px;text-transform:uppercase;background:var(--bg);}
.log-table td{padding:11px 12px;border-bottom:1px solid var(--line);}
.ua-cell{font-family:ui-monospace,Menlo,monospace;font-size:11px;color:var(--muted);}
.ip-cell{font-family:ui-monospace,Menlo,monospace;color:var(--blue);}
.table-shell{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}

/* ---- QR generator ---- */
.qrgen-shell{display:flex;gap:28px;flex-wrap:wrap;align-items:flex-start;}
.qrgen-form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;width:100%;max-width:420px;box-shadow:var(--shadow);}
.type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:18px;}
.type-btn{border:1px solid var(--line);background:var(--bg);border-radius:10px;padding:10px 4px;display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;font-size:10px;font-weight:600;color:var(--muted);}
.type-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;}
.type-btn.active{border-color:var(--blue);background:var(--blue-tint);color:var(--blue);}
.style-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(64px,1fr));gap:6px;margin:6px 0 14px;}
.style-swatch{border:1.5px solid var(--line);background:var(--bg);border-radius:9px;padding:8px 4px;text-align:center;cursor:pointer;font-size:10.5px;font-weight:600;color:var(--muted);}
.style-swatch.active{border-color:var(--blue);background:var(--blue-tint);color:var(--blue);}
.logo-toggle{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--ink);margin:2px 0 14px;cursor:pointer;}
.logo-toggle input{width:16px;height:16px;accent-color:var(--blue);cursor:pointer;}
.qrgen-preview{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;text-align:center;width:280px;box-shadow:var(--shadow);}
.qrgen-preview .qbox{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;display:inline-block;}
.color-row{display:flex;gap:10px;margin-top:14px;}
.color-row label{font-size:11px;color:var(--muted);font-weight:600;display:block;margin-bottom:4px;}
.color-row input[type=color]{width:100%;height:34px;border:1px solid var(--line);border-radius:8px;background:none;cursor:pointer;}
.history-list{margin-top:22px;display:flex;flex-direction:column;gap:8px;}
.history-item{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:8px 10px;font-size:12px;}
.history-item img{width:32px;height:32px;border-radius:4px;flex-shrink:0;}
.history-item .h-txt{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);}

/* ---- Modal ---- */
.modal-bg{position:fixed;inset:0;background:rgba(11,18,32,.45);display:none;align-items:center;justify-content:center;z-index:100;padding:20px;overflow-y:auto;}
.modal-bg.active{display:flex;}
.modal{background:var(--surface);border-radius:var(--radius);padding:26px;max-width:340px;width:100%;max-height:85vh;overflow-y:auto;text-align:center;box-shadow:0 30px 70px rgba(15,23,42,.3);}
.mfa-qr{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px;display:inline-block;margin:10px 0;}
.mfa-qr img{width:180px;height:180px;display:block;}
.status-pill.on{background:var(--ok-tint);color:var(--ok);}
