:root{--bg:#f7f8fb;--card:rgba(255,255,255,.82);--text:#172130;--muted:#6b7280;--line:#e5e7eb;--pink:#c53283;--pink2:#ef4aa2;--dark:#172130;--green:#16a34a;--red:#dc2626;--yellow:#ca8a04;--shadow:0 24px 70px rgba(23,33,48,.12);--radius:24px}body.dark{--bg:#0b111d;--card:rgba(19,28,43,.78);--text:#eef2f7;--muted:#9ca3af;--line:#243044;--shadow:0 24px 70px rgba(0,0,0,.32)}*{box-sizing:border-box}body{margin:0;font-family:"Cairo","Segoe UI",Tahoma,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}button,input,select,textarea{font-family:inherit}input,select,textarea{width:100%;border:1px solid var(--line);background:rgba(255,255,255,.72);color:var(--text);padding:13px 14px;border-radius:15px;outline:none}body.dark input,body.dark select,body.dark textarea{background:rgba(8,13,22,.7)}label{display:block;margin:12px 0 7px;font-weight:700}.hidden{display:none!important}.glass{background:var(--card);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.35);box-shadow:var(--shadow)}.muted{color:var(--muted);margin:0}.bg-animation{position:fixed;inset:0;z-index:-1;overflow:hidden;background:radial-gradient(circle at 20% 15%,rgba(197,50,131,.18),transparent 34%),radial-gradient(circle at 85% 70%,rgba(23,33,48,.18),transparent 36%)}.bg-animation span{position:absolute;width:260px;height:260px;border-radius:42% 58% 70% 30%;background:linear-gradient(135deg,rgba(197,50,131,.28),rgba(239,74,162,.05));animation:float 12s ease-in-out infinite}.bg-animation span:nth-child(1){top:8%;left:8%}.bg-animation span:nth-child(2){bottom:7%;right:12%;animation-delay:-3s}.bg-animation span:nth-child(3){top:42%;left:45%;width:150px;height:150px;animation-delay:-7s}.bg-animation span:nth-child(4){bottom:20%;left:13%;width:110px;height:110px;animation-delay:-10s}@keyframes float{0%,100%{transform:translate(0,0) rotate(0)}50%{transform:translate(28px,-32px) rotate(18deg)}}.login-screen{min-height:100vh;display:grid;place-items:center;padding:22px}.login-card{width:min(470px,100%);border-radius:32px;padding:38px}.login-logo{height:70px;object-fit:contain;margin-bottom:18px}.logo-dark{display:none}body.dark .logo-light{display:none}body.dark .logo-dark{display:block}.login-card h1{margin:0 0 8px;font-size:30px}.password-wrap{position:relative}.password-wrap input{padding-left:54px}.password-wrap button{position:absolute;left:8px;top:7px;border:0;background:transparent;width:40px;height:40px;border-radius:12px;cursor:pointer}.primary-btn,.ghost-btn,.danger-btn{border:0;border-radius:16px;padding:13px 18px;font-weight:800;cursor:pointer;transition:.22s transform,.22s background,.22s box-shadow}.primary-btn{width:100%;margin-top:18px;color:white;background:linear-gradient(135deg,var(--pink),var(--pink2));box-shadow:0 12px 30px rgba(197,50,131,.28)}.primary-btn:hover,.ghost-btn:hover,.danger-btn:hover,.icon-btn:hover{transform:translateY(-2px) scale(1.02)}.small{width:auto;margin:0;padding:10px 14px}.ghost-btn{background:rgba(148,163,184,.14);color:var(--text)}.danger-btn{background:rgba(220,38,38,.12);color:var(--red)}.error{color:var(--red);min-height:24px;margin-top:12px;font-weight:700}.app{display:grid;grid-template-columns:290px 1fr;min-height:100vh;gap:22px;padding:22px}.sidebar{border-radius:30px;padding:20px;position:sticky;top:22px;height:calc(100vh - 44px);display:flex;flex-direction:column}.brand-logo{max-width:210px;margin:8px auto 20px;display:block}nav{display:grid;gap:8px}.nav-btn{border:0;background:transparent;color:var(--text);padding:13px 14px;border-radius:16px;text-align:right;font-weight:800;cursor:pointer;transition:.2s}.nav-btn.active,.nav-btn:hover{background:linear-gradient(135deg,rgba(197,50,131,.16),rgba(197,50,131,.06));color:var(--pink);transform:translateX(-3px)}.sidebar-actions{margin-top:auto;display:grid;gap:10px}.content{min-width:0}.topbar{border-radius:28px;padding:22px 24px;margin-bottom:22px;display:flex;justify-content:space-between;align-items:center}.topbar h2{margin:0 0 6px}.user-pill{padding:10px 15px;border-radius:999px;background:rgba(197,50,131,.12);display:grid;text-align:center;font-weight:800}.user-pill small{color:var(--muted)}.page{display:none}.active-page{display:block}.filters{border-radius:24px;padding:16px;display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:18px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-card{border-radius:24px;padding:20px;position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;left:-30px;top:-30px;width:100px;height:100px;border-radius:50%;background:rgba(197,50,131,.12)}.stat-card strong{display:block;font-size:25px;margin-top:10px}.section-head{display:flex;justify-content:space-between;align-items:center;margin:24px 0 12px}.table-card{border-radius:24px;padding:14px;overflow:auto}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:14px;border-bottom:1px solid var(--line);text-align:right;vertical-align:middle}th{color:var(--muted);font-size:13px}tr:hover td{background:rgba(197,50,131,.04)}.actions{display:flex;gap:7px}.icon-btn{border:0;background:rgba(148,163,184,.14);width:36px;height:36px;border-radius:12px;cursor:pointer;position:relative;transition:.2s}.icon-btn:hover:after{content:attr(data-tip);position:absolute;bottom:43px;right:50%;transform:translateX(50%);background:var(--dark);color:white;padding:6px 10px;border-radius:10px;font-size:12px;white-space:nowrap;z-index:20}.badge{display:inline-flex;border-radius:999px;padding:6px 10px;font-weight:800;font-size:12px}.ok{background:rgba(22,163,74,.12);color:var(--green)}.warn{background:rgba(202,138,4,.12);color:var(--yellow)}.bad{background:rgba(220,38,38,.12);color:var(--red)}.modal{position:fixed;inset:0;background:rgba(0,0,0,.45);display:grid;place-items:center;padding:22px;z-index:99}.modal-box{width:min(720px,100%);border-radius:28px;padding:24px;position:relative;max-height:90vh;overflow:auto}.close{position:absolute;left:18px;top:14px;border:0;background:rgba(148,163,184,.16);border-radius:12px;width:38px;height:38px;font-size:24px;cursor:pointer}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}.check-card{border:1px solid var(--line);border-radius:15px;padding:12px;background:rgba(148,163,184,.08)}.check-card input{width:auto;margin-left:8px}.scanner-grid{display:grid;grid-template-columns:420px 1fr;gap:18px}.scanner-card{border-radius:24px;padding:18px}#reader{min-height:280px;border-radius:18px;overflow:hidden;border:1px dashed var(--line);margin:12px 0}.scan-actions{display:flex;gap:10px;margin-bottom:12px}.qr-canvas{width:76px;height:76px;background:white;border-radius:12px;padding:4px}@media(max-width:1000px){.app{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.filters,.stats-grid,.scanner-grid{grid-template-columns:1fr}.topbar{display:grid;gap:12px}.form-grid,.modules-grid{grid-template-columns:1fr}}
.id-card-preview{width:min(540px,100%);min-height:320px;border-radius:28px;background:linear-gradient(135deg,#fff 0%,#fff 46%,#fdf2f8 46%,#fff 100%);box-shadow:0 24px 70px rgba(23,33,48,.18);padding:22px;position:relative;overflow:hidden;border:1px solid #f1d5e5;margin:18px auto;color:#172130}.id-card-bg-mark{position:absolute;left:-8px;bottom:-52px;font-size:180px;font-weight:900;color:rgba(197,50,131,.08);line-height:1}.id-card-top{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:2}.id-card-logo{height:48px;max-width:210px;object-fit:contain}.id-card-top span{background:#172130;color:white;border-radius:999px;padding:8px 14px;font-weight:800;font-size:12px;letter-spacing:1px}.id-card-body{display:grid;grid-template-columns:90px 1fr 132px;gap:18px;align-items:center;margin-top:28px;position:relative;z-index:2}.id-avatar{width:88px;height:88px;border-radius:24px;background:linear-gradient(135deg,#c53283,#ef4aa2);display:grid;place-items:center;color:white;font-size:44px;font-weight:900}.id-info b{font-size:30px;color:#172130;display:block}.id-info small{font-size:18px;color:#c53283;font-weight:800}.id-info p{margin:14px 0 0;color:#64748b;font-weight:800}.id-qr{width:132px;height:132px;background:#fff;border:1px solid #eee;border-radius:18px;padding:6px}.id-card-footer{position:absolute;right:22px;left:22px;bottom:20px;display:flex;justify-content:space-between;align-items:center;border-top:1px dashed #e5e7eb;padding-top:12px;color:#64748b;font-size:13px}.id-card-footer strong{direction:ltr;color:#172130;font-size:12px}.modal-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:14px}body.dark .id-card-preview{background:linear-gradient(135deg,#fff 0%,#fff 46%,#fdf2f8 46%,#fff 100%);color:#172130}@media(max-width:640px){.id-card-body{grid-template-columns:1fr;text-align:center}.id-card-preview{min-height:520px}.id-card-footer{display:grid;gap:5px;text-align:center}.id-avatar,.id-qr{margin:auto}.id-info b{font-size:24px}}
.qr-img{width:82px;height:82px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:4px;object-fit:contain}.qr-img-big{width:132px!important;height:132px!important;background:#fff;border-radius:16px;padding:6px;object-fit:contain}.emp-photo{object-fit:cover!important;display:block}.file-label{border:1px dashed rgba(197,50,131,.35);border-radius:14px;padding:10px;background:rgba(197,50,131,.05);font-weight:800}.file-label input{display:block;margin-top:8px}.photo-preview{display:grid;place-items:center;margin:16px 0}.photo-preview .id-avatar{width:120px;height:120px;border-radius:28px}.id-card-preview .emp-photo{width:90px;height:90px;border-radius:24px}.id-card-preview{position:relative}.modal-actions{flex-wrap:wrap}.salary-mini-note{font-size:12px;color:#64748b}
.icon-btn.wide{width:auto;min-width:74px;padding:0 10px;font-weight:800;color:var(--pink)}
.qr-table{width:92px!important;height:92px!important;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:6px;display:block}
.id-card-preview canvas.id-qr{width:132px!important;height:132px!important;background:#fff;border:1px solid #eee;border-radius:18px;padding:6px}
/* V10 fixes */
.icon-btn.wide.card-btn,.icon-btn.wide.photo-btn{width:auto;min-width:92px;padding:0 12px;gap:6px;font-size:13px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}
.file-label{display:flex!important;align-items:center;justify-content:center;min-height:46px;border:1px dashed rgba(197,50,131,.55);border-radius:14px;background:rgba(197,50,131,.06);cursor:pointer;font-weight:800;color:#c53283}
.file-label input{display:none!important}
.qr-table{background:#fff;border-radius:10px;padding:4px;border:1px solid rgba(15,23,42,.1)}
.emp-photo{object-fit:cover!important}
