*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{color:#1e293b;background:#f1f5f9;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.sidebar{z-index:100;background:#1b2a4a;flex-direction:column;width:220px;min-height:100vh;transition:width .25s;display:flex;position:fixed;top:0;left:0}.sidebar--collapsed{width:64px}.sidebar__logo{border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:18px 16px 14px;display:flex}.sidebar__logo-icon img{object-fit:contain;background:#fff;border-radius:4px;width:36px;height:36px}.sidebar__logo-title{color:#fff;font-size:14px;font-weight:700;display:block}.sidebar__logo-subtitle{color:#e8913a;font-size:11px;display:block}.sidebar__nav{flex-direction:column;flex:1;gap:2px;padding:12px 0;display:flex}.sidebar__nav-item{color:#cbd5e1;cursor:pointer;text-align:left;background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:12px;width:100%;padding:11px 20px;font-size:14px;transition:background .15s,color .15s;display:flex}.sidebar__nav-item:hover{color:#fff;background:#ffffff0f}.sidebar__nav-item--active{color:#fff;background:#e8913a26;border-left-color:#e8913a}.sidebar__nav-item--active svg{color:#e8913a}.sidebar--collapsed .sidebar__nav-item{justify-content:center;padding:11px 0}.sidebar__toggle{color:#cbd5e1;cursor:pointer;background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;margin:0 auto 8px;display:flex}.sidebar__toggle:hover{background:#ffffff29}.sidebar__user{border-top:1px solid #ffffff14;align-items:center;gap:10px;padding:14px 16px;display:flex}.sidebar__user-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.sidebar__user-name{color:#fff;font-size:13px;font-weight:500;display:block}.sidebar__user-logout{color:#e8913a;cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;margin-top:2px;padding:0;font-size:12px;display:flex}.sidebar__user-logout:hover{text-decoration:underline}.sidebar--collapsed .sidebar__user{justify-content:center}.sidebar--collapsed .sidebar__user-info{display:none}@media (width<=768px){.sidebar{width:64px}.sidebar__logo-text,.sidebar__nav-item span,.sidebar__user-info{display:none}.sidebar__nav-item{justify-content:center;padding:11px 0}.sidebar__user{justify-content:center}}.header{z-index:50;background:#fff;border-bottom:1px solid #e2e8f0;align-items:center;gap:20px;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.header__title{color:#1e293b;white-space:nowrap;font-size:18px;font-weight:700}.header__spacer{flex:1}.header__search{flex:1;max-width:420px;margin:0 auto;position:relative}.header__search-icon{color:#94a3b8;pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.header__search-input{color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:8px 12px 8px 36px;font-size:13px}.header__search-input:focus{border-color:#1b2a4a}.header__right{white-space:nowrap;align-items:center;gap:16px;display:flex}.header__datetime{color:#64748b;flex-direction:column;align-items:flex-end;font-size:12px;line-height:1.3;display:flex}.header__date{color:#1e293b;font-weight:600}.header__bell{cursor:pointer;color:#64748b;background:0 0;border:none;position:relative}.header__bell-badge{color:#fff;background:#dc2626;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-6px}.header__avatar{align-items:center;gap:8px;display:flex}.header__avatar-circle{color:#fff;background:#1b2a4a;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.header__avatar-name{color:#1e293b;font-size:13px;font-weight:600}@media (width<=768px){.header{gap:10px;padding:0 12px}.header__search{max-width:180px}.header__datetime,.header__avatar-name{display:none}}.layout{min-height:100vh;display:flex}.layout__main{background:#f1f5f9;flex-direction:column;flex:1;min-height:100vh;transition:margin-left .25s;display:flex}.layout__content{flex:1;overflow-y:auto}@media (width<=768px){.layout__main{margin-left:64px!important}}.login-page{background:#f1f5f9;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:420px;padding:40px 36px 32px;box-shadow:0 4px 24px #0000000f}.login-card__logo{margin-bottom:16px}.login-card__logo-img{object-fit:contain;height:64px}.login-card__title{color:#1b2a4a;margin:0 0 4px;font-size:22px;font-weight:700}.login-card__subtitle{color:#64748b;margin:0 0 20px;font-size:14px}.login-card__shield{color:#1b2a4a;background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 24px;display:flex}.login-form{text-align:left}.login-form__field{margin-bottom:16px}.login-form__label{color:#1e293b;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.login-form__input{color:#1e293b;box-sizing:border-box;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border-color .15s}.login-form__input:focus{border-color:#1b2a4a}.login-form__password-wrap{position:relative}.login-form__password-wrap .login-form__input{padding-right:42px}.login-form__eye{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:0;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-form__error{color:#dc2626;margin:0 0 12px;font-size:13px;font-weight:500}.login-form__submit{color:#fff;cursor:pointer;background:#1b2a4a;border:none;border-radius:8px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:background .15s}.login-form__submit:hover{background:#162240}.login-card__demo{text-align:left;color:#1e293b;background:#f8fafc;border-radius:8px;margin-top:20px;padding:14px 16px;font-size:13px;line-height:1.6}.login-card__demo-title{color:#64748b;margin:0 0 4px;font-size:12px;font-style:italic}.login-card__demo p{margin:0}.sk-row td{padding:12px 16px!important}.sk-cell{background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9 50%,#e2e8f0 75%) 0 0/200% 100%;border-radius:4px;height:14px;animation:1.4s ease-in-out infinite sk-shimmer}@keyframes sk-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.state-empty{color:#94a3b8;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;font-size:14px;display:flex}.state-error{flex-direction:column;align-items:center;gap:12px;padding:40px 24px;display:flex}.state-error__msg{color:#dc2626;font-size:14px;font-weight:500}.state-error__btn{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #dc2626;border-radius:6px;padding:6px 18px;font-size:13px;font-weight:600}.state-error__btn:hover{background:#fecaca}.state-loading{color:#64748b;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;font-size:14px;display:flex}.spinner{border:3px solid #e2e8f0;border-top-color:#1b2a4a;border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.dashboard{padding:20px 24px 32px}.time-filter{flex-wrap:wrap;gap:6px;margin-bottom:18px;display:flex}.time-filter__btn{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:6px 16px;font-size:13px;transition:all .15s}.time-filter__btn--active{color:#fff;background:#1b2a4a;border-color:#1b2a4a}.time-filter__date{color:#1e293b;border:1px solid #e2e8f0;border-radius:6px;padding:6px 12px;font-size:13px}.time-filter__btn:hover:not(.time-filter__btn--active){background:#f1f5f9}.summary-cards{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px;display:grid}.card{background:#fff;border-radius:12px;flex-direction:column;gap:4px;padding:18px 20px;display:flex;box-shadow:0 1px 3px #0000000f}.card--dark{color:#fff;background:#1b2a4a}.card--danger{color:#fff;background:#dc2626}.card--row{flex-direction:row;justify-content:space-between;align-items:center}.card__top{justify-content:space-between;align-items:flex-start;display:flex}.card__label{opacity:.85;font-size:13px}.card__icon{opacity:.6}.card__value{font-size:32px;font-weight:800;line-height:1.1}.card__value--dark{color:#1e293b}.card__change{align-items:center;gap:2px;font-size:12px;display:flex}.card__change--up{color:#4ade80}.card__change--neutral{color:#64748b}.card__change--green{color:#16a34a}.charts-row{gap:16px;margin-bottom:20px;display:flex}.panel{background:#fff;border-radius:12px;padding:18px 20px;box-shadow:0 1px 3px #0000000f}.panel--wide{flex:2;min-width:0}.panel--narrow{flex:1;min-width:0}.panel__title{color:#1e293b;margin:0 0 14px;font-size:14px;font-weight:700}.circular-progress{flex-shrink:0}.dept-chart{flex-direction:column;gap:10px;display:flex}.dept-row{align-items:center;gap:10px;display:flex}.dept-label{text-align:right;color:#64748b;white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:120px;font-size:12px;overflow:hidden}.dept-track{background:#f1f5f9;border-radius:4px;flex:1;height:16px;overflow:hidden}.dept-fill{border-radius:4px;height:100%;transition:width .4s}.dept-axis{color:#94a3b8;justify-content:space-between;margin-top:4px;margin-left:130px;font-size:11px;display:flex}.overstay-table-wrapper{overflow-x:auto}.overstay-table{border-collapse:collapse;width:100%;font-size:13px}.overstay-table th{text-align:left;color:#64748b;white-space:nowrap;border-bottom:1px solid #e2e8f0;padding:8px 10px;font-weight:600}.overstay-table td{white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:9px 10px}.overstay-name{color:#1e293b;font-weight:600}.overstay-duration{color:#dc2626;font-weight:600}.flag-btn{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #dc2626;border-radius:5px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;transition:background .15s;display:inline-flex}.flag-btn:hover{background:#fecaca}.flag-btn--active{color:#fff;background:#dc2626}.data-quality{background:#fef3c7;border:1px solid #f59e0b;border-radius:10px;padding:14px 20px}.data-quality__title{color:#1e293b;margin:0 0 8px;font-size:13px;font-weight:700}.data-quality__title span{color:#64748b;font-weight:400}.data-quality__items{color:#1e293b;flex-wrap:wrap;gap:24px;font-size:13px;display:flex}.dq-num{color:#1b2a4a;cursor:pointer;font-size:15px}.dq-num:hover{text-decoration:underline}@media (width<=1200px){.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.charts-row{flex-direction:column}}@media (width<=600px){.dashboard{padding:12px}.summary-cards{grid-template-columns:1fr}.data-quality__items{flex-direction:column;gap:8px}}.panel__empty{text-align:center;color:#94a3b8;padding:32px 16px;font-size:13px}.dept-count{color:#64748b;text-align:right;min-width:30px;font-size:12px;font-weight:600}.pg{color:#64748b;background:#fff;border:1px solid #e2e8f0;border-top:none;border-radius:0 0 10px 10px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;font-size:13px;display:flex}.pg__info{align-items:center;gap:16px;display:flex}.pg__size{align-items:center;gap:6px;font-weight:500;display:flex}.pg__size select{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:4px 8px;font-size:13px}.pg__range{color:#94a3b8}.pg__controls{align-items:center;gap:4px;display:flex}.pg__btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;transition:all .15s;display:flex}.pg__btn:hover:not(:disabled){color:#1e293b;background:#f1f5f9}.pg__btn:disabled{opacity:.4;cursor:not-allowed}.pg__page{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;min-width:30px;height:30px;font-size:13px;font-weight:500;transition:all .15s}.pg__page:hover:not(:disabled):not(.pg__page--active){background:#f1f5f9}.pg__page--active{color:#fff;background:#1b2a4a;border-color:#1b2a4a}.pg__dots{color:#94a3b8;padding:0 4px}.vd-overlay{z-index:200;background:#00000059;justify-content:flex-end;display:flex;position:fixed;inset:0}.vd-panel{background:#fff;flex-direction:column;width:420px;max-width:100vw;height:100vh;animation:.22s ease-out vd-slide-in;display:flex;box-shadow:-4px 0 24px #0000001f}@keyframes vd-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.vd-header{border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.vd-header__title{color:#1e293b;margin:0;font-size:17px;font-weight:700}.vd-header__close{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.vd-header__close:hover{color:#1e293b;background:#f1f5f9}.vd-body{flex:1;padding:24px;overflow-y:auto}.vd-profile{flex-direction:column;align-items:center;gap:4px;margin-bottom:24px;display:flex}.vd-profile__avatar{color:#94a3b8;background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:6px;display:flex;overflow:hidden}.vd-profile__photo{object-fit:cover;width:100%;height:100%}.vd-profile__name{color:#1e293b;font-size:16px;font-weight:700}.vd-profile__id{color:#94a3b8;font-size:13px}.vd-details{margin:0;padding:0}.vd-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.vd-row:last-child{border-bottom:none}.vd-row--section-title dt{color:#3b5bdb;text-transform:uppercase;letter-spacing:.06em;width:100%;font-size:12px;font-weight:700}.vd-row dt{color:#64748b;font-size:13px;font-weight:500}.vd-row dd{color:#1e293b;text-align:right;margin:0;font-size:13px;font-weight:600}.vd-status{border-radius:12px;padding:2px 12px;font-size:12px;font-weight:600;display:inline-block}.vd-status--exited{color:#64748b;background:#f1f5f9}.vd-status--on-campus{color:#16a34a;background:#dcfce7}.vd-status--overstay{color:#dc2626;background:#fee2e2}.vd-status--generated{color:#2563eb;background:#eff6ff}.vd-qr{background:#f8fafc;border-radius:10px;flex-direction:column;align-items:center;gap:8px;margin-top:24px;padding:20px;display:flex}.vd-qr__img{width:120px;height:120px}.vd-qr__placeholder{background:#e2e8f0;border-radius:8px;width:120px;height:120px}.vd-qr__label{color:#94a3b8;font-size:12px;font-weight:500}.vd-footer{border-top:1px solid #e2e8f0;flex-shrink:0;gap:12px;padding:16px 24px;display:flex}.vd-footer__btn{cursor:pointer;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 0;font-size:13px;font-weight:600;transition:background .15s;display:flex}.vd-footer__btn--exit{color:#fff;background:#16a34a}.vd-footer__btn--exit:hover{background:#15803d}.vd-footer__btn--flag{color:#fff;background:#dc2626}.vd-footer__btn--flag:hover,.vd-footer__btn--flag.vd-footer__btn--flag-active{background:#b91c1c}.vd-footer__btn:disabled{opacity:.6;cursor:not-allowed}.vd-footer__error{color:#dc2626;text-align:center;width:100%;font-size:12px}.vd-spinner{animation:.7s linear infinite vd-spin}@keyframes vd-spin{to{transform:rotate(360deg)}}@media (width<=480px){.vd-panel{width:100vw}}.lv{flex-direction:column;gap:16px;display:flex}.lv__toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.lv__filters{flex-wrap:wrap;gap:12px;display:flex}.lv__filter{color:#1e293b;align-items:center;gap:6px;font-size:13px;display:flex}.lv__filter-label{white-space:nowrap;font-weight:600}.lv__filter select{color:#1e293b;cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%2364748B' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") right 10px center no-repeat;border:1px solid #e2e8f0;border-radius:6px;min-width:100px;padding:6px 28px 6px 10px;font-size:13px}.lv__filter select:focus{border-color:#1b2a4a;outline:none}.lv__export{color:#fff;cursor:pointer;white-space:nowrap;background:#dc2626;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:600;transition:background .15s;display:flex}.lv__export:hover{background:#b91c1c}.lv__table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow-x:auto}.lv__table{border-collapse:collapse;width:100%;font-size:13px}.lv__table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.lv__table th{text-align:left;color:#64748b;white-space:nowrap;text-transform:capitalize;padding:12px 16px;font-size:12px;font-weight:600}.lv__table td{color:#1e293b;white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:11px 16px}.lv__table tbody tr:last-child td{border-bottom:none}.lv__table tbody tr:hover{background:#f8fafc}.lv__name{color:#1b2a4a;font-weight:600}.lv-status{border-radius:12px;padding:3px 12px;font-size:12px;font-weight:600;line-height:1.4;display:inline-block}.lv-status--exited{color:#64748b;background:#f1f5f9}.lv-status--on-campus{color:#16a34a;background:#dcfce7}.lv-status--overstay{color:#dc2626;background:#fee2e2}.lv-status--generated{color:#2563eb;background:#eff6ff}.lv__actions{gap:8px;display:flex}.lv__btn{cursor:pointer;border:1.5px solid;border-radius:5px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:600;transition:background .15s,color .15s;display:inline-flex}.lv__btn--view{color:#2563eb;background:#eff6ff;border-color:#2563eb}.lv__btn--view:hover{color:#fff;background:#2563eb}.lv__btn--flag{color:#e8913a;background:#fff7ed;border-color:#e8913a}.lv__btn--flag:hover,.lv__btn--flag-active{color:#fff;background:#e8913a}.lv__empty{text-align:center;color:#94a3b8;font-style:italic;padding:32px 16px!important}@media (width<=768px){.lv__toolbar{flex-direction:column;align-items:stretch}.lv__export{align-self:flex-end}}.vl{flex-direction:column;gap:16px;display:flex}.vl__tabs-row{align-items:center;display:flex}.vl__tabs{gap:8px;display:flex}.vl__tab{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:20px;padding:7px 20px;font-size:13px;font-weight:600;transition:background .15s,color .15s}.vl__tab--active{color:#fff;background:#1b2a4a}.vl__tab:hover:not(.vl__tab--active){color:#1e293b;background:#e2e8f0}.vl__toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.vl__filters{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.vl__search{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:6px;width:190px;padding:7px 12px;font-size:13px}.vl__search::placeholder{color:#94a3b8}.vl__search:focus{border-color:#1b2a4a;outline:none}.vl__filter{color:#1e293b;align-items:center;gap:6px;font-size:13px;display:flex}.vl__filter-label{white-space:nowrap;font-weight:600}.vl__filter select{color:#1e293b;cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%2364748B' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") right 10px center no-repeat;border:1px solid #e2e8f0;border-radius:6px;min-width:80px;padding:6px 28px 6px 10px;font-size:13px}.vl__filter select:focus{border-color:#1b2a4a;outline:none}.vl__time-ranges{gap:0;display:flex}.vl__time-btn{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;padding:6px 14px;font-size:12px;font-weight:600;transition:background .15s,color .15s}.vl__time-btn:first-child{border-radius:6px 0 0 6px}.vl__time-btn:last-child{border-radius:0 6px 6px 0}.vl__time-btn:not(:first-child){border-left:none}.vl__time-btn--active{color:#fff;background:#1b2a4a;border-color:#1b2a4a}.vl__time-btn--active+.vl__time-btn{border-left:none}.vl__time-btn:hover:not(.vl__time-btn--active){background:#f1f5f9}.vl__date-picker{color:#1e293b;border:1px solid #e2e8f0;border-radius:6px;padding:6px 12px;font-size:13px}.vl__export{color:#fff;cursor:pointer;white-space:nowrap;background:#dc2626;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:600;transition:background .15s;display:flex}.vl__export:hover{background:#b91c1c}.vl__table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow-x:auto}.vl__table{border-collapse:collapse;width:100%;font-size:13px}.vl__table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.vl__table th{text-align:left;color:#64748b;white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:600}.vl__table td{color:#1e293b;white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:11px 16px}.vl__table tbody tr:last-child td{border-bottom:none}.vl__table tbody tr:hover{background:#f8fafc}.vl__name{color:#1b2a4a;font-weight:600}.vl__id{color:#64748b}.vl__status-badge{border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;line-height:1.4;display:inline-flex}.vl__status-badge--overstay{color:#dc2626;background:#fee2e2}.vl__status-badge--campus{color:#16a34a;background:#dcfce7}.vl__status-badge--exited{color:#475569;background:#e2e8f0}.vl__form-fault{color:#64748b}.vl__empty{text-align:center;color:#94a3b8;font-style:italic;padding:32px 16px!important}@media (width<=768px){.vl__toolbar,.vl__filters{flex-direction:column;align-items:stretch}.vl__search{width:100%}.vl__export{align-self:flex-end}.vl__time-ranges{flex-wrap:wrap}}.visitor-exit{padding:0}.visitor-exit__tabs{gap:8px;margin-bottom:24px;display:flex}.visitor-exit__tab{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.visitor-exit__tab--active{color:#fff;background:#1b2a4a;border-color:#1b2a4a}.visitor-exit__qr-panel{justify-content:center;padding:32px 0;display:flex}.visitor-exit__camera-placeholder{color:#94a3b8;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:12px;width:360px;height:320px;display:flex}.visitor-exit__camera-placeholder p{color:#64748b;margin:0;font-size:14px;font-weight:500}.visitor-exit__camera-note{color:#94a3b8;font-size:12px}.visitor-exit__manual-panel{max-width:600px}.visitor-exit__search-row{gap:10px;margin-bottom:20px;display:flex}.visitor-exit__search-group{background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex:1;align-items:center;display:flex}.visitor-exit__search-prefix{color:#64748b;white-space:nowrap;padding:10px 0 10px 12px;font-size:13px;font-weight:600}.visitor-exit__search-input{color:#1e293b;border:none;outline:none;flex:1;min-width:120px;padding:10px 14px;font-size:14px;transition:box-shadow .15s}.visitor-exit__search-group:focus-within{border-color:#1b2a4a;box-shadow:0 0 0 1px #1b2a4a}.visitor-exit__search-help{color:#64748b;margin:-10px 0 14px;font-size:12px}.visitor-exit__search-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#1b2a4a;border:none;border-radius:8px;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:500;transition:background .15s;display:flex}.visitor-exit__search-btn:hover{background:#162240}.visitor-exit__search-btn:disabled{opacity:.6;cursor:not-allowed}.visitor-exit__error{color:#dc2626;margin:0 0 16px;font-size:13px;font-weight:500}.visitor-exit__success{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}.visitor-exit__result{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.visitor-exit__result-header{align-items:center;gap:14px;margin-bottom:20px;display:flex}.visitor-exit__result-avatar{color:#fff;background:#1b2a4a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;font-weight:600;display:flex}.visitor-exit__result-name{color:#1e293b;margin:0;font-size:16px;font-weight:600}.visitor-exit__result-pass{color:#64748b;font-size:13px}.visitor-exit__status-badge{white-space:nowrap;border-radius:20px;margin-left:auto;padding:4px 12px;font-size:12px;font-weight:600}.visitor-exit__status-badge--active{color:#15803d;background:#dcfce7}.visitor-exit__status-badge--inactive{color:#92400e;background:#fef3c7}.visitor-exit__status-badge--expired{color:#991b1b;background:#fee2e2}.visitor-exit__details-grid{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px;display:grid}.visitor-exit__detail-item{align-items:flex-start;gap:8px;display:flex}.visitor-exit__detail-icon{color:#94a3b8;margin-top:2px}.visitor-exit__detail-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1px;font-size:11px;display:block}.visitor-exit__detail-value{color:#1e293b;font-size:14px;font-weight:500;display:block}.visitor-exit__actions{gap:10px;display:flex}.visitor-exit__lifecycle-message{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;width:100%;padding:10px 12px;font-size:13px;font-weight:500}.visitor-exit__action-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .15s;display:flex}.visitor-exit__action-btn:disabled{opacity:.6;cursor:not-allowed}.visitor-exit__action-btn--exit{color:#fff;background:#dc2626}.visitor-exit__action-btn--exit:hover:not(:disabled){background:#b91c1c}.visitor-exit__action-btn--enter{color:#fff;background:#16a34a}.visitor-exit__action-btn--enter:hover:not(:disabled){background:#15803d}@keyframes exit-spin{to{transform:rotate(360deg)}}.visitor-exit .spin{animation:.8s linear infinite exit-spin}
