@import"https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:wght@300;400;500;600&family=JetBrains+Mono:wght@400;700&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";.lsw-compact{display:flex;align-items:center;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:8px;overflow:hidden;padding:2px;gap:1px}.lsw-compact__btn{display:flex;align-items:center;gap:4px;padding:4px 9px;border:none;background:transparent;color:var(--tx3, #94a3b8);font-size:11px;font-weight:700;cursor:pointer;border-radius:6px;transition:all .15s;font-family:inherit;letter-spacing:.3px;white-space:nowrap}.lsw-compact__btn:hover{color:var(--tx1, #0f172a);background:var(--bg-card, #fff)}.lsw-compact__btn--active{background:var(--primary, #2563eb)!important;color:#fff!important;box-shadow:0 1px 4px #2563eb4d}.lsw-compact__sep{width:1px;height:14px;background:var(--border, #e2e8f0);flex-shrink:0}[data-theme=dark] .lsw-compact{background:#ffffff0d;border-color:#ffffff1a}[data-theme=dark] .lsw-compact__btn:hover{background:#ffffff14;color:#e2e8f0}[data-theme=dark] .lsw-compact__sep{background:#ffffff1a}.lsw-drop{position:relative}.lsw-drop__trigger{display:flex;align-items:center;gap:6px;padding:6px 11px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:12px;font-weight:600;cursor:pointer;transition:all .18s;font-family:inherit}.lsw-drop__trigger:hover,.lsw-drop__trigger--open{border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);background:var(--primary-light, #eff6ff)}.lsw-drop__label{white-space:nowrap}.lsw-drop__chevron{transition:transform .2s;color:var(--tx3, #94a3b8)}.lsw-drop__chevron--open{transform:rotate(-180deg)}.lsw-drop__menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:12px;box-shadow:0 12px 32px -4px #00000024,0 4px 12px #0000000d;min-width:180px;z-index:2000;overflow:hidden;animation:lsw-drop-in .18s cubic-bezier(.4,0,.2,1)}@keyframes lsw-drop-in{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:none}}.lsw-drop__item{display:flex;align-items:center;gap:10px;padding:11px 14px;width:100%;border:none;background:transparent;cursor:pointer;transition:background .12s;text-align:left;font-family:inherit}.lsw-drop__item:hover{background:var(--bg-input, #f8fafc)}.lsw-drop__item--active{background:var(--primary-light, #eff6ff)}.lsw-drop__flag{font-size:18px;flex-shrink:0}.lsw-drop__text{flex:1;min-width:0}.lsw-drop__native{display:block;font-size:13px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.3}.lsw-drop__english{display:block;font-size:11px;color:var(--tx3, #94a3b8);margin-top:1px}.lsw-drop__item--active .lsw-drop__native{color:var(--primary, #2563eb)}.lsw-drop__check{color:var(--primary, #2563eb);flex-shrink:0}[data-theme=dark] .lsw-drop__trigger,[data-theme=dark] .lsw-drop__menu{background:#1e293b;border-color:#ffffff14}[data-theme=dark] .lsw-drop__trigger:hover,[data-theme=dark] .lsw-drop__trigger--open{background:#2563eb26;border-color:#2563eb80}[data-theme=dark] .lsw-drop__item:hover{background:#ffffff0d}[data-theme=dark] .lsw-drop__item--active{background:#2563eb26}[data-theme=dark] .lsw-drop__native{color:#e2e8f0}.lsw-inline{display:flex;gap:10px;flex-wrap:wrap}.lsw-inline__btn{flex:1;min-width:140px;display:flex;align-items:center;gap:10px;padding:14px 16px;border-radius:12px;border:2px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);cursor:pointer;transition:all .18s;text-align:left;font-family:inherit;position:relative}.lsw-inline__btn:hover,.lsw-inline__btn--active{border-color:var(--primary, #2563eb);background:var(--primary-light, #eff6ff)}.lsw-inline__flag{font-size:24px;flex-shrink:0}.lsw-inline__text{flex:1;min-width:0}.lsw-inline__native{display:block;font-size:14px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.3}.lsw-inline__btn--active .lsw-inline__native{color:var(--primary, #2563eb)}.lsw-inline__sub{display:block;font-size:11px;color:var(--tx3, #94a3b8);margin-top:2px}.lsw-inline__dot{position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--primary, #2563eb)}[data-theme=dark] .lsw-inline__btn{background:#1e293b;border-color:#ffffff14}[data-theme=dark] .lsw-inline__btn:hover,[data-theme=dark] .lsw-inline__btn--active{background:#2563eb26;border-color:#2563eb66}[data-theme=dark] .lsw-inline__native{color:#e2e8f0}.sg-header{display:flex;align-items:center;justify-content:space-between;height:var(--hdr-h, 60px);padding:0 20px;background:var(--hdr-bg, #fff);border-bottom:1px solid var(--hdr-border, #e2e8f0);flex-shrink:0;z-index:100;gap:12px;font-family:Plus Jakarta Sans,system-ui,sans-serif;transition:background .25s,border-color .25s}.sg-header__left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.sg-header__menu-btn{width:36px;height:36px;border-radius:8px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .18s}.sg-header__menu-btn:hover{background:var(--bg-input, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.sg-header__breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;overflow:hidden}.sg-header__breadcrumb-home{color:var(--tx3, #94a3b8);font-weight:500;white-space:nowrap}.sg-header__breadcrumb-current{font-weight:700;color:var(--tx1, #0f172a);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sg-header__right{display:flex;align-items:center;gap:8px;flex-shrink:0}.sg-header__status{display:flex;align-items:center;gap:5px;background:#22c55e1a;border:1px solid rgba(34,197,94,.25);color:#16a34a;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700}.sg-header__status-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:sg-hdr-pulse 2s ease-in-out infinite}@keyframes sg-hdr-pulse{0%,to{opacity:1}50%{opacity:.35}}.sg-header__status-lbl{white-space:nowrap}.sg-header__clock{font-family:DM Mono,monospace;font-size:13px;font-weight:500;color:var(--tx2, #475569);background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:8px;padding:5px 11px;letter-spacing:.3px;white-space:nowrap}.sg-header__icon-btn{width:36px;height:36px;border-radius:8px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s}.sg-header__icon-btn:hover{background:var(--bg-input, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.sg-header__user{position:relative}.sg-header__user-btn{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border:1.5px solid transparent;border-radius:10px;background:transparent;cursor:pointer;transition:all .18s;font-family:inherit}.sg-header__user-btn:hover{background:var(--bg-input, #f1f5f9);border-color:var(--border, #e2e8f0)}.sg-header__user-btn--open{background:var(--bg-input, #f1f5f9);border-color:var(--primary, #2563eb)}.sg-header__avatar{width:34px;height:34px;border-radius:50%;color:#fff;font-weight:800;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:-.5px}.sg-header__user-text{display:flex;flex-direction:column;align-items:flex-start}.sg-header__user-name{font-size:12px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2;white-space:nowrap}.sg-header__user-role{font-size:10px;color:var(--tx3, #94a3b8);white-space:nowrap}.sg-header__user-chevron{color:var(--tx3, #94a3b8);transition:transform .2s;flex-shrink:0}.sg-header__user-chevron--open{transform:rotate(-180deg)}.sg-header__dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;box-shadow:0 16px 40px -8px #00000029,0 4px 16px #0000000f;width:220px;z-index:1000;overflow:hidden;animation:sg-dropdown-in .18s cubic-bezier(.4,0,.2,1);font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes sg-dropdown-in{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:none}}.sg-header__dropdown-header{display:flex;align-items:center;gap:10px;padding:14px 14px 12px}.sg-header__dropdown-avatar{width:38px;height:38px;border-radius:50%;color:#fff;font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sg-header__dropdown-name{font-size:13px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.3}.sg-header__dropdown-email{font-size:11px;color:var(--tx3, #94a3b8);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sg-header__dropdown-divider{height:1px;background:var(--border, #e2e8f0);margin:2px 0}.sg-header__dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 14px;width:100%;background:none;border:none;color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;transition:background .12s;text-align:left;font-family:inherit}.sg-header__dropdown-item:hover{background:var(--bg-input, #f8fafc)}.sg-header__dropdown-item--danger{color:#dc2626}.sg-header__dropdown-item--danger:hover{background:#fff5f5}@media(max-width:1023px){.sg-header{padding:0 16px}.sg-header__status-lbl{display:none}}@media(max-width:767px){.sg-header{padding:0 14px;gap:8px}.sg-header__clock,.sg-header__user-text,.sg-header__user-chevron{display:none}.sg-header__status{padding:4px 8px}.sg-header__breadcrumb-home{display:none}}[data-theme=dark] .sg-header{background:#0f172a;border-color:#ffffff0f}[data-theme=dark] .sg-header__menu-btn,[data-theme=dark] .sg-header__icon-btn,[data-theme=dark] .sg-header__clock{background:#ffffff0a;border-color:#ffffff1a;color:#94a3b8}[data-theme=dark] .sg-header__menu-btn:hover,[data-theme=dark] .sg-header__icon-btn:hover{background:#ffffff1a;color:#e2e8f0}[data-theme=dark] .sg-header__clock{color:#64748b}[data-theme=dark] .sg-header__user-btn:hover,[data-theme=dark] .sg-header__user-btn--open{background:#ffffff0f;border-color:#ffffff1a}[data-theme=dark] .sg-header__user-name,[data-theme=dark] .sg-header__breadcrumb-current{color:#e2e8f0}[data-theme=dark] .sg-header__dropdown{background:#1e293b;border-color:#ffffff14}[data-theme=dark] .sg-header__dropdown-item:hover{background:#ffffff0d;color:#e2e8f0}[data-theme=dark] .sg-header__dropdown-name{color:#e2e8f0}[data-theme=dark] .sg-header__dropdown-divider{background:#ffffff0f}.sg-sidebar{width:var(--sb-w, 260px);background:#0f172a;display:flex;flex-direction:column;height:100vh;position:fixed;left:0;top:0;z-index:950;overflow:hidden;transition:width var(--transition, .25s cubic-bezier(.4, 0, .2, 1));border-right:1px solid rgba(255,255,255,.06);box-shadow:inset -1px 0 #ffffff0a}.sg-sidebar--collapsed{width:var(--sb-rail, 64px)}@media(max-width:1023px){.sg-sidebar{transform:translate(-100%);transition:transform var(--transition, .25s cubic-bezier(.4, 0, .2, 1));width:272px!important}.sg-sidebar--mobile-open{transform:translate(0);box-shadow:8px 0 32px #0006}}.sg-sb-brand{display:flex;align-items:center;justify-content:space-between;padding:0 12px;height:60px;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.06);gap:4px}.sg-sb-brand__logo{display:flex;align-items:center;gap:10px;text-decoration:none;overflow:hidden;flex:1;min-width:0}.sg-sb-brand__icon{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #2563eb59}.sg-sb-brand__text{display:flex;flex-direction:column;overflow:hidden;transition:opacity var(--transition, .25s),width var(--transition, .25s)}.sg-sidebar--collapsed .sg-sb-brand__text{opacity:0;width:0;pointer-events:none}.sg-sb-brand__name{font-size:16px;font-weight:800;color:#fff;letter-spacing:-.4px;white-space:nowrap}.sg-sb-brand__sub{font-size:9px;color:#64748b;text-transform:uppercase;letter-spacing:.8px;margin-top:1px;white-space:nowrap}.sg-sb-collapse-btn{width:28px;height:28px;border-radius:7px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .18s}.sg-sb-collapse-btn:hover{background:#ffffff1a;color:#e2e8f0}.sg-sb-close-btn{width:32px;height:32px;border-radius:8px;border:none;background:#ffffff0f;color:#94a3b8;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s;flex-shrink:0}.sg-sb-close-btn:hover{background:#ffffff1f;color:#fff}.sg-sb-user{display:flex;align-items:center;gap:10px;padding:12px 14px;margin:8px 8px 0;border-radius:10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);overflow:hidden;flex-shrink:0}.sg-sb-user__avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sg-sb-user__info{flex:1;min-width:0;overflow:hidden}.sg-sb-user__name{display:block;font-size:12px;font-weight:700;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sg-sb-user__role{display:block;font-size:10px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sg-sb-user__dot{width:8px;height:8px;border-radius:50%;background:#22c55e;flex-shrink:0;box-shadow:0 0 0 2px #22c55e33;animation:sg-pulse-dot 2s ease-in-out infinite}@keyframes sg-pulse-dot{0%,to{box-shadow:0 0 0 2px #22c55e33}50%{box-shadow:0 0 0 5px #22c55e0d}}.sg-sb-nav{flex:1;padding:8px;overflow-y:auto;overflow-x:hidden}.sg-sb-nav::-webkit-scrollbar{width:3px}.sg-sb-nav::-webkit-scrollbar-track{background:transparent}.sg-sb-nav::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.sg-nav-group{margin-bottom:4px}.sg-nav-section-lbl{font-size:9.5px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:1px;padding:12px 10px 5px;white-space:nowrap;overflow:hidden}.sg-nav-divider{height:1px;margin:8px;background:#ffffff0f}.sg-nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;color:#94a3b8;text-decoration:none;transition:all .18s;margin-bottom:1px;position:relative;cursor:pointer;border:none;background:none;width:100%;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden}.sg-nav-item:hover{background:#ffffff0f;color:#e2e8f0}.sg-nav-item--active{background:#2563eb26;color:#60a5fa}.sg-nav-item--active:hover{background:#2563eb33}.sg-nav-item--active-parent{background:#ffffff0a;color:#e2e8f0}.sg-nav-item__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:18px}.sg-nav-item__label{overflow:hidden;text-overflow:ellipsis;transition:opacity var(--transition, .25s)}.sg-nav-item--active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:#2563eb;border-radius:0 3px 3px 0}.sg-nav-item__pip{width:5px;height:5px;border-radius:50%;background:#2563eb;margin-left:auto;flex-shrink:0}.sg-sidebar--collapsed .sg-nav-item{padding:10px;justify-content:center}.sg-sidebar--collapsed .sg-nav-item__label,.sg-sidebar--collapsed .sg-nav-item__pip,.sg-sidebar--collapsed .sg-nav-section-lbl{display:none}.sg-sidebar--collapsed .sg-nav-divider{margin:6px 4px}.sg-sb-tooltip-wrap{position:relative;display:block}.sg-sb-tooltip{position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:#1e293b;color:#e2e8f0;font-size:12px;font-weight:600;padding:6px 10px;border-radius:7px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s,transform .15s;transform:translateY(-50%) translate(-4px);z-index:9999;box-shadow:0 4px 12px #00000059;border:1px solid rgba(255,255,255,.08)}.sg-sb-tooltip:before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:5px solid transparent;border-right-color:#1e293b}.sg-sb-tooltip-wrap:hover .sg-sb-tooltip{opacity:1;transform:translateY(-50%) translate(0)}.sg-nav-sub{position:relative}.sg-nav-sub__trigger{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;color:#94a3b8;background:none;border:none;cursor:pointer;width:100%;font-size:13px;font-weight:500;transition:all .18s;white-space:nowrap}.sg-nav-sub__trigger:hover{background:#ffffff0f;color:#e2e8f0}.sg-nav-sub__trigger--open{background:#ffffff0a;color:#e2e8f0}.sg-nav-sub__arrow{margin-left:auto;display:flex;align-items:center}.sg-nav-sub__content{padding-left:14px;margin-top:2px;animation:sg-slide-down .2s ease}@keyframes sg-slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.sg-nav-sub__item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:7px;color:#64748b;text-decoration:none;font-size:12px;font-weight:500;transition:all .15s;margin-bottom:1px;white-space:nowrap;overflow:hidden}.sg-nav-sub__item:hover{background:#ffffff0f;color:#e2e8f0}.sg-nav-sub__item--active{background:#2563eb26;color:#60a5fa}.sg-nav-sub__icon{flex-shrink:0;opacity:.7}.sg-nav-sub__item--active .sg-nav-sub__icon{opacity:1}.sg-nav-item--config{justify-content:center;padding:10px}.sg-sb-foot{padding:12px 8px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;display:flex;flex-direction:column;gap:6px}.sg-sb-logout{display:flex;align-items:center;gap:10px;padding:9px 12px;width:100%;border-radius:8px;border:1px solid rgba(220,38,38,.2);background:#dc262614;color:#f87171;cursor:pointer;font-size:13px;font-weight:600;transition:all .18s}.sg-sb-logout:hover{background:#dc262626;color:#ef4444;border-color:#dc26264d}.sg-sb-logout--icon{justify-content:center;padding:9px;width:100%}.sg-sb-version{font-size:10px;color:#334155;text-align:center;letter-spacing:.3px;white-space:nowrap;overflow:hidden}.sg-sidebar--collapsed .sg-sb-version{display:none}.sg-sidebar--collapsed .sg-sb-foot{padding:10px 6px}[data-theme=dark] .sg-sidebar{background:#0a0f1a}@media(prefers-reduced-motion:reduce){.sg-sidebar,.sg-nav-item,.sg-sb-collapse-btn,.sg-nav-sub__content,.sg-sb-tooltip{transition:none;animation:none}}.footer{height:var(--ftr-h, 46px);background:var(--ftr-bg, #ffffff);border-top:1px solid var(--ftr-border, #e2e8f0);display:flex;align-items:center;justify-content:space-between;padding:0 24px;font-size:12px;color:var(--tx3, #94a3b8);transition:background .25s,border-color .25s;width:100%}.footer-left,.footer-right{display:flex;align-items:center;gap:12px}.ftr-dot{color:var(--border, #e2e8f0)}.ftr-version{background:var(--bg, #f1f5f9);border:1px solid var(--border, #e2e8f0);border-radius:20px;padding:1px 9px;font-size:11px;font-weight:700}@media(max-width:768px){.footer{padding:0 16px}.footer-right{display:none}}.toast-stack{position:fixed;bottom:58px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:13px 18px;border-radius:var(--radius, 10px);box-shadow:var(--shadow-lg, 0 8px 30px rgba(0,0,0,.14));font-size:14px;font-weight:500;pointer-events:all;min-width:280px;max-width:360px;animation:toast-in .3s ease}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.toast.success{background:#16a34a;color:#fff}.toast.danger{background:#dc2626;color:#fff}.toast.warning{background:#d97706;color:#fff}.toast.info{background:#2563eb;color:#fff}.sg-shell{display:flex;height:100vh;width:100vw;overflow:hidden;background:var(--bg, #f1f5f9);--sb-w: 260px;--sb-rail: 64px;--hdr-h: 60px;--ftr-h: 44px;--transition: .25s cubic-bezier(.4, 0, .2, 1)}.sg-shell--collapsed{--sb-w: var(--sb-rail)}.sg-main{display:flex;flex-direction:column;flex:1;min-width:0;height:100vh;overflow:hidden;transition:margin-left var(--transition)}.sg-content{flex:1;overflow-y:auto;background:var(--bg, #f1f5f9);scroll-behavior:smooth}.sg-content::-webkit-scrollbar{width:5px}.sg-content::-webkit-scrollbar-track{background:transparent}.sg-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.sg-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.sg-content-inner{padding:24px;min-height:calc(100% - var(--ftr-h))}.sg-mobile-backdrop{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:900;animation:sg-fade-in .2s ease}.sg-loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;background:var(--bg, #f1f5f9);font-family:Plus Jakarta Sans,system-ui,sans-serif;color:var(--tx3, #94a3b8);font-size:14px}.sg-loading-ring{width:44px;height:44px;border:3px solid rgba(37,99,235,.15);border-top-color:#2563eb;border-radius:50%;animation:sg-spin .7s linear infinite}@media(min-width:1024px){.sg-main{margin-left:var(--sb-w)}}@media(max-width:1023px){.sg-content-inner{padding:20px}}@media(max-width:767px){.sg-content-inner{padding:16px}}:root{--font: "Plus Jakarta Sans arial", system-ui, sans-serif;--font-mono: "DM Mono", "Fira Mono", monospace;--bg: #f1f5f9;--bg-card: #ffffff;--bg-input: #f8fafc;--bg-hover: #f1f5f9;--border: #e2e8f0;--border-focus: #2563eb;--tx1: #0f172a;--tx2: #475569;--tx3: #94a3b8;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: #dbeafe;--success: #16a34a;--success-light: #dcfce7;--success-border: #bbf7d0;--danger: #dc2626;--danger-light: #fee2e2;--danger-border: #fecaca;--warning: #d97706;--warning-light: #fef3c7;--warning-border: #fde68a;--info: #0284c7;--info-light: #e0f2fe;--info-border: #bae6fd;--radius-sm: 6px;--radius: 10px;--radius-lg: 8px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow: 0 2px 10px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .14);--bg-image: url(/images/smart-bg.png)}body{font-family:var(--font);color:var(--tx1);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;transition:background .25s,color .25s}button{cursor:pointer;font-family:var(--font)}input{font-family:var(--font)}@keyframes lgn-spin{to{transform:rotate(360deg)}}@keyframes lgn-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes lgn-fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes lgn-fade-in{0%{opacity:0}to{opacity:1}}@keyframes lgn-success-pop{0%{transform:scale(.7);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.lgn-root{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;font-family:var(--font);color:var(--tx1);padding:16px}.lgn-backdrop{position:fixed;inset:0;background-image:var(--bg-image);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}.lgn-backdrop:after{content:"";position:absolute;inset:0;background:#000000a6;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:background .3s}[data-theme=dark] .lgn-backdrop:after{background:#000000bf}.lgn-main{position:relative;z-index:2;width:100%;max-width:440px;display:flex;flex-direction:column;align-items:center;justify-content:center}.lgn-main__controls{position:absolute;top:20px;right:20px;display:flex;align-items:center;gap:8px;z-index:10}.lgn-icon-btn{width:34px;height:34px;border-radius:var(--radius-sm);border:1.5px solid rgba(255,255,255,.3);background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;display:flex;align-items:center;justify-content:center;transition:all .15s;cursor:pointer}.lgn-icon-btn:hover{border-color:var(--primary);background:#2563eb99;color:#fff}.lgn-main__controls .language-switcher{background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-color:#ffffff4d}.lgn-main__controls .language-switcher button{color:#fff}.lgn-main__controls .language-switcher button:hover{background:#ffffff26}.lgn-card{width:100%;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);overflow:hidden;position:relative;animation:lgn-fade-up .4s ease both}.lgn-bar{height:3px;background:var(--border);width:100%;overflow:hidden}.lgn-bar__fill{height:100%;background:linear-gradient(90deg,var(--primary),#60a5fa);border-radius:0 2px 2px 0;transition:width .25s ease}.lgn-bar--done .lgn-bar__fill{background:linear-gradient(90deg,var(--success),#34d399)}.lgn-header{display:flex;align-items:center;justify-content:center;gap:10px;padding:28px 28px 0}.lgn-header__logo{width:36px;height:36px;border-radius:10px;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #2563eb4d}.lgn-header__wordmark{font-size:20px;font-weight:700;color:var(--tx1);letter-spacing:-.3px}.lgn-panel{padding:28px 28px 24px;animation:lgn-fade-in .25s ease both}.lgn-panel--center{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:40px 28px}.lgn-shake{animation:lgn-shake .55s ease}.lgn-card__hdr{margin-bottom:22px}.lgn-card__title{font-size:20px;font-weight:700;color:var(--tx1);letter-spacing:-.3px;margin-bottom:4px}.lgn-card__sub{font-size:13px;color:var(--tx2);line-height:1.5}.lgn-card__foot{display:flex;align-items:center;justify-content:center;gap:5px;font-size:11px;color:var(--tx3);padding:12px 28px;border-top:1px solid var(--border);background:var(--bg-input)}.lgn-panel-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.lgn-panel-icon--primary{background:var(--primary-light);color:var(--primary)}.lgn-alert{display:flex;align-items:flex-start;gap:7px;font-size:13px;border-radius:var(--radius-sm);padding:9px 12px;margin-bottom:16px;line-height:1.45}.lgn-alert--error{color:var(--danger);background:var(--danger-light);border:1px solid var(--danger-border)}.lgn-alert--success{color:var(--success);background:var(--success-light);border:1px solid var(--success-border)}.lgn-alert--warning{color:var(--warning);background:var(--warning-light);border:1px solid var(--warning-border)}.lgn-alert svg{flex-shrink:0;margin-top:2px}.lgn-form{display:flex;flex-direction:column;gap:16px}.lgn-field{display:flex;flex-direction:column;gap:5px}.lgn-field__lbl{font-size:12px;font-weight:600;color:var(--tx2);letter-spacing:.1px}.lgn-field__msg{display:flex;align-items:center;gap:4px;font-size:11px;margin-top:2px}.lgn-field__msg--err{color:var(--danger)}.lgn-field__msg--hint{color:var(--tx3)}.lgn-field--err .lgn-inp{border-color:var(--danger);background:var(--danger-light)}.lgn-field--err .lgn-inp:focus{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-light)}.lgn-inp-wrap{position:relative;display:flex;align-items:center}.lgn-inp-icon{position:absolute;left:11px;color:var(--tx3);pointer-events:none;flex-shrink:0}.lgn-inp-ok{position:absolute;right:11px;color:var(--success);pointer-events:none}.lgn-inp{width:100%;height:40px;padding:0 12px 0 36px;background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--tx1);font-size:14px;font-family:var(--font);outline:none;transition:border-color .15s,box-shadow .15s,background .15s}.lgn-inp:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-light);background:var(--bg-card)}.lgn-inp::placeholder{color:var(--tx3)}.lgn-inp:disabled{opacity:.6;cursor:not-allowed}.lgn-inp--pwd{padding-right:40px}.lgn-inp--err{border-color:var(--danger);background:var(--danger-light)}.lgn-inp--err:focus{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-light)}.lgn-eye{position:absolute;right:10px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:4px;border:none;background:transparent;color:var(--tx3);transition:color .15s,background .15s;cursor:pointer}.lgn-eye:hover{color:var(--tx2);background:var(--bg-hover)}.lgn-caps{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--warning);margin-top:3px}.lgn-strength{margin-top:6px}.lgn-strength__bars{display:flex;gap:4px;margin-bottom:4px}.lgn-strength__bar{flex:1;height:3px;border-radius:2px;transition:background .2s}.lgn-strength__label{font-size:11px;font-weight:600}.lgn-match-ok{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--success);margin-top:3px}.lgn-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.lgn-check{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--tx2);cursor:pointer;-webkit-user-select:none;user-select:none}.lgn-check input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.lgn-link{background:none;border:none;padding:0;font-size:12px;font-weight:600;color:var(--primary);cursor:pointer;transition:color .15s}.lgn-link:hover{color:var(--primary-hover);text-decoration:underline}.lgn-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;height:42px;padding:0 18px;background:var(--primary);color:#fff;border:1.5px solid transparent;border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .15s,box-shadow .15s,opacity .15s;white-space:nowrap;margin-top:4px}.lgn-btn:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 14px #2563eb59}.lgn-btn:active:not(:disabled){transform:translateY(1px)}.lgn-btn:disabled{opacity:.55;cursor:not-allowed}.lgn-btn--ghost{background:transparent;color:var(--tx2);border-color:var(--border)}.lgn-btn--ghost:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-focus);color:var(--primary);box-shadow:none}.lgn-spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:lgn-spin .65s linear infinite;flex-shrink:0}.lgn-btn--ghost .lgn-spin{border-color:#00000026;border-top-color:var(--tx2)}.lgn-back{display:inline-flex;align-items:center;gap:5px;background:none;border:none;padding:0;font-size:12px;font-weight:600;color:var(--tx2);cursor:pointer;margin-bottom:20px;transition:color .15s}.lgn-back:hover{color:var(--primary)}.lgn-back:disabled{opacity:.5;cursor:not-allowed}.lgn-success-ring{width:68px;height:68px;border-radius:50%;background:var(--success-light);border:2px solid var(--success-border);display:flex;align-items:center;justify-content:center;margin-bottom:4px;animation:lgn-success-pop .45s cubic-bezier(.34,1.56,.64,1) both}.lgn-hint-text{font-size:12px;color:var(--tx3);line-height:1.55;max-width:300px}.lgn-panel-actions{display:flex;flex-direction:column;gap:8px;width:100%;margin-top:4px}@media(max-width:768px){.lgn-main{max-width:100%;padding:0}.lgn-main__controls{top:16px;right:16px}.lgn-card{border-radius:var(--radius);margin:0 8px}.lgn-panel{padding:20px 20px 18px}.lgn-header{padding:20px 20px 0}}@media(max-width:480px){.lgn-panel{padding:18px 16px}.lgn-card__title{font-size:18px}.lgn-main__controls{gap:6px}.lgn-icon-btn{width:30px;height:30px}}.dsh-root{min-height:100vh;background:#f0f4f9;background-image:radial-gradient(ellipse 80% 40% at 50% 0%,rgba(219,234,254,.6) 0%,transparent 60%),radial-gradient(ellipse 40% 30% at 95% 90%,rgba(237,233,254,.4) 0%,transparent 50%);padding:0;font-family:Plus Jakarta Sans,system-ui,sans-serif;color:#0f172a}.dsh-loading{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:#f0f4f9}.dsh-loading__spinner{width:32px;height:32px;border:2px solid rgba(37,99,235,.15);border-top-color:#2563eb;border-radius:50%;animation:dsh-spin .7s linear infinite}.dsh-loading__text{font-size:13px;color:#94a3b8;font-family:DM Mono,monospace;letter-spacing:.05em}@keyframes dsh-spin{to{transform:rotate(360deg)}}.dsh-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:100;gap:16px;flex-wrap:wrap;box-shadow:0 1px 4px #0f172a0f}.dsh-header__left{display:flex;flex-direction:column;gap:4px}.dsh-header__brand{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;letter-spacing:-.2px}.dsh-brand-icon{width:26px;height:26px;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 8px #2563eb40}.dsh-brand-name{color:#0f172a;font-weight:800}.dsh-brand-sep{color:#cbd5e1}.dsh-brand-page{color:#64748b;font-weight:500;font-size:13px}.dsh-header__ts{display:flex;align-items:center;gap:8px;font-size:11px;color:#94a3b8;font-family:DM Mono,monospace}.dsh-header__date{color:#cbd5e1;padding-left:8px;border-left:1px solid #e2e8f0}.dsh-header__right{display:flex;gap:8px;align-items:center}.dsh-refresh-btn{width:34px;height:34px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 1px 3px #0f172a0f}.dsh-refresh-btn:hover{background:#f1f5f9;color:#0f172a;border-color:#cbd5e1}.dsh-refresh-btn--spinning svg{animation:dsh-spin .8s linear infinite}.dsh-cta-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;transition:all .18s;border:1px solid #e2e8f0;background:#fff;color:#475569;font-family:inherit;white-space:nowrap;box-shadow:0 1px 3px #0f172a0f}.dsh-cta-btn:hover{background:#f8fafc;color:#0f172a;border-color:#cbd5e1}.dsh-cta-btn--primary{background:#2563eb;border-color:#2563eb;color:#fff;box-shadow:0 2px 8px #2563eb40}.dsh-cta-btn--primary:hover{background:#1d4ed8;border-color:#1d4ed8;box-shadow:0 4px 12px #2563eb59}.dsh-pulse{position:relative;display:inline-flex;align-items:center;justify-content:center;width:10px;height:10px;flex-shrink:0}.dsh-pulse__ring{position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--pulse-color, #10b981);opacity:0;animation:dsh-pulse-ring 2s ease-out infinite}.dsh-pulse__dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}@keyframes dsh-pulse-ring{0%{transform:scale(.8);opacity:.8}to{transform:scale(2);opacity:0}}.dsh-kpi-strip{display:grid;grid-template-columns:repeat(8,1fr);gap:1px;background:#e2e8f0;border-bottom:1px solid #e2e8f0}.dsh-kpi-card{background:#fff;padding:16px 16px 14px;position:relative;overflow:hidden;transition:background .2s,box-shadow .2s;animation:dsh-card-in .4s ease both}.dsh-kpi-card:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--k-color, #2563eb);transform:scaleX(0);transform-origin:left;transition:transform .6s cubic-bezier(.4,0,.2,1)}.dsh-kpi-card--clickable{cursor:pointer}.dsh-kpi-card--clickable:hover{background:#f8fafc;box-shadow:inset 0 -2px 0 var(--k-color, #2563eb)}.dsh-kpi-card--clickable:hover:after{transform:scaleX(1)}.dsh-kpi-card--urgent{background:#fff5f5}.dsh-kpi-card--urgent:after{transform:scaleX(1)}.dsh-kpi-card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.dsh-kpi-card__icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center}.dsh-kpi-card__val{font-family:DM Mono,monospace;font-size:24px;font-weight:500;letter-spacing:-1.5px;line-height:1;margin-bottom:3px}.dsh-kpi-card__lbl{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.6px;margin-bottom:2px}.dsh-kpi-card__sub{font-size:10px;color:#cbd5e1;font-family:DM Mono,monospace}.dsh-kpi-card__spark{margin-top:10px}.dsh-trend{display:inline-flex;align-items:center;gap:2px;font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;font-family:DM Mono,monospace}.dsh-trend--up{background:#dcfce7;color:#15803d}.dsh-trend--down{background:#fee2e2;color:#dc2626}.dsh-trend--flat{background:#f1f5f9;color:#94a3b8}.dsh-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;font-family:DM Mono,monospace}.dsh-grid{display:grid;grid-template-columns:1fr 340px;gap:16px;padding:16px 24px 32px;align-items:start}.dsh-grid__main,.dsh-grid__side{display:flex;flex-direction:column;gap:14px}.dsh-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:16px;animation:dsh-card-in .5s ease both;box-shadow:0 1px 4px #0f172a0d,0 4px 16px #0f172a08}.dsh-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}.dsh-card__title{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:800;color:#475569;text-transform:uppercase;letter-spacing:.7px}.dsh-card__subtitle{font-size:10px;font-weight:500;color:#94a3b8;text-transform:none;letter-spacing:0}.dsh-card__actions{display:flex;gap:8px}.dsh-link-btn{font-size:11px;font-weight:700;color:#2563eb;background:none;border:none;cursor:pointer;padding:0;transition:color .15s;font-family:inherit;white-space:nowrap;opacity:.75}.dsh-link-btn:hover{color:#1d4ed8;opacity:1}.dsh-bar-chart{display:flex;align-items:flex-end;gap:3px;height:100px;padding:0 0 20px;position:relative}.dsh-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;position:relative;height:100%}.dsh-bar-group--today .dsh-bar-pair:before{content:"";position:absolute;inset:-4px -3px;background:#2563eb0a;border-radius:4px;border:1px solid rgba(37,99,235,.2)}.dsh-bar-pair{display:flex;gap:1px;align-items:flex-end;height:80px;position:relative;margin-top:auto}.dsh-bar{width:5px;border-radius:2px 2px 0 0;transition:height 1.2s cubic-bezier(.4,0,.2,1);min-height:2px}.dsh-bar--vis{background:#3b82f6;opacity:.75}.dsh-bar--stu{background:#8b5cf6;opacity:.75}.dsh-bar-group:hover .dsh-bar{opacity:1}.dsh-bar-label{position:absolute;bottom:0;font-size:9px;color:#94a3b8;font-family:DM Mono,monospace;white-space:nowrap;transform:translate(-50%);left:50%}.dsh-bar-group--today .dsh-bar-label{color:#2563eb;font-weight:700}.dsh-chart-legend{display:flex;gap:16px;font-size:10px;color:#94a3b8;margin-top:4px}.dsh-legend-dot{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:4px;vertical-align:middle;opacity:.75}.dsh-peaks-grid{display:grid;grid-template-columns:repeat(24,1fr);gap:2px}.dsh-peak-cell{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:default}.dsh-peak-cell--now .dsh-peak-hour{color:#2563eb;font-weight:700}.dsh-peak-hour{font-size:8px;color:#cbd5e1;font-family:DM Mono,monospace}.dsh-peak-bars{display:flex;flex-direction:column;gap:1px;width:100%}.dsh-peak-bar{height:12px;border-radius:2px}.dsh-peak-bar--vis{background:#3b82f6}.dsh-peak-bar--stu{background:#8b5cf6}.dsh-cabinet-list{display:flex;flex-direction:column;gap:12px}.dsh-cabinet-row{display:grid;grid-template-columns:1fr 1fr auto;align-items:center;gap:10px}.dsh-cabinet-code{font-size:12px;font-weight:700;font-family:DM Mono,monospace;color:#0f172a}.dsh-cabinet-loc{font-size:10px;color:#94a3b8;margin-top:1px}.dsh-cabinet-bar-wrap{flex:1}.dsh-cabinet-nums{font-size:12px;font-family:DM Mono,monospace;font-weight:700;white-space:nowrap;text-align:right;color:#0f172a}.dsh-cabinet-total{color:#cbd5e1;font-weight:400}.dsh-asset-grid{display:flex;flex-direction:column;gap:10px}.dsh-asset-row{display:grid;grid-template-columns:100px 1fr 40px auto;align-items:center;gap:8px}.dsh-asset-type{font-size:11px;color:#475569;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dsh-asset-bar-wrap{flex:1}.dsh-asset-nums{text-align:right}.dsh-asset-alert{display:flex;align-items:center;gap:3px;font-size:10px;color:#dc2626;font-family:DM Mono,monospace;white-space:nowrap}.dsh-asset-summary{display:flex;justify-content:space-between;align-items:center;padding-top:10px;margin-top:4px;border-top:1px solid #f1f5f9}.dsh-asset-summary__label{font-size:11px;color:#94a3b8}.dsh-asset-summary__val{font-size:20px;font-weight:800;font-family:DM Mono,monospace}.dsh-insights-list{display:flex;flex-direction:column;gap:7px}.dsh-insight{display:flex;align-items:flex-start;gap:9px;padding:10px 11px;border-radius:9px;border:1px solid;transition:box-shadow .2s}.dsh-insight:hover{box-shadow:0 2px 8px #0f172a0f}.dsh-insight__icon{flex-shrink:0;margin-top:1px}.dsh-insight__body{flex:1;min-width:0}.dsh-insight__title{font-size:11px;font-weight:700;margin-bottom:2px;line-height:1.3}.dsh-insight__text{font-size:10px;color:#64748b;line-height:1.55}.dsh-insight__cta{display:flex;align-items:center;gap:2px;font-size:10px;font-weight:700;background:none;border:none;cursor:pointer;padding:0;white-space:nowrap;margin-top:5px;font-family:inherit;transition:opacity .15s}.dsh-insight__cta:hover{opacity:.7}.dsh-security-row{display:grid;grid-template-columns:1fr 1fr auto;align-items:center;gap:8px;margin-bottom:12px}.dsh-security-row__label{font-size:10px;color:#64748b;white-space:nowrap}.dsh-security-row__val{font-size:11px;font-weight:700;font-family:DM Mono,monospace;text-align:right}.dsh-security-stats{display:flex;flex-direction:column;gap:1px;margin-bottom:12px}.dsh-stat-row{display:flex;align-items:center;gap:8px;padding:7px 6px;border-bottom:1px solid #f8fafc;cursor:pointer;background:none;border-left:none;border-right:none;border-top:none;font-family:inherit;color:inherit;width:100%;text-align:left;transition:background .15s;border-radius:6px}.dsh-stat-row:hover{background:#f8fafc}.dsh-stat-row__lbl{flex:1;font-size:11px;color:#64748b}.dsh-stat-row__val{font-size:14px;font-weight:800;font-family:DM Mono,monospace}.dsh-section-mini-title{font-size:9px;font-weight:800;color:#94a3b8;text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}.dsh-refused-breakdown{padding-top:10px;border-top:1px solid #f1f5f9}.dsh-refused-row{display:grid;grid-template-columns:1fr 1fr 30px;align-items:center;gap:8px;margin-bottom:6px}.dsh-refused-code{font-size:9px;font-family:DM Mono,monospace;color:#64748b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dsh-refused-count{font-size:10px;font-weight:700;font-family:DM Mono,monospace;color:#0f172a;text-align:right}.dsh-card .dsh-hbar-track{background:#f1f5f9}.dsh-alerts-list{display:flex;flex-direction:column;gap:1px}.dsh-alert-row{display:flex;align-items:center;gap:8px;padding:8px 6px;border-radius:7px;transition:background .15s;border-bottom:1px solid #f8fafc}.dsh-alert-row:last-child{border-bottom:none}.dsh-alert-row:hover{background:#f8fafc}.dsh-alert-row--resolved{opacity:.4}.dsh-alert-sev{display:flex;align-items:center;flex-shrink:0}.dsh-alert-sev--red{color:#dc2626}.dsh-alert-sev--orange{color:#ea580c}.dsh-alert-sev--yellow{color:#ca8a04}.dsh-alert-body{flex:1;min-width:0}.dsh-alert-type{font-size:10px;font-weight:700;font-family:DM Mono,monospace;color:#0f172a}.dsh-alert-person{font-size:9px;color:#94a3b8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dsh-alert-time{font-size:9px;font-family:DM Mono,monospace;color:#cbd5e1;flex-shrink:0}.dsh-staff-list{display:flex;flex-direction:column;gap:10px}.dsh-staff-row{display:flex;align-items:center;gap:9px}.dsh-staff-rank{font-size:10px;font-weight:800;font-family:DM Mono,monospace;width:18px;flex-shrink:0}.dsh-staff-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;border:1.5px solid rgba(0,0,0,.06)}.dsh-staff-info{flex:1;min-width:0}.dsh-staff-name{font-size:11px;font-weight:600;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:5px}.dsh-staff-ops{font-size:14px;font-weight:800;font-family:DM Mono,monospace;color:#2563eb;flex-shrink:0}.dsh-staff-ops__lbl{font-size:9px;color:#94a3b8;font-weight:400;font-family:Plus Jakarta Sans,sans-serif}.dsh-qr-list{display:flex;flex-direction:column;gap:10px}.dsh-qr-row{display:grid;grid-template-columns:1fr 1fr 60px;align-items:center;gap:8px}.dsh-qr-purpose{font-size:11px;color:#475569;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dsh-qr-nums{text-align:right;font-family:DM Mono,monospace}.dsh-empty{font-size:11px;color:#cbd5e1;text-align:center;padding:18px 0;font-family:DM Mono,monospace}@keyframes dsh-card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.dsh-cabinet-stats>div:first-child>div:first-child,.dsh-asset-bar-wrap>div>div:first-child,.dsh-qr-row>div>div:first-child,.dsh-security-row>div>div:first-child,.dsh-staff-info>div>div:first-child,.dsh-refused-row>div>div:first-child{background:#f1f5f9!important}@media(max-width:1400px){.dsh-kpi-strip{grid-template-columns:repeat(4,1fr)}}@media(max-width:1200px){.dsh-grid{grid-template-columns:1fr}.dsh-grid__side{display:grid;grid-template-columns:1fr 1fr}}@media(max-width:1024px){.dsh-kpi-strip{grid-template-columns:repeat(4,1fr)}.dsh-peaks-grid{grid-template-columns:repeat(12,1fr)}}@media(max-width:768px){.dsh-kpi-strip{grid-template-columns:repeat(2,1fr)}.dsh-grid{padding:12px}.dsh-grid__side{grid-template-columns:1fr}.dsh-header{padding:12px 16px}.dsh-peaks-grid{grid-template-columns:repeat(8,1fr)}}@media(max-width:480px){.dsh-kpi-strip{grid-template-columns:1fr 1fr}}@media print{.dsh-header__right,.dsh-refresh-btn{display:none!important}.dsh-root{background:#fff}.dsh-card,.dsh-kpi-card{box-shadow:none;border-color:#e2e8f0}}:root{--sg-bg: #f5f5f5;--sg-surface: #ffffff;--sg-surface-2: #fafafa;--sg-surface-3: #eeeeee;--sg-border: #e0e0e0;--sg-border-2: #bdbdbd;--sg-ink-1: #212121;--sg-ink-2: #424242;--sg-ink-3: #616161;--sg-ink-4: #9e9e9e;--sg-cam-bg: #0d0d0d;--sg-cam-line: rgba(255, 255, 255, .06);--sg-info: #1565c0;--sg-info-dark: #0d47a1;--sg-info-light: #e3f2fd;--sg-info-mid: #90caf9;--sg-info-text: #0d47a1;--sg-success: #1b5e20;--sg-success-dark: #145214;--sg-success-light: #e8f5e9;--sg-success-mid: #a5d6a7;--sg-success-text: #1b5e20;--sg-warning: #e65100;--sg-warning-dark: #bf360c;--sg-warning-light: #fbe9e7;--sg-warning-mid: #ffab91;--sg-warning-text: #bf360c;--sg-error: #b71c1c;--sg-error-dark: #7f0000;--sg-error-light: #ffebee;--sg-error-mid: #ef9a9a;--sg-error-text: #7f0000;--sg-neutral: #455a64;--sg-neutral-light: #eceff1;--sg-neutral-mid: #b0bec5;--sg-neutral-text: #37474f;--sg-r-xs: 4px;--sg-r-sm: 8px;--sg-r-md: 12px;--sg-r-lg: 16px;--sg-r-xl: 20px;--sg-r-pill: 999px;--sg-font-ui: "DM Sans", system-ui, sans-serif;--sg-font-mono: "JetBrains Mono", "Fira Code", monospace;--sg-shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .05);--sg-shadow-md: 0 4px 16px rgba(0, 0, 0, .09), 0 2px 6px rgba(0, 0, 0, .05);--sg-shadow-lg: 0 12px 40px rgba(0, 0, 0, .11), 0 4px 10px rgba(0, 0, 0, .06);--sg-shadow-xl: 0 24px 80px rgba(0, 0, 0, .16);--sg-touch-min: 48px}*,*:before,*:after{box-sizing:border-box}.sg-page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}.sg-page-header__left{flex:1;min-width:0}.sg-page-header__right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.sg-page-title{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:600;color:var(--sg-ink-1);font-family:var(--sg-font-ui);letter-spacing:-.3px}.sg-title-icon{width:38px;height:38px;border-radius:var(--sg-r-md);background:var(--sg-ink-1);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sg-page-sub{font-size:12px;color:var(--sg-ink-4);margin-top:4px;margin-left:48px;font-family:var(--sg-font-ui)}.sg-header-btn{display:inline-flex;align-items:center;gap:6px;padding:0 14px;height:var(--sg-touch-min);border-radius:var(--sg-r-sm);border:1.5px solid var(--sg-border-2);background:var(--sg-surface);color:var(--sg-ink-3);font-size:13px;font-weight:500;font-family:var(--sg-font-ui);cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none;line-height:1}.sg-header-btn:hover{background:var(--sg-surface-3);border-color:var(--sg-ink-3);color:var(--sg-ink-1)}.sg-sound-btn{display:inline-flex;align-items:center;gap:6px;padding:0 12px;height:var(--sg-touch-min);border-radius:var(--sg-r-sm);border:1.5px solid var(--sg-border-2);font-size:12px;font-weight:500;font-family:var(--sg-font-ui);cursor:pointer;transition:all .15s}.sg-sound-btn--on{background:var(--sg-info-light);color:var(--sg-info);border-color:var(--sg-info-mid)}.sg-sound-btn--off{background:var(--sg-surface-3);color:var(--sg-ink-4)}.sg-layout{display:grid;grid-template-columns:1fr 300px;gap:16px;align-items:start}.sg-layout__main,.sg-layout__side{display:flex;flex-direction:column;gap:14px;min-width:0}.sg-scanner-card{background:var(--sg-cam-bg);border:1px solid #1a1a1a;border-radius:var(--sg-r-xl);overflow:hidden;box-shadow:var(--sg-shadow-lg)}.sg-cam-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--sg-cam-line);flex-wrap:wrap;min-height:56px}.sg-cam-toggle{display:inline-flex;align-items:center;gap:7px;padding:0 16px;height:40px;border-radius:var(--sg-r-sm);border:none;font-size:13px;font-weight:600;font-family:var(--sg-font-ui);cursor:pointer;transition:all .17s;white-space:nowrap;touch-action:manipulation}.sg-cam-toggle--start{background:var(--sg-info);color:#fff}.sg-cam-toggle--start:hover{background:var(--sg-info-dark)}.sg-cam-toggle--stop{background:#b71c1c38;color:#ffcdd2;border:1px solid rgba(183,28,28,.3)}.sg-cam-toggle--stop:hover{background:#b71c1c52}.sg-cam-toggle:disabled{opacity:.45;cursor:not-allowed}.sg-cam-select{padding:6px 9px;height:36px;border-radius:var(--sg-r-xs);border:1px solid rgba(255,255,255,.13);background:#ffffff12;color:#ccc;font-size:11px;font-family:var(--sg-font-ui);outline:none;cursor:pointer}.sg-cam-select:focus{border-color:var(--sg-info)}.sg-cam-viewport{position:relative;background:#0a0a0a;min-height:210px;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:min-height .3s ease}.sg-cam-viewport--active{min-height:260px}.sg-cam-viewport #sg-qr-reader,.sg-cam-viewport>div>div{width:100%!important}.sg-cam-placeholder{display:flex;flex-direction:column;align-items:center;gap:11px;color:#ffffff38;cursor:pointer;transition:color .2s;padding:44px 20px}.sg-cam-placeholder:hover{color:#ffffff70}.sg-cam-placeholder__frame{width:74px;height:74px;border-radius:17px;border:1.5px dashed currentColor;display:flex;align-items:center;justify-content:center}.sg-cam-placeholder p{font-size:13px;font-weight:500;margin:0;font-family:var(--sg-font-ui)}.sg-cam-placeholder small{font-size:11px;opacity:.7;font-family:var(--sg-font-ui)}.sg-cam-overlay{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--sg-r-pill);font-size:11px;font-weight:600;white-space:nowrap;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:var(--sg-font-ui)}.sg-cam-overlay--idle{background:#0f0e0cb8;color:#ffffff80}.sg-cam-overlay--info{background:#1565c0e0;color:#fff}.sg-cam-overlay--warning{background:#e65100e6;color:#fff}.sg-cam-overlay--success{background:#1b5e20e0;color:#fff}.sg-cam-corners{position:absolute;inset:20px;pointer-events:none}.sg-cam-corners span{position:absolute;width:20px;height:20px;border-color:#ffffff5c;border-style:solid}.sg-cam-corners span:nth-child(1){top:0;left:0;border-width:2px 0 0 2px;border-radius:3px 0 0}.sg-cam-corners span:nth-child(2){top:0;right:0;border-width:2px 2px 0 0;border-radius:0 3px 0 0}.sg-cam-corners span:nth-child(3){bottom:0;left:0;border-width:0 0 2px 2px;border-radius:0 0 0 3px}.sg-cam-corners span:nth-child(4){bottom:0;right:0;border-width:0 2px 2px 0;border-radius:0 0 3px}.sg-cam-error{display:flex;align-items:center;gap:7px;padding:9px 12px;background:#b71c1c24;color:#ffcdd2;font-size:11px;font-family:var(--sg-font-ui);border-top:1px solid rgba(183,28,28,.2)}.sg-link{color:#90caf9;text-decoration:underline;cursor:pointer;background:none;border:none;font-size:inherit;padding:0;font-family:inherit}.sg-status-bar{display:flex;align-items:center;gap:9px;padding:9px 12px;border-top:1px solid var(--sg-cam-line);font-size:11px;font-weight:500;color:#ffffff5c;font-family:var(--sg-font-ui);min-height:40px}.sg-status-indicator{width:7px;height:7px;border-radius:50%;flex-shrink:0;transition:background .3s}.sg-status-indicator--idle{background:#ffffff2e}.sg-status-indicator--active{background:var(--sg-info-mid);animation:sg-pulse-dot 1.5s infinite}.sg-status-indicator--loading{background:var(--sg-warning-mid);animation:sg-pulse-dot .7s infinite}.sg-status-text{flex:1}.sg-result-area{display:flex;flex-direction:column;gap:12px}.sg-empty{display:flex;flex-direction:column;align-items:center;gap:14px;padding:52px 24px;text-align:center;background:var(--sg-surface);border:1px solid var(--sg-border);border-radius:var(--sg-r-xl);box-shadow:var(--sg-shadow-sm)}.sg-empty__icon{width:76px;height:76px;border-radius:20px;background:var(--sg-surface-3);display:flex;align-items:center;justify-content:center;color:var(--sg-ink-4)}.sg-empty h3{font-size:15px;font-weight:600;color:var(--sg-ink-2);font-family:var(--sg-font-ui)}.sg-empty p{font-size:12px;color:var(--sg-ink-4);max-width:290px;line-height:1.65;font-family:var(--sg-font-ui)}.sg-processing{display:flex;align-items:center;justify-content:center;gap:10px;padding:24px;color:var(--sg-ink-4);font-size:13px;font-family:var(--sg-font-ui)}.sg-alert-card{display:flex;align-items:flex-start;gap:14px;padding:17px 19px;border-radius:var(--sg-r-xl);border:1.5px solid transparent;animation:sg-slide-in .18s ease;flex-wrap:wrap}.sg-alert-card--red{background:var(--sg-error-light);border-color:var(--sg-error-mid)}.sg-alert-card--error{background:var(--sg-surface);border-color:var(--sg-border-2)}.sg-alert-card--red .sg-alert-card__icon{color:var(--sg-error)}.sg-alert-card--error .sg-alert-card__icon{color:var(--sg-warning)}.sg-alert-card__icon{flex-shrink:0;margin-top:2px}.sg-alert-card__body{flex:1;min-width:0}.sg-alert-card__title{font-size:14px;font-weight:600;color:var(--sg-ink-1);margin-bottom:3px;font-family:var(--sg-font-ui)}.sg-alert-card__desc{font-size:12px;color:var(--sg-ink-3);line-height:1.55;font-family:var(--sg-font-ui)}.sg-alert-card__actions{display:flex;gap:7px;flex-wrap:wrap;align-items:center;margin-top:8px}.sg-flow-card{background:var(--sg-surface);border:1px solid var(--sg-border);border-radius:var(--sg-r-xl);padding:18px;box-shadow:var(--sg-shadow-sm);display:flex;flex-direction:column;gap:13px;animation:sg-slide-in .18s ease;overflow:hidden}.sg-flow-card--checkin{border-left:3px solid var(--sg-info)}.sg-flow-card--checkout{border-left:3px solid var(--sg-warning)}.sg-flow-card--add{border-left:3px solid var(--sg-success)}.sg-flow-card--add-luggage{border-left:3px solid var(--sg-warning)}.sg-flow-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sg-flow-step{font-size:10px;font-weight:600;color:var(--sg-ink-4);margin-left:auto;font-family:var(--sg-font-ui)}.sg-flow-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--sg-r-pill);font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;white-space:nowrap;font-family:var(--sg-font-ui)}.sg-flow-badge--checkin{background:var(--sg-info-light);color:var(--sg-info-text)}.sg-flow-badge--checkout{background:var(--sg-warning-light);color:var(--sg-warning-text)}.sg-flow-badge--confirm{background:var(--sg-success-light);color:var(--sg-success-text)}.sg-flow-badge--scan{background:var(--sg-neutral-light);color:var(--sg-neutral-text)}.sg-flow-badge--info{background:var(--sg-surface-3);color:var(--sg-ink-3)}.sg-flow-badge--luggage{background:var(--sg-warning-light);color:var(--sg-warning-text)}.sg-person{display:flex;align-items:center;gap:11px;padding:12px 13px;background:var(--sg-surface-2);border:1px solid var(--sg-border);border-radius:var(--sg-r-md);font-family:var(--sg-font-ui);overflow:hidden}.sg-person--compact{padding:8px 11px}.sg-person__avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.sg-person--compact .sg-person__avatar{width:32px;height:32px;font-size:11px}.sg-person__avatar--student{background:var(--sg-info-light);color:var(--sg-info)}.sg-person__avatar--visitor{background:#f3e5f5;color:#6a1b9a}.sg-person__info{flex:1;min-width:0}.sg-person__name{font-size:14px;font-weight:600;color:var(--sg-ink-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sg-person--compact .sg-person__name{font-size:13px}.sg-person__sub{font-size:10px;color:var(--sg-ink-4);margin-top:2px}.sg-person__type{font-size:9px;font-weight:700;padding:3px 8px;border-radius:var(--sg-r-pill);text-transform:uppercase;letter-spacing:.4px;flex-shrink:0}.sg-person__type--student{background:var(--sg-info-light);color:var(--sg-info)}.sg-person__type--visitor{background:#f3e5f5;color:#6a1b9a}.sg-member-progress{padding:12px 14px;background:var(--sg-info-light);border:1px solid var(--sg-info-mid);border-radius:var(--sg-r-md);font-family:var(--sg-font-ui)}.sg-member-progress__header{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--sg-info-text);margin-bottom:8px}.sg-member-progress__dots{display:flex;align-items:center;gap:5px;margin-left:auto}.sg-member-dot{width:9px;height:9px;border-radius:50%;background:var(--sg-info-mid);transition:all .2s}.sg-member-dot--done{background:var(--sg-success)}.sg-member-dot--active{background:var(--sg-info);transform:scale(1.3);box-shadow:0 0 0 2px var(--sg-info-light),0 0 0 3px var(--sg-info)}.sg-member-progress__bar{height:4px;background:var(--sg-info-mid);border-radius:var(--sg-r-pill);overflow:hidden}.sg-member-progress__fill{height:100%;background:var(--sg-info);border-radius:var(--sg-r-pill);transition:width .4s ease}.sg-bag-summary-strip{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--sg-success-light);border:1px solid var(--sg-success-mid);border-radius:var(--sg-r-sm);font-size:12px;font-weight:600;color:var(--sg-success-text);font-family:var(--sg-font-ui);flex-wrap:wrap}.sg-bag-summary-dots{display:flex;align-items:center;gap:4px;margin-left:auto;flex-wrap:wrap}.sg-bag-dot-sm{width:8px;height:8px;border-radius:50%;background:var(--sg-neutral-mid);transition:background .2s}.sg-bag-dot-sm--yes{background:var(--sg-success)}.sg-bag-dot-sm--no{background:var(--sg-border-2)}.sg-question-block{display:flex;align-items:flex-start;gap:13px;padding:14px 15px;background:var(--sg-info-light);border:1px solid var(--sg-info-mid);border-radius:var(--sg-r-md);font-family:var(--sg-font-ui)}.sg-question-block__icon{width:44px;height:44px;border-radius:10px;background:var(--sg-info);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sg-question-block__q{font-size:14px;font-weight:600;color:var(--sg-info-text);margin-bottom:3px}.sg-question-block__hint{font-size:11px;color:var(--sg-info)}.sg-info-strip{display:flex;align-items:center;gap:6px;padding:9px 12px;background:var(--sg-surface-2);border:1px solid var(--sg-border);border-radius:var(--sg-r-xs);font-size:11px;color:var(--sg-ink-4);font-family:var(--sg-font-ui)}.sg-nobag-strip{display:flex;align-items:center;gap:6px;padding:9px 12px;background:var(--sg-success-light);border:1px solid var(--sg-success-mid);border-radius:var(--sg-r-xs);font-size:11px;font-weight:600;color:var(--sg-success-text);font-family:var(--sg-font-ui)}.sg-action-row{display:flex;gap:9px;flex-wrap:wrap}.sg-action-row--checkout{margin-top:4px}.sg-answer-btn{display:flex;align-items:center;justify-content:center;gap:8px;flex:1;min-width:130px;min-height:var(--sg-touch-min);padding:12px 16px;border-radius:var(--sg-r-md);border:1.5px solid transparent;font-size:13px;font-weight:600;font-family:var(--sg-font-ui);cursor:pointer;transition:all .17s;touch-action:manipulation}.sg-answer-btn--yes{background:var(--sg-ink-1);color:#fff}.sg-answer-btn--yes:hover:not(:disabled){background:var(--sg-ink-2);transform:translateY(-1px);box-shadow:0 6px 20px #00000038}.sg-answer-btn--no{background:var(--sg-surface-2);color:var(--sg-ink-2);border-color:var(--sg-border-2)}.sg-answer-btn--no:hover:not(:disabled){background:var(--sg-surface-3)}.sg-answer-btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.sg-back-row{display:flex;justify-content:flex-start;padding-top:4px;border-top:1px solid var(--sg-border);margin-top:2px}.sg-cell-strip{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--sg-r-md);border:1px solid var(--sg-border);font-family:var(--sg-font-ui);overflow:hidden}.sg-cell-strip--checkin{background:var(--sg-ink-1);border-color:transparent;color:#fff}.sg-cell-strip--checkout{background:linear-gradient(135deg,#7b3f00,#a0520d);border-color:transparent;color:#fff}.sg-cell-strip--nobag{background:var(--sg-surface-2);color:var(--sg-ink-3)}.sg-cell-strip__code{font-family:var(--sg-font-mono);font-size:17px;font-weight:700;flex-shrink:0;min-width:62px;height:46px;border-radius:9px;background:#ffffff26;display:flex;align-items:center;justify-content:center;letter-spacing:-.5px;padding:0 8px}.sg-cell-strip--nobag .sg-cell-strip__code{background:var(--sg-surface-3);color:var(--sg-ink-4);font-size:14px}.sg-cell-strip__icon{width:46px;height:46px;border-radius:9px;background:var(--sg-surface-3);display:flex;align-items:center;justify-content:center;color:var(--sg-ink-4);flex-shrink:0}.sg-cell-strip__body{flex:1;min-width:0}.sg-cell-strip__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;opacity:.72;margin-bottom:3px}.sg-cell-strip__sub{font-size:12px;font-weight:500;display:flex;align-items:center;gap:5px;flex-wrap:wrap}.sg-cell-strip__time{font-size:10px;opacity:.65;margin-top:3px;display:flex;align-items:center;gap:4px}.sg-luggage-confirm{padding:15px;background:var(--sg-warning-light);border:1.5px solid var(--sg-warning-mid);border-radius:var(--sg-r-md);animation:sg-slide-in .18s ease;font-family:var(--sg-font-ui)}.sg-luggage-confirm__header{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600;color:var(--sg-warning-text);margin-bottom:8px}.sg-luggage-confirm__body{font-size:12px;color:var(--sg-warning-text);line-height:1.6;margin-bottom:10px}.sg-luggage-confirm__detail{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#ffffff8c;border-radius:var(--sg-r-xs);font-size:11px;color:var(--sg-warning-text);line-height:1.55;margin-bottom:12px}.sg-scan-target{display:flex;align-items:center;gap:13px;padding:13px 15px;background:var(--sg-neutral-light);border:1.5px solid var(--sg-neutral-mid);border-radius:var(--sg-r-md);font-family:var(--sg-font-ui)}.sg-scan-target__icon{width:48px;height:48px;border-radius:11px;background:var(--sg-neutral);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sg-scan-target__title{font-size:14px;font-weight:600;color:var(--sg-neutral-text)}.sg-scan-target__sub{font-size:11px;color:var(--sg-neutral);margin-top:3px}.sg-type-sel{display:flex;flex-direction:column;gap:11px}.sg-registered-summary{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:8px 11px;background:var(--sg-success-light);border-radius:var(--sg-r-xs);border:1px solid var(--sg-success-mid);font-family:var(--sg-font-ui)}.sg-registered-summary__lbl{font-size:10px;font-weight:700;color:var(--sg-success-text)}.sg-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:9px}.sg-type-btn{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 10px;min-height:var(--sg-touch-min);border-radius:var(--sg-r-md);border:1.5px solid var(--sg-border);background:var(--sg-surface);cursor:pointer;transition:all .17s;font-family:var(--sg-font-ui);position:relative;touch-action:manipulation}.sg-type-btn:hover{border-color:var(--sg-info);background:var(--sg-info-light);transform:translateY(-1px)}.sg-type-btn--has{border-color:var(--sg-success);background:var(--sg-success-light)}.sg-type-btn__icon{width:40px;height:40px;border-radius:9px;background:var(--sg-info-light);color:var(--sg-info);display:flex;align-items:center;justify-content:center}.sg-type-btn--has .sg-type-btn__icon{background:var(--sg-success-light);color:var(--sg-success)}.sg-type-btn__label{font-size:11px;font-weight:600;color:var(--sg-ink-1);text-align:center}.sg-type-btn__badge{position:absolute;top:5px;right:7px;background:var(--sg-success);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:var(--sg-r-pill)}.sg-dup-notice{display:flex;align-items:flex-start;gap:10px;padding:11px 13px;background:var(--sg-warning-light);border:1.5px solid var(--sg-warning-mid);border-radius:var(--sg-r-md);color:var(--sg-warning-text);font-family:var(--sg-font-ui)}.sg-dup-notice__title{font-weight:700;font-size:12px;margin-bottom:3px}.sg-dup-notice__sub{font-size:11px;margin-bottom:7px}.sg-dup-notice__btns{display:flex;gap:5px}.sg-spin-wrap{display:flex;align-items:center;gap:9px;padding:18px;color:var(--sg-ink-4);font-size:12px;font-family:var(--sg-font-ui)}.sg-asset-list{display:flex;flex-direction:column;gap:6px}.sg-asset-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--sg-surface-2);border:1px solid var(--sg-border);border-radius:var(--sg-r-sm);font-family:var(--sg-font-ui);min-height:44px}.sg-asset-item__left{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--sg-ink-1);flex:1;min-width:0}.sg-asset-item__right{display:flex;align-items:center;gap:5px;flex-shrink:0}.sg-no-assets{font-size:11px;color:var(--sg-ink-4);text-align:center;padding:8px 0;font-family:var(--sg-font-ui)}.sg-checkout-assets{display:flex;flex-direction:column;gap:6px}.sg-checkout-asset{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--sg-surface-2);border:1px solid var(--sg-border);border-radius:var(--sg-r-sm);font-family:var(--sg-font-ui);min-height:44px;flex-wrap:wrap;gap:6px}.sg-checkout-asset__left{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--sg-ink-1)}.sg-checkout-asset__right{display:flex;align-items:center;gap:5px}.sg-verify-section{display:flex;flex-direction:column;gap:9px}.sg-verify-header{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:600;color:var(--sg-ink-2);font-family:var(--sg-font-ui)}.sg-progress-bar{position:relative;height:6px;background:var(--sg-surface-3);border-radius:var(--sg-r-pill);overflow:visible}.sg-progress-bar__fill{height:100%;background:var(--sg-info);border-radius:var(--sg-r-pill);transition:width .4s ease}.sg-progress-bar__label{position:absolute;right:0;top:-18px;font-size:9px;font-weight:700;color:var(--sg-ink-4);font-family:var(--sg-font-ui)}.sg-verify-hint{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--sg-info-text);padding:8px 11px;background:var(--sg-info-light);border-radius:var(--sg-r-xs);font-family:var(--sg-font-ui)}.sg-consent-section{display:flex;flex-direction:column;gap:9px}.sg-consent-warn{display:flex;align-items:flex-start;gap:11px;padding:11px 13px;background:var(--sg-warning-light);border:1.5px solid var(--sg-warning-mid);border-radius:var(--sg-r-md);color:var(--sg-warning-text);font-family:var(--sg-font-ui)}.sg-consent-warn svg{flex-shrink:0;margin-top:2px}.sg-consent-warn strong{display:block;font-size:12px;margin-bottom:3px}.sg-consent-warn p{font-size:11px;margin:0;line-height:1.55}.sg-checkout-add-row{display:flex;gap:8px;flex-wrap:wrap}.sg-add-action-btn{display:inline-flex;align-items:center;gap:7px;padding:0 13px;min-height:var(--sg-touch-min);border-radius:var(--sg-r-sm);font-size:12px;font-weight:700;font-family:var(--sg-font-ui);cursor:pointer;transition:all .17s;flex:1;min-width:140px;justify-content:center;border:1.5px dashed;touch-action:manipulation}.sg-add-action-btn:disabled{opacity:.45;cursor:not-allowed}.sg-add-action-btn--device{border-color:var(--sg-info);background:var(--sg-info-light);color:var(--sg-info-text)}.sg-add-action-btn--device:hover:not(:disabled){background:var(--sg-info);color:#fff;border-style:solid}.sg-add-action-btn--luggage{border-color:var(--sg-warning);background:var(--sg-warning-light);color:var(--sg-warning-text)}.sg-add-action-btn--luggage:hover:not(:disabled){background:var(--sg-warning);color:#fff;border-style:solid}.sg-luggage-banner{background:var(--sg-success-light);border:1.5px solid var(--sg-success-mid);border-radius:var(--sg-r-md);overflow:hidden;animation:sg-slide-in .2s ease;font-family:var(--sg-font-ui)}.sg-luggage-banner__header{display:flex;align-items:center;gap:8px;padding:12px 15px 10px;font-size:13px;font-weight:600;color:var(--sg-success-text);border-bottom:1px solid var(--sg-success-mid)}.sg-luggage-banner__cell{display:flex;align-items:center;gap:13px;padding:14px 15px}.sg-luggage-banner__cell-code{font-family:var(--sg-font-mono);font-size:22px;font-weight:700;color:var(--sg-success-text);background:var(--sg-success-mid);padding:7px 13px;border-radius:var(--sg-r-sm);flex-shrink:0}.sg-luggage-banner__cell-info{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--sg-success);flex-wrap:wrap}.sg-luggage-banner__instruction{display:flex;align-items:flex-start;gap:7px;padding:0 15px 12px;font-size:11px;color:var(--sg-success-text);line-height:1.55}.sg-luggage-banner__foot{padding:0 15px 14px}.sg-luggage-inline{display:flex;flex-direction:column}.sg-stack-wrapper{border-radius:var(--sg-r-md);overflow:hidden}.sg-stack-wrapper--error{outline:2px solid var(--sg-error);outline-offset:2px}.sg-stack-sel{padding:13px;background:var(--sg-warning-light);border:1.5px solid var(--sg-warning-mid);border-radius:var(--sg-r-md);font-family:var(--sg-font-ui)}.sg-stack-sel__header{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:var(--sg-warning-text);margin-bottom:5px}.sg-stack-sel__hint{font-size:11px;color:var(--sg-warning-text);margin-bottom:9px}.sg-stack-sel__grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}.sg-stack-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px;min-height:52px;border-radius:var(--sg-r-xs);border:1.5px solid var(--sg-warning-mid);background:var(--sg-surface);color:var(--sg-warning-text);font-size:11px;font-weight:600;cursor:pointer;transition:all .14s;font-family:var(--sg-font-ui);touch-action:manipulation}.sg-stack-btn:hover{background:var(--sg-warning-light)}.sg-stack-btn--sel{background:var(--sg-info);border-color:var(--sg-info);color:#fff}.sg-field-error{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--sg-error);font-weight:600;margin-top:5px;font-family:var(--sg-font-ui)}.sg-chip{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:var(--sg-r-pill);font-size:10px;font-weight:600;white-space:nowrap;font-family:var(--sg-font-ui)}.sg-chip--info{background:var(--sg-info-light);color:var(--sg-info-text)}.sg-chip--success{background:var(--sg-success-light);color:var(--sg-success-text)}.sg-chip--warning{background:var(--sg-warning-light);color:var(--sg-warning-text)}.sg-chip--error{background:var(--sg-error-light);color:var(--sg-error-text)}.sg-chip--neutral{background:var(--sg-neutral-light);color:var(--sg-neutral-text)}.sg-chip--blue{background:var(--sg-info-light);color:var(--sg-info-text)}.sg-chip--green{background:var(--sg-success-light);color:var(--sg-success-text)}.sg-chip--amber{background:var(--sg-warning-light);color:var(--sg-warning-text)}.sg-chip--red{background:var(--sg-error-light);color:var(--sg-error-text)}.sg-chip--gray{background:var(--sg-neutral-light);color:var(--sg-neutral-text)}.sg-chip--purple{background:#f3e5f5;color:#6a1b9a}.sg-chip--occupied{background:var(--sg-warning-light);color:var(--sg-warning-text)}.sg-chip--stacked{background:#f3e5f5;color:#6a1b9a}.sg-chip--available{background:var(--sg-success-light);color:var(--sg-success-text)}.sg-chip--sm{font-size:9px;padding:2px 6px}.sg-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:600;padding:0 16px;height:var(--sg-touch-min);border-radius:var(--sg-r-sm);border:1.5px solid var(--sg-border-2);background:var(--sg-surface);color:var(--sg-ink-2);cursor:pointer;transition:all .15s;white-space:nowrap;font-family:var(--sg-font-ui);text-decoration:none;line-height:1;touch-action:manipulation}.sg-btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}.sg-btn:active:not(:disabled){transform:scale(.98)}.sg-btn--sm{font-size:11px;height:36px;padding:0 12px}.sg-btn--xs{font-size:10px;height:30px;padding:0 9px}.sg-btn--grow{flex:1}.sg-btn--full{width:100%}.sg-btn--lg{height:52px;font-size:14px}.sg-btn--primary{background:var(--sg-ink-1);color:#fff;border-color:var(--sg-ink-1)}.sg-btn--primary:hover:not(:disabled){background:var(--sg-ink-2)}.sg-btn--success{background:var(--sg-success);color:#fff;border-color:var(--sg-success)}.sg-btn--success:hover:not(:disabled){background:var(--sg-success-dark);transform:translateY(-1px);box-shadow:0 4px 14px #1b5e204d}.sg-btn--danger{background:var(--sg-error);color:#fff;border-color:var(--sg-error)}.sg-btn--danger:hover:not(:disabled){background:var(--sg-error-dark);transform:translateY(-1px)}.sg-btn--warning{background:var(--sg-warning);color:#fff;border-color:var(--sg-warning)}.sg-btn--warning:hover:not(:disabled){background:var(--sg-warning-dark);transform:translateY(-1px)}.sg-btn--ghost{background:var(--sg-surface);color:var(--sg-ink-3);border-color:var(--sg-border-2)}.sg-btn--ghost:hover:not(:disabled){background:var(--sg-surface-3)}.sg-icon-btn{width:36px;height:36px;border-radius:var(--sg-r-sm);border:1px solid var(--sg-border);background:var(--sg-surface-2);color:var(--sg-ink-3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0;touch-action:manipulation}.sg-icon-btn:hover{background:var(--sg-surface-3);color:var(--sg-ink-1)}.sg-icon-btn--danger{border-color:var(--sg-error-mid);color:var(--sg-error)}.sg-icon-btn--danger:hover{background:var(--sg-error);color:#fff}.sg-spinner{width:26px;height:26px;border:2.5px solid var(--sg-info-light);border-top-color:var(--sg-info);border-radius:50%;animation:sg-spin .55s linear infinite;flex-shrink:0}.sg-spinner-xs{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.25);border-top-color:currentColor;border-radius:50%;animation:sg-spin .5s linear infinite;flex-shrink:0}.sg-btn--ghost .sg-spinner-xs{border-color:#0000001a;border-top-color:var(--sg-ink-3)}.sg-side-card{background:var(--sg-surface);border:1px solid var(--sg-border);border-radius:var(--sg-r-xl);padding:15px;box-shadow:var(--sg-shadow-sm);display:flex;flex-direction:column;gap:11px;overflow:hidden}.sg-side-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.sg-side-card__title{font-size:13px;font-weight:600;color:var(--sg-ink-1);font-family:var(--sg-font-ui)}.sg-side-card__sub{font-size:10px;color:var(--sg-ink-4);margin-top:2px;font-family:var(--sg-font-ui)}.sg-side-stats{display:flex;align-items:center;gap:5px}.sg-legend{display:flex;flex-wrap:wrap;gap:6px}.sg-legend__item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--sg-ink-4);font-family:var(--sg-font-ui)}.sg-legend__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sg-legend__dot--empty{background:var(--sg-surface-3);border:1px solid var(--sg-border)}.sg-legend__dot--occupied{background:var(--sg-warning-light);border:1px solid var(--sg-warning-mid)}.sg-legend__dot--active{background:var(--sg-info-light);border:1px solid var(--sg-info-mid)}.sg-legend__dot--stacked{background:#f3e5f5;border:1px solid #ce93d8}.sg-legend__dot--alert{background:var(--sg-error-light);border:1px solid var(--sg-error-mid)}.sg-legend__dot--maint{background:var(--sg-surface-3);border:1px dashed var(--sg-border-2);opacity:.5}.sg-cell-grid-wrap{display:flex;flex-direction:column;gap:8px}.sg-cell-search-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.sg-cell-search{flex:1;min-width:0;padding:0 10px;height:40px;border:1px solid var(--sg-border-2);border-radius:var(--sg-r-sm);font-size:12px;color:var(--sg-ink-1);background:var(--sg-surface);outline:none;font-family:var(--sg-font-ui);transition:border-color .15s}.sg-cell-search:focus{border-color:var(--sg-info);box-shadow:0 0 0 3px var(--sg-info-light)}.sg-cell-search::placeholder{color:var(--sg-ink-4)}.sg-cell-pages{display:flex;gap:4px;flex-wrap:wrap}.sg-cell-page-btn{padding:5px 9px;height:32px;border-radius:var(--sg-r-xs);border:1px solid var(--sg-border-2);background:var(--sg-surface-2);color:var(--sg-ink-3);font-size:10px;font-weight:600;cursor:pointer;font-family:var(--sg-font-ui);white-space:nowrap;transition:all .14s;touch-action:manipulation}.sg-cell-page-btn--active{background:var(--sg-info-light);color:var(--sg-info-text);border-color:var(--sg-info-mid)}.sg-cell-page-btn:hover:not(.sg-cell-page-btn--active){background:var(--sg-surface-3)}.sg-cell-page-info{font-size:10px;color:var(--sg-ink-4);text-align:center;font-family:var(--sg-font-ui)}.sg-cell-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(36px,1fr));gap:4px;max-height:230px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding-right:2px}.sg-cell-grid::-webkit-scrollbar{width:3px}.sg-cell-grid::-webkit-scrollbar-track{background:var(--sg-surface-3);border-radius:3px}.sg-cell-grid::-webkit-scrollbar-thumb{background:var(--sg-border-2);border-radius:3px}.sg-cell{aspect-ratio:1;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;font-family:var(--sg-font-mono);position:relative;transition:transform .13s,box-shadow .13s;-webkit-user-select:none;user-select:none;cursor:default;border:1px solid transparent;min-height:32px}.sg-cell--empty{background:var(--sg-surface-3);color:var(--sg-ink-4);border-color:var(--sg-border)}.sg-cell--occupied{background:var(--sg-warning-light);color:var(--sg-warning-text);border-color:var(--sg-warning-mid)}.sg-cell--active{background:var(--sg-info-light);color:var(--sg-info-text);border-color:var(--sg-info-mid)}.sg-cell--stacked{background:#f3e5f5;color:#6a1b9a;border-color:#ce93d8}.sg-cell--alert{background:var(--sg-error-light);color:var(--sg-error-text);border-color:var(--sg-error-mid);animation:sg-pulse-cell 2s infinite}.sg-cell--maint{background:var(--sg-surface-3);color:var(--sg-ink-4);opacity:.42;border:1px dashed var(--sg-border-2)}.sg-cell--click{cursor:pointer}.sg-cell--click:hover{transform:scale(1.13);box-shadow:0 3px 10px #00000024;z-index:1}.sg-cell__count{position:absolute;top:-4px;right:-4px;width:14px;height:14px;border-radius:50%;background:var(--sg-error);color:#fff;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--sg-font-ui)}.sg-cell-no-results{grid-column:1 / -1;text-align:center;font-size:11px;color:var(--sg-ink-4);padding:14px 0;font-family:var(--sg-font-ui)}.sg-cell-stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:5px}.sg-cell-stat{text-align:center;padding:6px 4px;background:var(--sg-surface-2);border-radius:var(--sg-r-xs);border:1px solid var(--sg-border)}.sg-cell-stat__val{font-size:15px;font-weight:600;color:var(--sg-ink-1);font-family:var(--sg-font-ui)}.sg-cell-stat__lbl{font-size:8px;color:var(--sg-ink-4);text-transform:uppercase;letter-spacing:.4px;margin-top:1px;font-family:var(--sg-font-ui)}.sg-stack-warn{display:flex;flex-direction:column;gap:5px;padding:9px 11px;background:var(--sg-warning-light);border:1px solid var(--sg-warning-mid);border-radius:var(--sg-r-xs);font-size:11px;color:var(--sg-warning-text);font-weight:600;font-family:var(--sg-font-ui)}.sg-stack-warn__cells{display:flex;gap:4px;flex-wrap:wrap}.sg-empty-sessions{display:flex;align-items:center;gap:8px;justify-content:center;padding:14px;color:var(--sg-ink-4);font-size:12px;font-family:var(--sg-font-ui)}.sg-sessions{display:flex;flex-direction:column;gap:5px;max-height:340px;overflow-y:auto;-webkit-overflow-scrolling:touch}.sg-sessions::-webkit-scrollbar{width:3px}.sg-sessions::-webkit-scrollbar-thumb{background:var(--sg-border-2);border-radius:3px}.sg-session{display:flex;align-items:center;gap:9px;padding:9px 10px;min-height:52px;background:var(--sg-surface-2);border:1px solid var(--sg-border);border-radius:var(--sg-r-sm);transition:background .14s;font-family:var(--sg-font-ui)}.sg-session:hover{background:var(--sg-surface-3)}.sg-session--alert{border-color:var(--sg-error-mid);background:var(--sg-error-light)}.sg-session__cell{width:32px;height:32px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;font-family:var(--sg-font-mono);flex-shrink:0}.sg-session__cell--student{background:var(--sg-info-light);color:var(--sg-info-text)}.sg-session__cell--visitor,.sg-session__cell--stacked{background:#f3e5f5;color:#6a1b9a}.sg-session__cell--ao{background:var(--sg-success-light);color:var(--sg-success-text)}.sg-session__body{flex:1;min-width:0}.sg-session__name{font-size:11px;font-weight:600;color:var(--sg-ink-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sg-session__meta{font-size:9px;color:var(--sg-ink-4);margin-top:1px}.sg-session__meta--alert{color:var(--sg-error-text);font-weight:600}.sg-session__time{font-size:11px;font-weight:600;color:var(--sg-ink-3);white-space:nowrap}.sg-session__time--alert{color:var(--sg-error-text)}.sg-popup-overlay{position:fixed;inset:0;background:#0000007a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:sg-fade-in .18s ease}@media(min-width:480px){.sg-popup-overlay{align-items:center;padding:16px}}.sg-popup{background:var(--sg-surface);border-radius:var(--sg-r-xl) var(--sg-r-xl) 0 0;box-shadow:var(--sg-shadow-xl);width:100%;max-width:420px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;animation:sg-sheet-up .22s ease}@media(min-width:480px){.sg-popup{border-radius:var(--sg-r-xl);max-height:80vh;animation:sg-scale-in .2s ease}}.sg-popup:before{content:"";display:block;width:36px;height:4px;border-radius:var(--sg-r-pill);background:var(--sg-border-2);margin:10px auto 0;flex-shrink:0}@media(min-width:480px){.sg-popup:before{display:none}}.sg-popup__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--sg-border);gap:10px;flex-shrink:0}.sg-popup__header-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.sg-popup__header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.sg-popup__cell-badge{width:44px;height:44px;border-radius:12px;background:var(--sg-ink-1);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--sg-font-mono);font-size:15px;font-weight:700;flex-shrink:0}.sg-popup__title-text{font-size:16px;font-weight:700;color:var(--sg-ink-1);font-family:var(--sg-font-ui)}.sg-popup__subtitle{font-size:11px;color:var(--sg-ink-4);margin-top:2px;font-family:var(--sg-font-ui)}.sg-popup__body{overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex:1;padding:12px 16px 16px;display:flex;flex-direction:column;gap:10px}.sg-popup__body::-webkit-scrollbar{width:3px}.sg-popup__body::-webkit-scrollbar-thumb{background:var(--sg-border-2);border-radius:3px}.sg-popup__empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 16px;color:var(--sg-ink-4);font-size:13px;font-family:var(--sg-font-ui)}.sg-popup__session-card{background:var(--sg-surface-2);border:1px solid var(--sg-border);border-radius:var(--sg-r-md);overflow:hidden}.sg-popup__bag-header{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--sg-neutral-light);border-bottom:1px solid var(--sg-border);font-size:10px;font-weight:700;color:var(--sg-neutral-text);text-transform:uppercase;letter-spacing:.4px;font-family:var(--sg-font-ui)}.sg-popup__session-rows{display:flex;flex-direction:column}.sg-popup__row{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--sg-border);font-family:var(--sg-font-ui);min-height:44px}.sg-popup__row:last-child{border-bottom:none}.sg-popup__row-icon{width:28px;height:28px;border-radius:7px;background:var(--sg-surface-3);display:flex;align-items:center;justify-content:center;color:var(--sg-ink-4);flex-shrink:0}.sg-popup__row-content{flex:1;min-width:0}.sg-popup__row-label{font-size:9px;font-weight:700;color:var(--sg-ink-4);text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px}.sg-popup__row-value{font-size:13px;font-weight:600;color:var(--sg-ink-1);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.sg-dialog-overlay,.sg-modal-overlay{position:fixed;inset:0;background:#00000070;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px;animation:sg-fade-in .18s ease}.sg-modal-overlay{z-index:1000;align-items:flex-end;padding:0}@media(min-width:480px){.sg-modal-overlay{align-items:center;padding:16px}}.sg-dialog{background:var(--sg-surface);border-radius:var(--sg-r-xl);box-shadow:var(--sg-shadow-xl);padding:26px 22px;width:100%;max-width:360px;text-align:center;animation:sg-scale-in .2s ease;font-family:var(--sg-font-ui)}.sg-dialog__icon{width:54px;height:54px;border-radius:50%;background:var(--sg-error-light);color:var(--sg-error);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}.sg-dialog__title{font-size:17px;font-weight:600;color:var(--sg-ink-1);margin-bottom:7px}.sg-dialog__msg{font-size:13px;color:var(--sg-ink-3);line-height:1.6;margin-bottom:18px}.sg-dialog__actions{display:flex;gap:9px;justify-content:center}.sg-modal{background:var(--sg-surface);border-radius:var(--sg-r-xl) var(--sg-r-xl) 0 0;box-shadow:var(--sg-shadow-xl);width:100%;max-width:440px;max-height:92vh;overflow-y:auto;animation:sg-sheet-up .22s ease;font-family:var(--sg-font-ui)}@media(min-width:480px){.sg-modal{border-radius:var(--sg-r-xl);animation:sg-scale-in .22s ease}}.sg-modal__header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 13px;border-bottom:1px solid var(--sg-border)}.sg-modal__title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:var(--sg-ink-1)}.sg-modal__asset-tag{display:flex;align-items:center;gap:9px;padding:11px 13px 11px 20px;background:var(--sg-info-light);border-bottom:1px solid var(--sg-border)}.sg-modal__asset-tag strong{font-size:13px;font-weight:600;color:var(--sg-ink-1);display:block}.sg-modal__asset-tag span{font-size:10px;color:var(--sg-ink-4)}.sg-modal__footer{padding:13px 20px;border-top:1px solid var(--sg-border);display:flex;gap:9px}.sg-form-group{padding:11px 20px 0;display:flex;flex-direction:column;gap:4px}.sg-form-group label{font-size:11px;font-weight:700;color:var(--sg-ink-3);display:flex;align-items:center;gap:4px}.sg-required{color:var(--sg-error)}.sg-optional{font-size:9px;font-weight:500;color:var(--sg-ink-4)}.sg-input,.sg-textarea{padding:0 11px;height:44px;border:1.5px solid var(--sg-border-2);border-radius:var(--sg-r-sm);font-size:13px;color:var(--sg-ink-1);background:var(--sg-surface);outline:none;font-family:var(--sg-font-ui);width:100%;transition:border-color .18s}.sg-textarea{height:auto;padding:10px 11px;resize:vertical;min-height:56px}.sg-input:focus,.sg-textarea:focus{border-color:var(--sg-info);box-shadow:0 0 0 3px var(--sg-info-light)}.sg-select{padding:0 11px;height:44px;border:1.5px solid var(--sg-border-2);border-radius:var(--sg-r-sm);font-size:13px;color:var(--sg-ink-1);background:var(--sg-surface);outline:none;font-family:var(--sg-font-ui);width:100%;cursor:pointer;transition:border-color .18s}.sg-select:focus{border-color:var(--sg-info);box-shadow:0 0 0 3px var(--sg-info-light)}.sg-consent-notice{display:flex;align-items:flex-start;gap:6px;padding:9px 20px;font-size:11px;color:var(--sg-ink-4);line-height:1.5;font-family:var(--sg-font-ui)}.sg-toast-wrap{position:fixed;top:14px;right:14px;z-index:9999;display:flex;flex-direction:column;gap:7px;width:340px;max-width:calc(100vw - 20px);pointer-events:none}.sg-toast{display:flex;align-items:flex-start;gap:9px;padding:12px 14px;border-radius:var(--sg-r-md);border:1px solid transparent;box-shadow:var(--sg-shadow-md);font-size:12px;font-weight:500;font-family:var(--sg-font-ui);pointer-events:all;animation:sg-slide-in .2s ease}.sg-toast--success{background:var(--sg-success-light);border-color:var(--sg-success-mid);color:var(--sg-success-text)}.sg-toast--error{background:var(--sg-error-light);border-color:var(--sg-error-mid);color:var(--sg-error-text)}.sg-toast--warning{background:var(--sg-warning-light);border-color:var(--sg-warning-mid);color:var(--sg-warning-text)}.sg-toast--info{background:var(--sg-info-light);border-color:var(--sg-info-mid);color:var(--sg-info-text)}.sg-toast__icon{flex-shrink:0;margin-top:1px}.sg-toast__msg{flex:1;line-height:1.45}.sg-toast__close{background:none;border:none;cursor:pointer;opacity:.5;transition:opacity .14s;color:inherit;padding:0;display:flex;width:20px;height:20px;align-items:center;justify-content:center}.sg-toast__close:hover{opacity:1}.sg-co-stages{display:flex;align-items:center;gap:4px;margin-left:auto;flex-wrap:wrap}.sg-co-stage{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--sg-ink-4);padding:3px 8px;border-radius:20px;background:var(--sg-surface-3);border:1px solid var(--sg-border);letter-spacing:.02em}.sg-co-stage--active{color:var(--sg-warning);background:var(--sg-warning-light);border-color:var(--sg-warning-mid)}.sg-co-stage--done{color:var(--sg-success);background:var(--sg-success-light);border-color:var(--sg-success-mid)}.sg-bag-retrieval{display:flex;flex-direction:column;gap:12px;animation:sg-slide-in .18s ease}.sg-bag-retrieval__header{display:flex;align-items:center;justify-content:space-between;gap:8px}.sg-bag-retrieval__title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--sg-ink-2);text-transform:uppercase;letter-spacing:.05em;font-family:var(--sg-font-ui)}.sg-bag-retrieval__dots{display:flex;align-items:center;gap:5px}.sg-bag-dot{width:9px;height:9px;border-radius:50%;background:var(--sg-border);transition:background .2s,transform .2s}.sg-bag-dot--done{background:var(--sg-success)}.sg-bag-dot--active{background:var(--sg-warning);transform:scale(1.35);box-shadow:0 0 0 2px var(--sg-warning-light),0 0 0 3px var(--sg-warning)}.sg-bag-card{background:var(--sg-surface);border:1.5px solid var(--sg-border);border-radius:var(--sg-r-md);padding:14px 16px;display:flex;flex-direction:column;gap:10px}.sg-bag-card__cell-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.sg-bag-card__cell-label{font-size:11px;font-weight:600;color:var(--sg-ink-4);text-transform:uppercase;letter-spacing:.05em;font-family:var(--sg-font-ui)}.sg-bag-card__cell-code{font-family:var(--sg-font-mono);font-size:22px;font-weight:800;color:var(--sg-ink-1);letter-spacing:.06em}.sg-bag-card__location{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--sg-ink-3);font-family:var(--sg-font-ui)}.sg-bag-card__position{background:var(--sg-warning-light);border:1px solid var(--sg-warning-mid);border-radius:7px;padding:9px 12px;display:flex;flex-direction:column;gap:3px}.sg-bag-card__position-label{font-size:10px;font-weight:600;color:var(--sg-warning);text-transform:uppercase;letter-spacing:.05em;font-family:var(--sg-font-ui)}.sg-bag-card__position-value{font-size:15px;font-weight:800;color:var(--sg-ink-1);letter-spacing:.02em;font-family:var(--sg-font-ui)}.sg-bag-card__remaining{border-top:1px solid var(--sg-border);padding-top:8px;display:flex;flex-direction:column;gap:5px;font-family:var(--sg-font-ui)}.sg-bag-card__remaining>span{font-size:10px;color:var(--sg-ink-4);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.sg-bag-card__remaining-list{display:flex;flex-wrap:wrap;gap:5px}.sg-bag-card__remaining-item{display:inline-flex;align-items:center;gap:4px;background:var(--sg-surface-2);border:1px solid var(--sg-border);border-radius:5px;padding:3px 8px;font-size:11px}.sg-bag-card__remaining-cell{font-family:var(--sg-font-mono);font-weight:700;color:var(--sg-ink-2)}.sg-bag-card__remaining-pos{font-size:10px;color:var(--sg-ink-4)}.sg-bags-done{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--sg-success-text);background:var(--sg-success-light);border:1px solid var(--sg-success-mid);border-radius:7px;padding:8px 12px;animation:sg-slide-in .18s ease;font-family:var(--sg-font-ui)}@keyframes sg-fade-in{0%{opacity:0}to{opacity:1}}@keyframes sg-scale-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes sg-slide-in{0%{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}@keyframes sg-sheet-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes sg-pulse-dot{0%,to{opacity:1}50%{opacity:.3}}@keyframes sg-pulse-cell{0%,to{box-shadow:none}50%{box-shadow:0 0 0 3px #b71c1c33}}@media(max-width:1040px){.sg-layout{grid-template-columns:1fr}.sg-layout__side{display:grid;grid-template-columns:1fr 1fr;gap:14px}}@media(max-width:720px){.sg-page-header{flex-direction:column;gap:10px}.sg-page-sub{margin-left:0}.sg-layout__side{grid-template-columns:1fr}.sg-answer-btn{min-width:100px}.sg-cell-grid{grid-template-columns:repeat(auto-fill,minmax(30px,1fr));max-height:195px}.sg-cell{font-size:9px}.sg-cell-stats-row{gap:3px}.sg-type-grid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr))}.sg-toast-wrap{top:8px;right:8px;width:calc(100vw - 16px)}}@media(max-width:440px){.sg-action-row{flex-direction:column}.sg-answer-btn{min-width:unset}.sg-checkout-add-row{flex-direction:column}.sg-add-action-btn{min-width:unset}.sg-bag-card__cell-code{font-size:18px}.sg-co-stages{display:none}}.asset-grid{display:grid;grid-template-columns:260px 1fr;gap:20px;align-items:start}.page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px;gap:14px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:10px}.page-subtitle{font-size:13px;color:var(--tx3, #94a3b8);margin-top:3px}.page-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}.badge-red{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border:1px solid var(--danger-border, #fecaca)}.badge-amber{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border:1px solid var(--warning-border, #fde68a)}.badge-green{background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border:1px solid var(--success-border, #bbf7d0)}.badge-gray{background:var(--bg, #f1f5f9);color:var(--tx3, #94a3b8);border:1px solid var(--border, #e2e8f0)}.card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:var(--radius, 10px);padding:20px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.08));transition:background .25s,border-color .25s}.card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px}.card-title{font-size:15px;font-weight:700;color:var(--tx1, #0f172a)}.section-label{font-size:12px;font-weight:700;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px;padding:0 2px}.session-item{padding:13px 14px;border-radius:var(--radius-sm, 6px);border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);cursor:pointer;transition:all .15s;margin-bottom:8px}.session-item.active{border-color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe)}.session-item.has-missing{border-color:var(--danger-border, #fecaca);background:var(--danger-light, #fee2e2)}.session-item:hover{transform:translate(2px);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.08))}.session-item-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}.session-cell{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0}.session-cell.missing{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border:1px solid var(--danger-border, #fecaca)}.session-cell.pending{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border:1px solid var(--warning-border, #fde68a)}.session-info{flex:1;min-width:0}.session-name{font-size:13px;font-weight:700;color:var(--tx1, #0f172a);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-id{font-size:11px;color:var(--tx3, #94a3b8)}.session-badges{display:flex;gap:5px;flex-wrap:wrap}.asset-detail-header{border-left:4px solid var(--warning, #d97706)}.asset-detail-header.success{border-left-color:var(--success, #16a34a)}.asset-detail-header.warning{border-left-color:var(--warning, #d97706)}.asset-detail-header.danger{border-left-color:var(--danger, #dc2626)}.student-name-large{font-size:20px;font-weight:700;color:var(--tx1, #0f172a);margin-bottom:2px}.student-meta{font-size:13px;color:var(--tx3, #94a3b8)}.header-badges{display:flex;gap:8px;flex-wrap:wrap}.progress-container{margin-top:16px}.progress-header{display:flex;justify-content:space-between;font-size:13px;margin-bottom:5px}.progress-label{color:var(--tx2, #475569);font-weight:500}.progress-value{font-weight:700;color:var(--tx1, #0f172a)}.progress-track{height:10px;background:var(--bg, #f1f5f9);border-radius:5px;overflow:hidden;border:1px solid var(--border, #e2e8f0)}.progress-fill{height:100%;border-radius:5px;background:var(--success, #16a34a);transition:width .4s}.progress-fill.warning{background:var(--warning, #d97706)}.progress-fill.danger{background:var(--danger, #dc2626)}.asset-item{display:flex;align-items:center;gap:14px;padding:14px 12px;border-radius:var(--radius-sm, 6px);margin-bottom:8px;transition:all .15s}.asset-item.missing{background:var(--danger-light, #fee2e2);border:1px solid var(--danger-border, #fecaca)}.asset-item.present{background:var(--success-light, #dcfce7);border:1px solid var(--success-border, #bbf7d0)}.asset-item.pending{background:var(--bg, #f1f5f9);border:1px solid var(--border, #e2e8f0)}.asset-icon{width:40px;height:40px;border-radius:var(--radius-sm, 6px);background:var(--bg-card, #ffffff);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;border:1px solid var(--border, #e2e8f0)}.asset-details{flex:1;min-width:0}.asset-name{font-size:14px;font-weight:600;color:var(--tx1, #0f172a)}.asset-meta{font-size:12px;color:var(--tx3, #94a3b8);margin-top:2px}.asset-actions{display:flex;gap:6px}.action-btn{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx3, #94a3b8);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.action-btn:hover{transform:scale(1.1)}.action-btn.present{border-color:var(--success, #16a34a);background:var(--success, #16a34a);color:#fff}.action-btn.missing{border-color:var(--danger, #dc2626);background:var(--danger, #dc2626);color:#fff}.action-btn.present:hover{background:var(--success-hover, #15803d)}.action-btn.missing:hover{background:var(--danger-hover, #b91c1c)}.qr-scanner-wrapper{position:relative}.qr-scanner-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8)}.qr-scanner-input{padding-left:32px;width:200px;font-size:13px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:14px;font-weight:600;padding:10px 18px;border-radius:var(--radius-sm, 6px);border:none;cursor:pointer;transition:all .15s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.btn-success{background:var(--success, #16a34a);color:#fff}.btn-success:hover{background:#15803d;box-shadow:0 4px 12px #16a34a4d}.btn-danger:hover{background:#b91c1c;box-shadow:0 4px 12px #dc26264d}.btn-warning{background:var(--warning, #d97706);color:#fff}.btn-warning:hover{background:#b45309;box-shadow:0 4px 12px #d977064d}.btn-ghost{background:transparent;color:var(--tx2, #475569);border:1px solid var(--border, #e2e8f0)}.btn-ghost:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}.divider{height:1px;background:var(--border, #e2e8f0);margin:16px 0}.modal-bg{position:fixed;inset:0;background:#00000073;z-index:900;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:var(--radius-lg, 16px);box-shadow:var(--shadow-lg, 0 8px 30px rgba(0,0,0,.14));width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.modal-title{font-size:17px;font-weight:700;color:var(--tx1, #0f172a)}.modal-close-btn{width:30px;height:30px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f1f5f9);color:var(--tx2, #475569);font-size:17px;display:flex;align-items:center;justify-content:center;cursor:pointer}.modal-close-btn:hover{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626)}.modal-body{padding:18px 24px}.modal-foot{padding:14px 24px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:10px}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:13px;font-weight:600;color:var(--tx2, #475569)}.form-hint{font-size:11px;color:var(--tx3, #94a3b8)}.required{color:var(--danger, #dc2626);margin-left:2px}.input,textarea.input{background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:var(--radius-sm, 6px);color:var(--tx1, #0f172a);font-size:14px;padding:10px 12px;outline:none;width:100%;transition:border-color .15s,box-shadow .15s;font-family:inherit}.input:focus,textarea.input:focus{border-color:var(--border-focus, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}textarea.input{resize:vertical;min-height:80px}.warning-alert{padding:12px 14px;background:var(--danger-light, #fee2e2);border:1px solid var(--danger-border, #fecaca);border-radius:var(--radius-sm, 6px);font-size:13px;color:var(--danger, #dc2626);line-height:1.6}@media(max-width:768px){.asset-grid{grid-template-columns:1fr}.page-hdr{flex-direction:column}.asset-item{flex-wrap:wrap}.asset-actions{width:100%;justify-content:flex-end}.modal{max-width:90%}}@media(max-width:480px){.qr-scanner-input{width:150px}.session-item-header{flex-wrap:wrap}.header-badges{width:100%;justify-content:flex-start}}:root{--primary: #2563eb;--primary-light: #dbeafe;--success: #16a34a;--success-light: #dcfce7;--warning: #d97706;--warning-light: #fef3c7;--danger: #dc2626;--danger-light: #fee2e2;--purple: #7c3aed;--purple-light: #ede9fe;--tx1: #0f172a;--tx2: #64748b;--border: #e2e8f0;--surface: #ffffff;--bg: #f8fafc;--radius: 10px;--shadow: 0 1px 3px rgba(0, 0, 0, .07), 0 4px 12px rgba(0, 0, 0, .05)}.vk-hdr{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 20px;background:var(--surface);border-bottom:1px solid var(--border);margin-bottom:0}.vk-hdr__title{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:800;color:var(--tx1);letter-spacing:-.3px}.vk-hdr__sub{font-size:12px;color:var(--tx2);margin-top:3px}.vk-hdr__acts{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.vk-stepper{display:flex;align-items:center;padding:14px 20px;background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto}.vk-step{display:flex;align-items:center;gap:6px;flex-shrink:0}.vk-step__bubble{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0;transition:all .2s}.vk-step__bubble--idle{background:#e2e8f0;color:var(--tx2)}.vk-step__bubble--active{background:var(--primary);color:#fff;box-shadow:0 0 0 3px #2563eb33}.vk-step__bubble--done{background:var(--success);color:#fff}.vk-step__label{font-size:12px;color:var(--tx2);font-weight:500}.vk-step__label--active{color:var(--primary);font-weight:700}.vk-step__label--done{color:var(--success)}.vk-step__line{width:32px;height:2px;background:var(--border);margin:0 4px;flex-shrink:0;transition:background .2s}.vk-step__line--done{background:var(--success)}.vk-layout{display:grid;grid-template-columns:1fr 300px;gap:20px;padding:20px;max-width:1240px;margin:0 auto}@media(max-width:860px){.vk-layout{grid-template-columns:1fr}.vk-sidebar{display:none}}.vk-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:16px}.vk-card__title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--tx1);padding-bottom:14px;border-bottom:1px solid var(--border)}.vk-section{display:flex;flex-direction:column;gap:12px}.vk-section__label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--tx2);text-transform:uppercase;letter-spacing:.5px}.vk-divider{height:1px;background:var(--border);margin:4px 0}.vk-form-group{display:flex;flex-direction:column;gap:5px}.vk-label{font-size:13px;font-weight:600;color:var(--tx1)}.vk-req{color:var(--danger)}.vk-opt,.vk-tiny-note{color:var(--tx2);font-weight:400;font-size:11px}.vk-hint{font-size:11.5px;color:var(--tx2);line-height:1.4}.vk-err-msg{font-size:11.5px;color:var(--danger)}.vk-warn-inline{font-size:12px;color:var(--warning);padding:8px 10px;background:var(--warning-light);border-radius:6px}.vk-input{padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;background:var(--surface);color:var(--tx1);transition:border-color .15s;width:100%;box-sizing:border-box}.vk-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.vk-input--err{border-color:var(--danger)}.vk-input--sm{padding:6px 10px;font-size:13px}.vk-input--mono{font-family:Courier New,monospace;letter-spacing:.5px}.vk-input--textarea{resize:vertical;min-height:64px;line-height:1.5}.vk-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:560px){.vk-grid-2{grid-template-columns:1fr}}.vk-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.vk-type-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;border:2px solid var(--border);border-radius:10px;background:var(--surface);cursor:pointer;transition:all .15s;text-align:center}.vk-type-btn:hover,.vk-type-btn--on{border-color:var(--primary);background:var(--primary-light)}.vk-type-btn__icon{color:var(--primary)}.vk-type-btn__label{font-size:13px;font-weight:700;color:var(--tx1)}.vk-type-btn__desc{font-size:11px;color:var(--tx2)}.vk-group-counter-row{display:flex;align-items:center;gap:10px}.vk-counter-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s;color:var(--tx1)}.vk-counter-btn:hover:not(:disabled){background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.vk-counter-btn:disabled{opacity:.4;cursor:not-allowed}.vk-counter-val{font-size:20px;font-weight:800;color:var(--tx1);min-width:40px;text-align:center}.vk-phone-first{display:flex;flex-direction:column;gap:6px}.vk-search-wrap{position:relative;display:flex;align-items:center}.vk-search-icon{position:absolute;left:12px;color:var(--tx2);pointer-events:none}.vk-search-input{width:100%;padding:10px 12px 10px 36px;border:1px solid var(--border);border-radius:8px;font-size:13px;background:var(--surface);color:var(--tx1);box-sizing:border-box;transition:border-color .15s}.vk-search-input:focus{outline:none;border-color:var(--primary)}.vk-no-match{display:flex;align-items:center;font-size:13px;color:var(--tx2);padding:10px;background:#f8fafc;border-radius:8px;border:1px dashed var(--border);flex-wrap:wrap;gap:8px}.vk-existing-card{display:flex;align-items:flex-start;gap:14px;padding:14px;background:var(--success-light);border:1px solid var(--success);border-radius:10px}.vk-existing-card__icon{flex-shrink:0;margin-top:2px}.vk-existing-card__body{flex:1;min-width:0}.vk-existing-card__title{font-size:11px;font-weight:700;color:var(--success);text-transform:uppercase;letter-spacing:.5px}.vk-existing-card__name{font-size:15px;font-weight:800;color:var(--tx1);margin:2px 0 4px}.vk-existing-card__meta{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--tx2)}.vk-existing-card__meta span{display:flex;align-items:center;gap:3px}.vk-existing-card__acts{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.vk-confirmed-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--success-light);border:1px solid var(--success);border-radius:8px;font-size:13px;color:var(--tx1)}.vk-confirmed-bar span{flex:1}.vk-id-scanner{display:flex;flex-direction:column;gap:8px}.vk-id-scanner__row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.vk-id-captured{display:flex;align-items:center;gap:8px;flex:1;padding:6px 12px;background:var(--success-light);border:1px solid var(--success);border-radius:7px}.vk-id-captured__val{font-size:12px;font-family:Courier New,monospace;flex:1;color:var(--tx1)}.vk-id-waiting{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--tx2);flex:1;padding:6px 12px;border:1px dashed var(--border);border-radius:7px}.vk-id-captured-badge{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--success);font-family:Courier New,monospace;padding:3px 8px;background:var(--success-light);border-radius:5px;margin-top:4px}.vk-scanner__usb-badge{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--tx2)}.vk-scanner__usb-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:vk-pulse 1.5s infinite}@keyframes vk-pulse{0%,to{opacity:1}50%{opacity:.3}}.vk-scanner{display:flex;flex-direction:column;gap:10px}.vk-scanner__cam{margin-top:4px;border-radius:10px;overflow:hidden}.vk-scanner__row{display:flex;gap:8px}.vk-camera-wrap{display:flex;flex-direction:column;gap:6px}.vk-camera-select{padding:5px 10px;border:1px solid var(--border);border-radius:6px;font-size:12px}.vk-camera-err{font-size:12px;color:var(--danger);display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--danger-light);border-radius:6px}.vk-link{color:var(--primary);background:none;border:none;cursor:pointer;font-size:12px;text-decoration:underline}.vk-host-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:8px;overflow:hidden;max-height:220px;overflow-y:auto}.vk-host-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--border)}.vk-host-item:last-child{border-bottom:none}.vk-host-item:hover{background:var(--primary-light)}.vk-host-selected{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--primary-light);border:1px solid var(--primary);border-radius:8px}.vk-host-name{font-size:13px;font-weight:700;color:var(--tx1);display:flex;align-items:center;gap:6px}.vk-host-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:11px;color:var(--tx2);margin-top:2px}.vk-host-meta span{display:flex;align-items:center;gap:3px}.vk-dot-online{width:7px;height:7px;border-radius:50%;background:var(--success);display:inline-block}.vk-desk-badge{background:var(--primary-light);color:var(--primary);font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px}.vk-avatar{width:38px;height:38px;border-radius:10px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0}.vk-avatar--sm{width:30px;height:30px;font-size:11px;border-radius:7px}.vk-avatar--xs{width:26px;height:26px;font-size:10px;border-radius:6px}.vk-card-number-wrap{display:flex;flex-direction:column;gap:6px;padding:14px 16px;background:#f0f9ff;border:1.5px solid #bae6fd;border-radius:10px}.vk-card-number-wrap__header{display:flex;align-items:center;gap:7px;color:#0369a1}.vk-card-number-wrap__title{font-size:13px;font-weight:700;color:#0369a1}.vk-card-number-wrap__row{display:flex;align-items:center;gap:8px}.vk-card-number-wrap__icon-wrap{position:relative;flex:1}.vk-card-number-wrap__icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--tx2);pointer-events:none}.vk-card-number-input{padding-left:32px!important;font-family:Courier New,monospace;font-size:14px;font-weight:700;letter-spacing:1px;text-transform:uppercase}.vk-card-number-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--success);background:var(--success-light);border:1px solid var(--success);border-radius:6px;padding:4px 10px;margin-top:2px}.vk-card-assigned-pill{display:inline-flex;align-items:center;gap:6px;background:var(--success-light);border:1px solid var(--success);color:var(--success);font-size:13px;font-weight:700;padding:5px 14px;border-radius:20px}.vk-card-mini-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;color:#0369a1;background:#e0f2fe;border-radius:4px;padding:1px 5px;margin-left:4px}.vk-sticker-hero{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;background:var(--bg);border:1.5px dashed var(--border);border-radius:10px;text-align:center}.vk-sticker-icon{width:56px;height:56px;border-radius:16px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;color:var(--primary)}.vk-sticker-hero__title{font-size:14px;font-weight:700;color:var(--tx1)}.vk-sticker-hero__sub{font-size:12px;color:var(--tx2)}.vk-success-panel{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 20px;background:var(--success-light);border:2px solid var(--success);border-radius:12px;text-align:center}.vk-success-panel__icon{color:var(--success)}.vk-success-panel__title{font-size:17px;font-weight:800;color:var(--tx1)}.vk-success-panel__val{font-size:13px;font-family:Courier New,monospace;color:var(--tx2);background:var(--surface);padding:4px 12px;border-radius:6px;border:1px solid var(--border)}.vk-success-panel__sub{font-size:13px;color:var(--tx2);line-height:1.5}.vk-status-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:13px}.vk-status-bar--loading{background:var(--warning-light);color:var(--warning)}.vk-done-banner{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--success);border-radius:10px;color:#fff}.vk-done-banner__title{font-size:16px;font-weight:800}.vk-done-banner__sub{font-size:12px;opacity:.85;margin-top:3px}.vk-gate-instruction{display:flex;align-items:flex-start;gap:16px;padding:18px;background:var(--primary-light);border:1.5px solid var(--primary);border-radius:12px}.vk-gate-instruction__icon{width:52px;height:52px;border-radius:14px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.vk-gate-instruction__body{flex:1}.vk-gate-instruction__title{font-size:15px;font-weight:800;color:var(--tx1);margin-bottom:6px}.vk-gate-instruction__desc{font-size:13px;color:var(--tx1);line-height:1.6;margin-bottom:8px}.vk-gate-instruction__host{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--primary);padding:8px 10px;background:#fff9;border-radius:7px}.vk-gate-instruction__host strong{font-weight:700}.vk-summary{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:8px;overflow:hidden}.vk-summary__row{display:flex;padding:9px 14px;border-bottom:1px solid var(--border)}.vk-summary__row:last-child{border-bottom:none}.vk-summary__row:nth-child(2n){background:var(--bg)}.vk-summary__key{font-size:11.5px;color:var(--tx2);font-weight:600;width:110px;flex-shrink:0;display:flex;align-items:center}.vk-summary__val{font-size:12.5px;color:var(--tx1);font-weight:500;flex:1;word-break:break-all}.vk-alert{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:8px;border:1px solid}.vk-alert--success{background:var(--success-light);border-color:var(--success);color:var(--tx1)}.vk-alert--error{background:var(--danger-light);border-color:var(--danger);color:var(--tx1)}.vk-alert--warning{background:var(--warning-light);border-color:var(--warning);color:var(--tx1)}.vk-alert--info{background:var(--primary-light);border-color:var(--primary);color:var(--tx1)}.vk-alert--red,.vk-alert--blocked{background:#fff5f5;border-color:var(--danger);color:var(--danger)}.vk-alert--flagged{background:var(--warning-light);border-color:var(--warning);color:var(--tx1)}.vk-alert__icon{flex-shrink:0;margin-top:2px}.vk-alert__body{flex:1}.vk-alert__title{font-weight:700;font-size:13px;margin-bottom:3px}.vk-alert__msg{font-size:12.5px;line-height:1.5;opacity:.9}.vk-alert__acts{display:flex;gap:6px;flex-direction:column}.vk-info-bar{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-radius:8px;border:1px solid;font-size:13px}.vk-info-bar--blue{background:var(--primary-light);border-color:var(--primary);color:var(--tx1)}.vk-info-bar--green{background:var(--success-light);border-color:var(--success);color:var(--tx1)}.vk-info-bar--purple{background:var(--purple-light);border-color:var(--purple);color:var(--tx1)}.vk-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.vk-pill--green{background:var(--success-light);color:var(--success)}.vk-pill--green-sm{background:var(--success-light);color:var(--success);font-size:11px;padding:2px 8px}.vk-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:10px;font-size:10px;font-weight:700}.vk-badge--danger{background:var(--danger-light);color:var(--danger)}.vk-badge--purple{background:var(--purple-light);color:var(--purple)}.vk-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:8px;border:1.5px solid transparent;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none;white-space:nowrap}.vk-btn:disabled{opacity:.5;cursor:not-allowed}.vk-btn--primary{background:var(--primary);color:#fff;border-color:var(--primary)}.vk-btn--primary:hover:not(:disabled){background:#1d4ed8}.vk-btn--success{background:var(--success);color:#fff;border-color:var(--success)}.vk-btn--success:hover:not(:disabled){background:#15803d}.vk-btn--ghost{background:transparent;color:var(--tx1);border-color:var(--border)}.vk-btn--ghost:hover:not(:disabled){background:var(--bg)}.vk-btn--active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.vk-btn--sm{padding:5px 12px;font-size:12px}.vk-btn--xs{padding:3px 8px;font-size:11px}.vk-btn--lg{padding:12px 20px;font-size:14px;font-weight:700}.vk-btn-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.vk-btn-row--end{justify-content:flex-end}.vk-toast-wrap{position:fixed;top:16px;right:16px;z-index:999;display:flex;flex-direction:column;gap:8px;max-width:340px}.vk-toast{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;box-shadow:0 4px 20px #00000026;font-size:13px;font-weight:500;animation:vk-slide-in .2s ease}.vk-toast--success{background:var(--success);color:#fff}.vk-toast--error{background:var(--danger);color:#fff}.vk-toast--warning{background:var(--warning);color:#fff}.vk-toast--info{background:var(--primary);color:#fff}.vk-toast__icon{flex-shrink:0}.vk-toast__msg{flex:1}.vk-toast__close{background:none;border:none;color:inherit;cursor:pointer;opacity:.7;font-size:16px;line-height:1;padding:0}.vk-toast__close:hover{opacity:1}@keyframes vk-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.vk-sidebar{display:flex;flex-direction:column;gap:14px}.vk-side-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.vk-side-card--role{border-top:3px solid var(--primary)}.vk-side-title{padding:10px 14px;font-size:12px;font-weight:800;color:var(--tx1);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px;background:var(--bg);text-transform:uppercase;letter-spacing:.5px}.vk-role-list{display:flex;flex-direction:column}.vk-role-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}.vk-role-item:last-child{border-bottom:none}.vk-role-item--active{background:var(--primary-light)}.vk-role-item__badge{padding:2px 10px;border-radius:4px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;margin-top:2px;background:var(--primary);color:#fff}.vk-role-item__badge--sec{background:var(--warning)}.vk-role-item__title{font-size:13px;font-weight:700;color:var(--tx1);margin-bottom:2px}.vk-role-item__desc{font-size:11.5px;color:var(--tx2);line-height:1.4}.vk-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);padding:12px 14px;gap:4px}.vk-stat{text-align:center}.vk-stat__val{font-size:20px;font-weight:900;color:var(--tx1);line-height:1}.vk-stat__lbl{font-size:10px;color:var(--tx2);margin-top:2px;font-weight:600;text-transform:uppercase}.vk-active-list{display:flex;flex-direction:column}.vk-active-item{display:flex;align-items:center;gap:9px;padding:9px 14px;border-bottom:1px solid var(--border);transition:background .1s}.vk-active-item:last-child{border-bottom:none}.vk-active-item--overstay{background:#dc26260a}.vk-active-item__name{font-size:12px;font-weight:700;color:var(--tx1);display:flex;align-items:center;gap:4px;flex-wrap:wrap}.vk-active-item__meta{font-size:11px;color:var(--tx2);margin-top:1px;display:flex;align-items:center;flex-wrap:wrap;gap:4px}.vk-active-item__time{font-size:11px;color:var(--tx2);flex-shrink:0;display:flex;align-items:center;gap:3px}.vk-active-item__time--alert{color:var(--danger);font-weight:700}.vk-muted-center{text-align:center;color:var(--tx2);font-size:13px}.vk-spin-sm{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:vk-spin .7s linear infinite}.vk-spin-sm--dark{border-color:var(--border);border-top-color:var(--tx2)}.vk-spin{animation:vk-spin .8s linear infinite}@keyframes vk-spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #ffffff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:toast-slide-in .3s ease;border-left:4px solid var(--primary, #2563eb);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toast-success{border-left-color:var(--success, #16a34a)}.toast-error{border-left-color:var(--danger, #dc2626)}.toast-warning{border-left-color:var(--warning, #d97706)}.toast-info{border-left-color:var(--primary, #2563eb)}.toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.toast-success .toast-icon{color:var(--success, #16a34a)}.toast-error .toast-icon{color:var(--danger, #dc2626)}.toast-warning .toast-icon{color:var(--warning, #d97706)}.toast-info .toast-icon{color:var(--primary, #2563eb)}.toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;transition:color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.student-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.student-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.student-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.student-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.student-tabs-container{display:flex;gap:2px;margin-bottom:24px;border-bottom:2px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);padding:0 4px;border-radius:12px 12px 0 0}.student-tab-btn{padding:14px 24px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:500;color:var(--tx2, #475569);border-bottom:3px solid transparent;margin-bottom:-2px;display:flex;align-items:center;gap:10px;transition:all .2s;font-family:inherit;position:relative}.student-tab-btn:hover{color:var(--primary, #2563eb);background:var(--bg-hover, #f1f5f9)}.student-tab-btn.active{color:var(--primary, #2563eb);border-bottom-color:var(--primary, #2563eb);font-weight:600;background:var(--primary-light, #dbeafe)}.student-tab-count{background:var(--bg, #f1f5f9);color:var(--tx3, #64748b);border:1px solid var(--border, #e2e8f0);border-radius:20px;font-size:11px;font-weight:600;padding:2px 8px;transition:all .2s}.student-tab-btn.active .student-tab-count{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.student-stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-bottom:24px}.stats-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.stats-primary{border-left:4px solid var(--primary, #2563eb)}.stats-success{border-left:4px solid var(--success, #16a34a)}.stats-warning{border-left:4px solid var(--warning, #d97706)}.stats-danger{border-left:4px solid var(--danger, #dc2626)}.stats-info{border-left:4px solid var(--info, #0891b2)}.stats-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg, #f8fafc)}.stats-primary .stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.stats-success .stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.stats-warning .stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.stats-danger .stats-icon{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626)}.stats-info .stats-icon{background:var(--info-light, #cffafe);color:var(--info, #0891b2)}.stats-content{flex:1}.stats-title{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.stats-value{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.student-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #ffffff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.student-search-wrapper{position:relative;flex:1;min-width:280px}.student-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.student-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.student-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.student-search-input::placeholder{color:var(--tx3, #94a3b8)}.student-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.student-filter-icon{color:var(--tx3, #94a3b8)}.student-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.student-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.student-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s;margin-bottom:24px}.student-card:hover{box-shadow:0 8px 24px #00000014}.student-card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--border, #e2e8f0)}.student-card-title{font-size:16px;font-weight:600;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.student-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:20px}.student-table{width:100%;border-collapse:separate;border-spacing:0}.student-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0)}.student-table td{padding:16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #ffffff);transition:background-color .2s}.student-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.student-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary, #2563eb) 0%,#7c3aed 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;text-transform:uppercase;flex-shrink:0;box-shadow:0 4px 10px #2563eb33}.student-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.student-reg-number{font-family:SF Mono,Fira Code,monospace;font-size:13px;font-weight:600;color:var(--tx1, #0f172a);background:var(--bg, #f1f5f9);padding:4px 8px;border-radius:6px;border:1px solid var(--border, #e2e8f0);display:inline-block;white-space:nowrap}.student-name{font-weight:600;color:var(--tx1, #0f172a)}.student-expiry-info{display:flex;flex-direction:column;gap:4px}.student-expiry-date{font-size:13px;font-weight:500;color:var(--tx2, #475569)}.student-expiry-date.expired{color:var(--danger, #dc2626);text-decoration:line-through}.student-expiry-date.expiring-soon{color:var(--warning, #d97706)}.student-expiry-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;width:fit-content}.student-expiry-badge.expired{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border:1px solid var(--danger-border, #fecaca)}.student-expiry-badge.soon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border:1px solid var(--warning-border, #fde68a)}.student-status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:30px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent}.student-status-badge.active{background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border-color:var(--success-border, #bbf7d0)}.student-status-badge.inactive{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger-border, #fecaca)}.student-status-badge.warning{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border-color:var(--warning-border, #fde68a)}.student-last-scan{font-size:12px;color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.student-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.student-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.student-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.student-action-btn:disabled{opacity:.5;cursor:not-allowed}.student-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px;border-top:1px solid var(--border, #e2e8f0)}.student-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.student-pagination-buttons{display:flex;gap:6px}.student-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.student-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.student-pagination-btn.active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.student-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.student-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #ffffff);border-radius:20px;border:2px dashed var(--border, #e2e8f0);margin-bottom:24px}.student-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.student-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.student-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.student-skeleton-table{background:var(--bg-card, #ffffff);border-radius:16px;padding:24px;margin-bottom:24px}.student-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.student-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.student-skeleton-list{display:flex;flex-direction:column;gap:12px}.student-skeleton-item{height:60px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}.student-import-section{margin-top:20px}.student-upload-area{margin-bottom:24px}.student-upload-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;border:2px dashed var(--border, #e2e8f0);border-radius:12px;background:var(--bg, #f8fafc);cursor:pointer;transition:all .2s;text-align:center}.student-upload-dropzone:hover{border-color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe)}.student-upload-icon{color:var(--tx3, #94a3b8);margin-bottom:16px}.student-upload-dropzone h4{font-size:16px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.student-upload-dropzone p{font-size:13px;color:var(--tx3, #64748b);margin-bottom:16px}.student-selected-file{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-card, #ffffff);border:1px solid var(--primary, #2563eb);border-radius:30px;color:var(--primary, #2563eb);font-size:13px;font-weight:500}.student-upload-progress{margin-top:16px;padding:12px;background:var(--bg, #f8fafc);border-radius:8px}.student-progress-bar{height:6px;background:var(--primary, #2563eb);border-radius:3px;transition:width .3s ease;margin-bottom:8px}.student-upload-progress span{font-size:12px;color:var(--tx2, #475569)}.student-template-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border, #e2e8f0)}.student-template-section h4{font-size:13px;font-weight:600;color:var(--tx2, #475569);margin-bottom:12px}.student-required-columns{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.student-column-badge{padding:4px 10px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:20px;font-size:12px;color:var(--primary, #2563eb);font-family:monospace}.student-template-actions{display:flex;gap:12px;flex-wrap:wrap}.student-upload-list{display:flex;flex-direction:column;gap:12px}.student-upload-item{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:10px;transition:all .2s}.student-upload-item:hover{background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb)}.student-upload-info{flex:1}.student-upload-file{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);margin-bottom:6px}.student-upload-meta{display:flex;gap:12px;font-size:12px;color:var(--tx3, #64748b);margin-bottom:8px}.student-upload-stats{display:flex;gap:12px}.student-stat{font-size:12px;font-weight:500;padding:2px 8px;border-radius:12px}.student-stat.success{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.student-stat.warning{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.student-upload-status{display:flex;align-items:center;gap:8px}.student-empty-history{text-align:center;padding:40px 20px;color:var(--tx3, #64748b)}.student-empty-history svg{margin-bottom:12px}.student-photo-section{display:flex;align-items:center;gap:20px;margin-bottom:24px;padding:16px;background:var(--bg, #f8fafc);border-radius:12px}.student-photo-preview{width:80px;height:80px;border-radius:50%;overflow:hidden;border:3px solid var(--bg-card, #ffffff);box-shadow:0 4px 12px #0000001a}.student-photo-img{width:100%;height:100%;object-fit:cover}.student-photo-placeholder{width:100%;height:100%;background:var(--bg-hover, #f1f5f9);display:flex;align-items:center;justify-content:center;color:var(--tx3, #64748b)}.student-photo-controls{flex:1;display:flex;gap:8px}.student-info-card{background:var(--bg, #f8fafc);border-radius:10px;padding:16px;margin-bottom:20px;border-left:3px solid var(--primary, #2563eb)}.student-info-card p{margin-bottom:8px;font-size:14px;color:var(--tx2, #475569)}.student-info-card p:last-child{margin-bottom:0}.student-info-card strong{color:var(--tx1, #0f172a);font-weight:600;min-width:100px;display:inline-block}.modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:modal-fade-in .2s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:modal-scale-in .3s ease}@keyframes modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.modal-title{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.modal-body{padding:20px 28px}.modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.form-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.required{color:var(--danger, #dc2626);margin-left:2px;font-size:14px}.form-hint{font-size:11px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.input,select.input{background:var(--bg-input, #ffffff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.input:focus,select.input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.input.error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}.error-message{color:var(--danger, #dc2626);font-size:11px;margin-top:4px;display:block}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.status-toggle{display:flex;align-items:center;gap:12px}.status-label{font-size:13px;font-weight:500}.status-label.active{color:var(--success, #16a34a)}.status-label.inactive{color:var(--danger, #dc2626)}.modern-switch{position:relative;display:inline-block;cursor:pointer}.modern-switch.small input+.switch-slider{width:40px;height:22px}.modern-switch.small input+.switch-slider .switch-handle{width:18px;height:18px}.modern-switch.small.checked input+.switch-slider .switch-handle{transform:translate(18px)}.modern-switch.medium input+.switch-slider{width:52px;height:28px}.modern-switch.medium input+.switch-slider .switch-handle{width:24px;height:24px}.modern-switch.medium.checked input+.switch-slider .switch-handle{transform:translate(24px)}.modern-switch input{opacity:0;width:0;height:0;position:absolute}.modern-switch .switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.modern-switch.checked .switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.modern-switch .switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.modern-switch.disabled{opacity:.5;cursor:not-allowed}.confirm-icon{text-align:center;margin-bottom:16px}.confirm-icon .text-success{color:var(--success, #16a34a)}.confirm-icon .text-danger{color:var(--danger, #dc2626)}.confirm-message{font-size:14px;color:var(--tx2, #475569);text-align:center;line-height:1.6}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.btn-sm{font-size:12px;padding:8px 14px}.btn-primary{background:var(--primary, #2563eb);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.btn-danger{background:var(--danger, #dc2626);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.btn:disabled{opacity:.5;cursor:not-allowed}.spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-right:6px}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}@media(max-width:1200px){.student-stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:992px){.student-stats-grid{grid-template-columns:repeat(2,1fr)}.student-upload-item{flex-direction:column;align-items:flex-start;gap:12px}.student-upload-status{width:100%;justify-content:flex-end}}@media(max-width:768px){.student-page-hdr{flex-direction:column}.student-page-actions{width:100%;justify-content:flex-start}.student-tabs-container{overflow-x:auto;padding-bottom:4px}.student-tab-btn{padding:12px 16px;white-space:nowrap}.student-filters-bar{flex-direction:column;align-items:stretch}.student-search-wrapper,.student-filter-group{width:100%}.student-filter-select{flex:1}.student-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stats-card{padding:16px}.stats-icon{width:40px;height:40px}.stats-value{font-size:20px}.grid-2{grid-template-columns:1fr}.student-table td{min-width:120px}.student-table td:first-child{min-width:80px}.student-table td:nth-child(3){min-width:150px}.student-pagination{flex-direction:column;align-items:stretch}.student-pagination-buttons{justify-content:center}.student-action-buttons{justify-content:flex-start}.modal{max-width:95%}.modal-hdr,.modal-body,.modal-foot{padding:16px 20px}.modal-title{font-size:16px}.btn{padding:8px 16px}.student-photo-section{flex-direction:column;align-items:center;text-align:center}}@media(max-width:480px){.toast{min-width:auto;width:calc(100vw - 40px)}.student-stats-grid{grid-template-columns:1fr}.student-template-actions{flex-direction:column}.student-template-actions .btn{width:100%}.student-upload-meta,.student-upload-stats{flex-direction:column;gap:4px}.student-info-card strong{min-width:80px}}@media print{.student-page-actions,.student-filters-bar,.student-action-buttons,.toast-container,.modal-bg{display:none!important}.student-card{box-shadow:none;border:1px solid #000}.student-table th{background:#f0f0f0}.student-table td{border-bottom:1px solid #ddd}}.qr-preview-container{display:flex;flex-direction:column;align-items:center;padding:10px}.qr-info{width:100%;background:var(--bg, #f8fafc);padding:15px;border-radius:8px;margin-top:15px}.qr-info p{margin:5px 0;font-size:14px;color:var(--tx2, #475569)}.qr-info p strong{color:var(--tx1, #0f172a);min-width:80px;display:inline-block}.qr-actions{margin-top:15px;padding-top:15px;border-top:1px solid var(--border, #e2e8f0);display:flex;gap:10px;justify-content:center}.usr-mgt-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.usr-mgt-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #ffffff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:usr-mgt-toast-slide-in .3s ease;border-left:4px solid;border-color:var(--primary, #2563eb)}.usr-mgt-toast-success{border-left-color:var(--success, #16a34a)}.usr-mgt-toast-error{border-left-color:var(--danger, #dc2626)}.usr-mgt-toast-warning{border-left-color:var(--warning, #d97706)}.usr-mgt-toast-info{border-left-color:var(--primary, #2563eb)}.usr-mgt-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.usr-mgt-toast-success .usr-mgt-toast-icon{color:var(--success, #16a34a)}.usr-mgt-toast-error .usr-mgt-toast-icon{color:var(--danger, #dc2626)}.usr-mgt-toast-warning .usr-mgt-toast-icon{color:var(--warning, #d97706)}.usr-mgt-toast-info .usr-mgt-toast-icon{color:var(--primary, #2563eb)}.usr-mgt-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.usr-mgt-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;transition:color .2s}.usr-mgt-toast-close:hover{color:var(--tx1, #0f172a)}@keyframes usr-mgt-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.usr-mgt-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.usr-mgt-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.usr-mgt-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.usr-mgt-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.usr-mgt-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}.usr-mgt-stats-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.usr-mgt-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.usr-mgt-stats-primary{border-left:4px solid var(--primary, #2563eb)}.usr-mgt-stats-success{border-left:4px solid var(--success, #16a34a)}.usr-mgt-stats-warning{border-left:4px solid var(--warning, #d97706)}.usr-mgt-stats-danger{border-left:4px solid var(--danger, #dc2626)}.usr-mgt-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--bg, #f8fafc)}.usr-mgt-stats-primary .usr-mgt-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.usr-mgt-stats-success .usr-mgt-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.usr-mgt-stats-warning .usr-mgt-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.usr-mgt-stats-danger .usr-mgt-stats-icon{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626)}.usr-mgt-stats-content{flex:1}.usr-mgt-stats-title{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.usr-mgt-stats-value{font-size:30px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.usr-mgt-stats-trend{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--success, #16a34a);margin-top:6px}.usr-mgt-tabs-container{display:flex;gap:2px;margin-bottom:24px;border-bottom:2px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);padding:0 4px;border-radius:12px 12px 0 0}.usr-mgt-tab-btn{padding:14px 24px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:500;color:var(--tx2, #475569);border-bottom:3px solid transparent;margin-bottom:-2px;display:flex;align-items:center;gap:10px;transition:all .2s;font-family:inherit;position:relative}.usr-mgt-tab-btn:hover{color:var(--primary, #2563eb);background:var(--bg-hover, #f1f5f9)}.usr-mgt-tab-btn.usr-mgt-active{color:var(--primary, #2563eb);border-bottom-color:var(--primary, #2563eb);font-weight:600;background:var(--primary-light, #dbeafe)}.usr-mgt-tab-count{background:var(--bg, #f1f5f9);color:var(--tx3, #64748b);border:1px solid var(--border, #e2e8f0);border-radius:20px;font-size:11px;font-weight:600;padding:2px 8px;transition:all .2s}.usr-mgt-tab-btn.usr-mgt-active .usr-mgt-tab-count{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.usr-mgt-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #ffffff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.usr-mgt-search-wrapper{position:relative;flex:1;min-width:280px}.usr-mgt-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.usr-mgt-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.usr-mgt-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.usr-mgt-search-input::placeholder{color:var(--tx3, #94a3b8)}.usr-mgt-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.usr-mgt-filter-icon{color:var(--tx3, #94a3b8)}.usr-mgt-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.usr-mgt-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.usr-mgt-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.usr-mgt-card:hover{box-shadow:0 8px 24px #00000014}.usr-mgt-card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--border, #e2e8f0)}.usr-mgt-card-title{font-size:16px;font-weight:600;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.usr-mgt-table-responsive{overflow-x:auto;border-radius:12px}.usr-mgt-users-table,.usr-mgt-logs-table{width:100%;border-collapse:separate;border-spacing:0}.usr-mgt-users-table th,.usr-mgt-logs-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0)}.usr-mgt-users-table td,.usr-mgt-logs-table td{padding:18px 16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #ffffff)}.usr-mgt-users-table tr:hover td,.usr-mgt-logs-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.usr-mgt-user-info{display:flex;align-items:center;gap:14px}.usr-mgt-user-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary, #2563eb) 0%,#7c3aed 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:600;text-transform:uppercase;flex-shrink:0;box-shadow:0 4px 10px #2563eb33}.usr-mgt-user-avatar.usr-mgt-small{width:32px;height:32px;font-size:12px;box-shadow:none}.usr-mgt-user-name{font-size:15px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:4px}.usr-mgt-user-email{font-size:12px;color:var(--tx3, #64748b)}.usr-mgt-staff-id{font-family:SF Mono,Fira Code,monospace;font-size:13px;font-weight:600;color:var(--tx1, #0f172a);background:var(--bg, #f1f5f9);padding:6px 10px;border-radius:6px;border:1px solid var(--border, #e2e8f0);display:inline-block}.usr-mgt-role-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:30px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;transition:all .2s}.usr-mgt-role-badge.usr-mgt-role-receptionist{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border:1px solid var(--primary-border, #bfdbfe)}.usr-mgt-role-badge.usr-mgt-role-supervisor{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border:1px solid var(--warning-border, #fde68a)}.usr-mgt-role-badge.usr-mgt-role-admin{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border:1px solid var(--danger-border, #fecaca)}.usr-mgt-contact-info{display:flex;flex-direction:column;gap:6px;font-size:13px}.usr-mgt-contact-info div{display:flex;align-items:center;gap:8px;color:var(--tx2, #475569)}.usr-mgt-login-info{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--tx2, #475569);white-space:nowrap;background:var(--bg, #f8fafc);padding:6px 10px;border-radius:6px;width:fit-content}.usr-mgt-status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:30px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent}.usr-mgt-status-badge.usr-mgt-active{background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border-color:var(--success-border, #bbf7d0)}.usr-mgt-status-badge.usr-mgt-inactive{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger-border, #fecaca)}.usr-mgt-status-badge.usr-mgt-locked{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border-color:var(--warning-border, #fde68a)}.usr-mgt-status-badge.usr-mgt-info{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-color:var(--primary-border, #bfdbfe)}.usr-mgt-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.usr-mgt-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.usr-mgt-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.usr-mgt-action-btn.usr-mgt-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.usr-mgt-action-btn:disabled{opacity:.5;cursor:not-allowed}.usr-mgt-modern-switch{position:relative;display:inline-block;cursor:pointer}.usr-mgt-modern-switch.usr-mgt-small input+.usr-mgt-switch-slider{width:40px;height:22px}.usr-mgt-modern-switch.usr-mgt-small input+.usr-mgt-switch-slider .usr-mgt-switch-handle{width:18px;height:18px}.usr-mgt-modern-switch.usr-mgt-small.usr-mgt-checked input+.usr-mgt-switch-slider .usr-mgt-switch-handle{transform:translate(18px)}.usr-mgt-modern-switch.usr-mgt-medium input+.usr-mgt-switch-slider{width:52px;height:28px}.usr-mgt-modern-switch.usr-mgt-medium input+.usr-mgt-switch-slider .usr-mgt-switch-handle{width:24px;height:24px}.usr-mgt-modern-switch.usr-mgt-medium.usr-mgt-checked input+.usr-mgt-switch-slider .usr-mgt-switch-handle{transform:translate(24px)}.usr-mgt-modern-switch input{opacity:0;width:0;height:0;position:absolute}.usr-mgt-modern-switch .usr-mgt-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.usr-mgt-modern-switch.usr-mgt-checked .usr-mgt-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.usr-mgt-modern-switch .usr-mgt-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.usr-mgt-modern-switch.usr-mgt-disabled{opacity:.5;cursor:not-allowed}.usr-mgt-status-toggle{display:flex;align-items:center;gap:12px}.usr-mgt-status-label{font-size:14px;font-weight:500}.usr-mgt-status-label.usr-mgt-active{color:var(--success, #16a34a)}.usr-mgt-status-label.usr-mgt-inactive{color:var(--danger, #dc2626)}.usr-mgt-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:24px;flex-wrap:wrap;gap:16px}.usr-mgt-pagination-info{font-size:14px;color:var(--tx3, #64748b)}.usr-mgt-pagination-buttons{display:flex;gap:6px}.usr-mgt-pagination-btn{width:40px;height:40px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.usr-mgt-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.usr-mgt-pagination-btn.usr-mgt-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.usr-mgt-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.usr-mgt-roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px}.usr-mgt-role-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:20px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .3s ease;position:relative;overflow:hidden}.usr-mgt-role-card:hover{transform:translateY(-4px);box-shadow:0 20px 30px -10px #00000026}.usr-mgt-role-card.usr-mgt-role-blue{border-top:5px solid var(--primary, #2563eb)}.usr-mgt-role-card.usr-mgt-role-amber{border-top:5px solid var(--warning, #d97706)}.usr-mgt-role-card.usr-mgt-role-red{border-top:5px solid var(--danger, #dc2626)}.usr-mgt-role-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}.usr-mgt-role-header svg{color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:8px;border-radius:12px;width:40px;height:40px}.usr-mgt-role-title{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);flex:1}.usr-mgt-role-actions-top{display:flex;gap:8px;align-items:center}.usr-mgt-role-code{display:flex;align-items:center;justify-content:space-between;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:10px;padding:12px 16px;margin-bottom:20px}.usr-mgt-role-code code{font-size:14px;font-weight:600;color:var(--primary, #2563eb);font-family:SF Mono,Fira Code,monospace}.usr-mgt-role-staff-count{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--tx3, #64748b);background:var(--bg-card, #ffffff);padding:4px 10px;border-radius:20px;border:1px solid var(--border, #e2e8f0)}.usr-mgt-role-permissions-section{margin-bottom:20px}.usr-mgt-role-permissions-section h4{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.usr-mgt-role-permissions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;background:var(--bg, #f8fafc);border-radius:12px;padding:16px}.usr-mgt-permission-badge{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--tx2, #475569);padding:8px 10px;background:var(--bg-card, #ffffff);border-radius:8px;border:1px solid var(--border, #e2e8f0);transition:all .2s}.usr-mgt-permission-badge:hover{border-color:var(--primary, #2563eb);box-shadow:0 2px 8px #2563eb1a}.usr-mgt-permission-icon{flex-shrink:0}.usr-mgt-permission-icon.usr-mgt-allowed{color:var(--success, #16a34a)}.usr-mgt-permission-icon.usr-mgt-denied{color:var(--danger, #dc2626)}.usr-mgt-role-card.usr-mgt-add-role{display:flex;align-items:center;justify-content:center;min-height:280px;border:2px dashed var(--border, #e2e8f0);background:var(--bg, #f8fafc);cursor:pointer;transition:all .2s;border-top:2px dashed var(--border, #e2e8f0)}.usr-mgt-role-card.usr-mgt-add-role:hover{border-color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);transform:translateY(-2px)}.usr-mgt-add-role-content{text-align:center;padding:24px}.usr-mgt-add-role-content svg{color:var(--tx3, #94a3b8);margin-bottom:16px;width:48px;height:48px}.usr-mgt-add-role-content h3{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.usr-mgt-add-role-content p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:20px}.usr-mgt-log-time{font-size:13px;color:var(--tx2, #475569);font-family:SF Mono,Fira Code,monospace;background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px;display:inline-block}.usr-mgt-log-user{display:flex;align-items:center;gap:10px;font-weight:500;color:var(--tx1, #0f172a)}.usr-mgt-log-event{display:inline-flex;align-items:center;padding:6px 12px;border-radius:30px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.usr-mgt-log-event.usr-mgt-event-login_success{background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border:1px solid var(--success-border, #bbf7d0)}.usr-mgt-log-event.usr-mgt-event-login_fail{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border:1px solid var(--danger-border, #fecaca)}.usr-mgt-log-event.usr-mgt-event-account_locked{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border:1px solid var(--warning-border, #fde68a)}.usr-mgt-log-ip{font-size:12px;font-family:SF Mono,Fira Code,monospace;color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px}.usr-mgt-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:usr-mgt-modal-fade-in .2s ease}@keyframes usr-mgt-modal-fade-in{0%{opacity:0}to{opacity:1}}.usr-mgt-modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:usr-mgt-modal-scale-in .3s ease}@keyframes usr-mgt-modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.usr-mgt-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.usr-mgt-modal-title{font-size:20px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:10px}.usr-mgt-modal-close-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.usr-mgt-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.usr-mgt-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.usr-mgt-modal-body{padding:20px 28px}.usr-mgt-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.usr-mgt-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.usr-mgt-form-label{font-size:14px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:4px}.usr-mgt-required{color:var(--danger, #dc2626);margin-left:2px;font-size:16px}.usr-mgt-form-hint{font-size:12px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.usr-mgt-input,select.usr-mgt-input{background:var(--bg-input, #ffffff);border:1.5px solid var(--border, #e2e8f0);border-radius:12px;color:var(--tx1, #0f172a);font-size:14px;padding:12px 16px;outline:none;width:100%;transition:all .2s}.usr-mgt-input:focus,select.usr-mgt-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.usr-mgt-input.usr-mgt-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}.usr-mgt-error-message{color:var(--danger, #dc2626);font-size:12px;margin-top:4px;display:block}.usr-mgt-password-field{display:flex;gap:8px;align-items:center}.usr-mgt-password-field>div:first-child{position:relative;flex:1}.usr-mgt-password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;transition:color .2s}.usr-mgt-password-toggle:hover{color:var(--primary, #2563eb)}.usr-mgt-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.usr-mgt-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;padding:12px 20px;border-radius:12px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.usr-mgt-btn-sm{font-size:13px;padding:8px 16px}.usr-mgt-btn-primary{background:var(--primary, #2563eb);color:#fff}.usr-mgt-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 8px 16px #2563eb4d}.usr-mgt-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.usr-mgt-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.usr-mgt-btn-danger{background:var(--danger, #dc2626);color:#fff}.usr-mgt-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 8px 16px #dc26264d}.usr-mgt-btn:disabled{opacity:.5;cursor:not-allowed}.usr-mgt-spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:usr-mgt-spin .6s linear infinite;margin-right:8px}@keyframes usr-mgt-spin{to{transform:rotate(360deg)}}.usr-mgt-spin{animation:usr-mgt-spin 1s linear infinite}.usr-mgt-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #ffffff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.usr-mgt-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.usr-mgt-empty-state h3{font-size:20px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.usr-mgt-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.usr-mgt-skeleton-table{background:var(--bg-card, #ffffff);border-radius:16px;padding:24px}.usr-mgt-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.usr-mgt-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:usr-mgt-shimmer 1.5s infinite;border-radius:4px}@keyframes usr-mgt-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.usr-mgt-confirm-icon{text-align:center;margin-bottom:20px}.usr-mgt-confirm-message{font-size:15px;color:var(--tx2, #475569);text-align:center;line-height:1.6}@media(max-width:1200px){.usr-mgt-stats-grid,.usr-mgt-roles-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:992px){.usr-mgt-role-permissions{grid-template-columns:1fr}}@media(max-width:768px){.usr-mgt-page-hdr{flex-direction:column}.usr-mgt-page-actions{width:100%;justify-content:flex-start}.usr-mgt-tabs-container{overflow-x:auto;padding-bottom:4px}.usr-mgt-tab-btn{padding:12px 16px;white-space:nowrap}.usr-mgt-filters-bar{flex-direction:column;align-items:stretch}.usr-mgt-search-wrapper,.usr-mgt-filter-group{width:100%}.usr-mgt-filter-select{flex:1}.usr-mgt-grid-2{grid-template-columns:1fr}.usr-mgt-stats-grid{grid-template-columns:1fr;gap:16px}.usr-mgt-roles-grid{grid-template-columns:1fr}.usr-mgt-modal{max-width:95%}.usr-mgt-users-table td,.usr-mgt-logs-table td{min-width:140px}.usr-mgt-users-table td:first-child{min-width:200px}.usr-mgt-pagination{flex-direction:column;align-items:stretch}.usr-mgt-pagination-buttons{justify-content:center}.usr-mgt-password-field{flex-wrap:wrap}.usr-mgt-role-actions-top{flex-wrap:wrap;justify-content:flex-end}}@media(max-width:480px){.usr-mgt-toast{min-width:auto;width:calc(100vw - 40px)}.usr-mgt-action-buttons{justify-content:flex-start}.usr-mgt-modal-hdr,.usr-mgt-modal-body,.usr-mgt-modal-foot{padding:16px 20px}.usr-mgt-modal-title{font-size:18px}.usr-mgt-btn{padding:10px 16px}}.vst-purpose-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.vst-purpose-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #ffffff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:vst-purpose-toast-slide-in .3s ease;border-left:4px solid var(--primary, #2563eb);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.vst-purpose-toast-success{border-left-color:var(--success, #16a34a)}.vst-purpose-toast-error{border-left-color:var(--danger, #dc2626)}.vst-purpose-toast-warning{border-left-color:var(--warning, #d97706)}.vst-purpose-toast-info{border-left-color:var(--primary, #2563eb)}.vst-purpose-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.vst-purpose-toast-success .vst-purpose-toast-icon{color:var(--success, #16a34a)}.vst-purpose-toast-error .vst-purpose-toast-icon{color:var(--danger, #dc2626)}.vst-purpose-toast-warning .vst-purpose-toast-icon{color:var(--warning, #d97706)}.vst-purpose-toast-info .vst-purpose-toast-icon{color:var(--primary, #2563eb)}.vst-purpose-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.vst-purpose-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;transition:color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.vst-purpose-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes vst-purpose-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.vst-purpose-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.vst-purpose-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.vst-purpose-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.vst-purpose-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.vst-purpose-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.vst-purpose-stats-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.vst-purpose-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.vst-purpose-stats-primary{border-left:4px solid var(--primary, #2563eb)}.vst-purpose-stats-success{border-left:4px solid var(--success, #16a34a)}.vst-purpose-stats-warning{border-left:4px solid var(--warning, #d97706)}.vst-purpose-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--bg, #f8fafc)}.vst-purpose-stats-primary .vst-purpose-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.vst-purpose-stats-success .vst-purpose-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.vst-purpose-stats-warning .vst-purpose-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.vst-purpose-stats-content{flex:1}.vst-purpose-stats-title{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.vst-purpose-stats-value{font-size:30px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.vst-purpose-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #ffffff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.vst-purpose-search-wrapper{position:relative;flex:1;min-width:280px}.vst-purpose-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.vst-purpose-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.vst-purpose-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.vst-purpose-search-input::placeholder{color:var(--tx3, #94a3b8)}.vst-purpose-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.vst-purpose-filter-icon{color:var(--tx3, #94a3b8)}.vst-purpose-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.vst-purpose-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.vst-purpose-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.vst-purpose-card:hover{box-shadow:0 8px 24px #00000014}.vst-purpose-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.vst-purpose-purposes-table{width:100%;border-collapse:separate;border-spacing:0}.vst-purpose-purposes-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0)}.vst-purpose-purposes-table td{padding:16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #ffffff);transition:background-color .2s}.vst-purpose-purposes-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.vst-purpose-purposes-table tr.vst-purpose-dragging{opacity:.5;background:var(--primary-light, #dbeafe)}.vst-purpose-purposes-table tr.vst-purpose-dragging td{background:var(--primary-light, #dbeafe)}.vst-purpose-drag-handle{color:var(--tx3, #94a3b8);cursor:grab;transition:color .2s}.vst-purpose-drag-handle:hover{color:var(--primary, #2563eb)}.vst-purpose-purpose-code{font-family:SF Mono,Fira Code,monospace;font-size:13px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block}.vst-purpose-purpose-label{font-weight:500;color:var(--tx1, #0f172a)}.vst-purpose-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2, #475569)}.vst-purpose-status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:30px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent}.vst-purpose-status-badge.vst-purpose-active{background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border-color:var(--success-border, #bbf7d0)}.vst-purpose-status-badge.vst-purpose-inactive{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger-border, #fecaca)}.vst-purpose-date-info{font-size:13px;color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px;display:inline-block}.vst-purpose-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.vst-purpose-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.vst-purpose-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.vst-purpose-action-btn.vst-purpose-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.vst-purpose-action-btn:disabled{opacity:.5;cursor:not-allowed}.vst-purpose-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg, #f8fafc);border-radius:8px;color:var(--tx3, #64748b);font-size:12px;border:1px dashed var(--border, #e2e8f0)}.vst-purpose-drag-hint svg{color:var(--primary, #2563eb)}.vst-purpose-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #ffffff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.vst-purpose-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.vst-purpose-empty-state h3{font-size:20px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.vst-purpose-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.vst-purpose-skeleton-table{background:var(--bg-card, #ffffff);border-radius:16px;padding:24px}.vst-purpose-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.vst-purpose-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:vst-purpose-shimmer 1.5s infinite;border-radius:4px}@keyframes vst-purpose-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.vst-purpose-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:vst-purpose-modal-fade-in .2s ease}@keyframes vst-purpose-modal-fade-in{0%{opacity:0}to{opacity:1}}.vst-purpose-modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:vst-purpose-modal-scale-in .3s ease}@keyframes vst-purpose-modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.vst-purpose-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.vst-purpose-modal-title{font-size:20px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:10px}.vst-purpose-modal-close-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.vst-purpose-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.vst-purpose-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.vst-purpose-modal-body{padding:20px 28px}.vst-purpose-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.vst-purpose-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.vst-purpose-form-label{font-size:14px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.vst-purpose-required{color:var(--danger, #dc2626);margin-left:2px;font-size:16px}.vst-purpose-auto-badge{font-size:11px;font-weight:500;padding:2px 8px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:20px;border:1px solid var(--primary-border, #bfdbfe);text-transform:none;letter-spacing:normal}.vst-purpose-form-hint{font-size:12px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.vst-purpose-input,select.vst-purpose-input{background:var(--bg-input, #ffffff);border:1.5px solid var(--border, #e2e8f0);border-radius:12px;color:var(--tx1, #0f172a);font-size:14px;padding:12px 16px;outline:none;width:100%;transition:all .2s}.vst-purpose-input:focus,select.vst-purpose-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.vst-purpose-input.vst-purpose-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}.vst-purpose-error-message{color:var(--danger, #dc2626);font-size:12px;margin-top:4px;display:block}.vst-purpose-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.vst-purpose-status-toggle{display:flex;align-items:center;gap:12px}.vst-purpose-status-label{font-size:14px;font-weight:500}.vst-purpose-status-label.vst-purpose-active{color:var(--success, #16a34a)}.vst-purpose-status-label.vst-purpose-inactive{color:var(--danger, #dc2626)}.vst-purpose-modern-switch{position:relative;display:inline-block;cursor:pointer}.vst-purpose-modern-switch.vst-purpose-small input+.vst-purpose-switch-slider{width:40px;height:22px}.vst-purpose-modern-switch.vst-purpose-small input+.vst-purpose-switch-slider .vst-purpose-switch-handle{width:18px;height:18px}.vst-purpose-modern-switch.vst-purpose-small.vst-purpose-checked input+.vst-purpose-switch-slider .vst-purpose-switch-handle{transform:translate(18px)}.vst-purpose-modern-switch.vst-purpose-medium input+.vst-purpose-switch-slider{width:52px;height:28px}.vst-purpose-modern-switch.vst-purpose-medium input+.vst-purpose-switch-slider .vst-purpose-switch-handle{width:24px;height:24px}.vst-purpose-modern-switch.vst-purpose-medium.vst-purpose-checked input+.vst-purpose-switch-slider .vst-purpose-switch-handle{transform:translate(24px)}.vst-purpose-modern-switch input{opacity:0;width:0;height:0;position:absolute}.vst-purpose-modern-switch .vst-purpose-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.vst-purpose-modern-switch.vst-purpose-checked .vst-purpose-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.vst-purpose-modern-switch .vst-purpose-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.vst-purpose-modern-switch.vst-purpose-disabled{opacity:.5;cursor:not-allowed}.vst-purpose-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;padding:12px 20px;border-radius:12px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.vst-purpose-btn-sm{font-size:13px;padding:8px 16px}.vst-purpose-btn-primary{background:var(--primary, #2563eb);color:#fff}.vst-purpose-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 8px 16px #2563eb4d}.vst-purpose-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.vst-purpose-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.vst-purpose-btn-danger{background:var(--danger, #dc2626);color:#fff}.vst-purpose-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 8px 16px #dc26264d}.vst-purpose-btn:disabled{opacity:.5;cursor:not-allowed}.vst-purpose-spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:vst-purpose-spin .6s linear infinite;margin-right:8px}@keyframes vst-purpose-spin{to{transform:rotate(360deg)}}.vst-purpose-spin{animation:vst-purpose-spin 1s linear infinite}.vst-purpose-confirm-icon{text-align:center;margin-bottom:20px}.vst-purpose-confirm-icon .vst-purpose-text-success{color:var(--success, #16a34a)}.vst-purpose-confirm-icon .vst-purpose-text-danger{color:var(--danger, #dc2626)}.vst-purpose-confirm-message{font-size:15px;color:var(--tx2, #475569);text-align:center;line-height:1.6}@media(max-width:1024px){.vst-purpose-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.vst-purpose-page-hdr{flex-direction:column}.vst-purpose-page-actions{width:100%;justify-content:flex-start}.vst-purpose-filters-bar{flex-direction:column;align-items:stretch}.vst-purpose-search-wrapper,.vst-purpose-filter-group{width:100%}.vst-purpose-filter-select{flex:1}.vst-purpose-grid-2{grid-template-columns:1fr}.vst-purpose-stats-grid{grid-template-columns:1fr;gap:16px}.vst-purpose-modal{max-width:95%}.vst-purpose-purposes-table td{min-width:120px}.vst-purpose-purposes-table td:first-child{min-width:40px}.vst-purpose-action-buttons{justify-content:flex-start}.vst-purpose-modal-hdr,.vst-purpose-modal-body,.vst-purpose-modal-foot{padding:16px 20px}.vst-purpose-modal-title{font-size:18px}.vst-purpose-btn{padding:10px 16px}}@media(max-width:480px){.vst-purpose-toast{min-width:auto;width:calc(100vw - 40px)}.vst-purpose-stats-card{padding:16px}.vst-purpose-stats-icon{width:44px;height:44px}.vst-purpose-stats-value{font-size:24px}.vst-purpose-drag-hint{font-size:11px}}@media print{.vst-purpose-page-actions,.vst-purpose-filters-bar,.vst-purpose-action-buttons,.vst-purpose-drag-hint,.vst-purpose-toast-container{display:none!important}.vst-purpose-card{box-shadow:none;border:1px solid #000}.vst-purpose-purposes-table th{background:#f0f0f0}}.asset-type-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.asset-type-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #ffffff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:asset-type-toast-slide-in .3s ease;border-left:4px solid var(--primary, #2563eb);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.asset-type-toast-success{border-left-color:var(--success, #16a34a)}.asset-type-toast-error{border-left-color:var(--danger, #dc2626)}.asset-type-toast-warning{border-left-color:var(--warning, #d97706)}.asset-type-toast-info{border-left-color:var(--primary, #2563eb)}.asset-type-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.asset-type-toast-success .asset-type-toast-icon{color:var(--success, #16a34a)}.asset-type-toast-error .asset-type-toast-icon{color:var(--danger, #dc2626)}.asset-type-toast-warning .asset-type-toast-icon{color:var(--warning, #d97706)}.asset-type-toast-info .asset-type-toast-icon{color:var(--primary, #2563eb)}.asset-type-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.asset-type-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;transition:color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.asset-type-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes asset-type-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.asset-type-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.asset-type-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.asset-type-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.asset-type-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.asset-type-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}.asset-type-stats-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.asset-type-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.asset-type-stats-primary{border-left:4px solid var(--primary, #2563eb)}.asset-type-stats-success{border-left:4px solid var(--success, #16a34a)}.asset-type-stats-warning{border-left:4px solid var(--warning, #d97706)}.asset-type-stats-info{border-left:4px solid var(--info, #3b82f6)}.asset-type-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--bg, #f8fafc)}.asset-type-stats-primary .asset-type-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.asset-type-stats-success .asset-type-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.asset-type-stats-warning .asset-type-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.asset-type-stats-info .asset-type-stats-icon{background:var(--info-light, #dbeafe);color:var(--info, #3b82f6)}.asset-type-stats-content{flex:1}.asset-type-stats-title{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.asset-type-stats-value{font-size:30px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.asset-type-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #ffffff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.asset-type-search-wrapper{position:relative;flex:1;min-width:280px}.asset-type-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.asset-type-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.asset-type-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.asset-type-search-input::placeholder{color:var(--tx3, #94a3b8)}.asset-type-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.asset-type-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.asset-type-card:hover{box-shadow:0 8px 24px #00000014}.asset-type-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.asset-type-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.asset-type-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none}.asset-type-lookup-table th:hover{color:var(--primary, #2563eb)}.asset-type-lookup-table td{padding:16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #ffffff);transition:background-color .2s}.asset-type-lookup-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.asset-type-lookup-table tr.asset-type-dragging{opacity:.5;background:var(--primary-light, #dbeafe)}.asset-type-lookup-table tr.asset-type-dragging td{background:var(--primary-light, #dbeafe)}.asset-type-drag-handle{color:var(--tx3, #94a3b8);cursor:grab;transition:color .2s}.asset-type-drag-handle:hover{color:var(--primary, #2563eb)}.asset-type-sort-icon{margin-left:4px;color:var(--tx3, #94a3b8)}.asset-type-sort-icon.asc,.asset-type-sort-icon.desc{font-weight:700;color:var(--primary, #2563eb)}.asset-type-code-badge{display:inline-block;padding:6px 10px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border:1px solid var(--primary-border, #bfdbfe);border-radius:6px;font-family:SF Mono,Fira Code,monospace;font-size:13px;font-weight:600}.asset-type-label-cell{font-weight:500;color:var(--tx1, #0f172a)}.asset-type-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2, #475569)}.asset-type-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;border:1px solid transparent}.asset-type-badge-blue{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-color:var(--primary-border, #bfdbfe)}.asset-type-badge-gray{background:var(--bg, #f1f5f9);color:var(--tx3, #94a3b8);border-color:var(--border, #e2e8f0)}.asset-type-status-toggle{display:flex;align-items:center;gap:12px}.asset-type-status-label{font-size:14px;font-weight:500}.asset-type-status-label.asset-type-active{color:var(--success, #16a34a)}.asset-type-status-label.asset-type-inactive{color:var(--danger, #dc2626)}.asset-type-date-info{font-size:13px;color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px;display:inline-block}.asset-type-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.asset-type-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.asset-type-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.asset-type-action-btn.asset-type-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.asset-type-action-btn:disabled{opacity:.5;cursor:not-allowed}.asset-type-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg, #f8fafc);border-radius:8px;color:var(--tx3, #64748b);font-size:12px;border:1px dashed var(--border, #e2e8f0)}.asset-type-drag-hint svg{color:var(--primary, #2563eb)}.asset-type-modern-switch{position:relative;display:inline-block;cursor:pointer}.asset-type-modern-switch.asset-type-small input+.asset-type-switch-slider{width:40px;height:22px}.asset-type-modern-switch.asset-type-small input+.asset-type-switch-slider .asset-type-switch-handle{width:18px;height:18px}.asset-type-modern-switch.asset-type-small.asset-type-checked input+.asset-type-switch-slider .asset-type-switch-handle{transform:translate(18px)}.asset-type-modern-switch input{opacity:0;width:0;height:0;position:absolute}.asset-type-modern-switch .asset-type-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.asset-type-modern-switch.asset-type-checked .asset-type-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.asset-type-modern-switch .asset-type-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.asset-type-modern-switch.asset-type-disabled{opacity:.5;cursor:not-allowed}.asset-type-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #ffffff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.asset-type-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.asset-type-empty-state h3{font-size:20px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.asset-type-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.asset-type-skeleton-table{background:var(--bg-card, #ffffff);border-radius:16px;padding:24px}.asset-type-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.asset-type-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:asset-type-shimmer 1.5s infinite;border-radius:4px}@keyframes asset-type-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.asset-type-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:asset-type-modal-fade-in .2s ease}@keyframes asset-type-modal-fade-in{0%{opacity:0}to{opacity:1}}.asset-type-modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:asset-type-modal-scale-in .3s ease}@keyframes asset-type-modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.asset-type-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.asset-type-modal-title{font-size:20px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:10px}.asset-type-modal-close-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.asset-type-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.asset-type-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.asset-type-modal-body{padding:20px 28px}.asset-type-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.asset-type-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.asset-type-form-label{font-size:14px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.asset-type-required{color:var(--danger, #dc2626);margin-left:2px;font-size:16px}.asset-type-auto-badge{font-size:11px;font-weight:500;padding:2px 8px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:20px;border:1px solid var(--primary-border, #bfdbfe);text-transform:none;letter-spacing:normal}.asset-type-form-hint{font-size:12px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.asset-type-input,select.asset-type-input{background:var(--bg-input, #ffffff);border:1.5px solid var(--border, #e2e8f0);border-radius:12px;color:var(--tx1, #0f172a);font-size:14px;padding:12px 16px;outline:none;width:100%;transition:all .2s;font-family:inherit}.asset-type-input:focus,select.asset-type-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.asset-type-input.asset-type-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}.asset-type-error-message{color:var(--danger, #dc2626);font-size:12px;margin-top:4px;display:block}.asset-type-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.asset-type-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;padding:12px 20px;border-radius:12px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.asset-type-btn-sm{font-size:13px;padding:8px 16px}.asset-type-btn-primary{background:var(--primary, #2563eb);color:#fff}.asset-type-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 8px 16px #2563eb4d}.asset-type-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.asset-type-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.asset-type-btn-danger{background:var(--danger, #dc2626);color:#fff}.asset-type-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 8px 16px #dc26264d}.asset-type-btn:disabled{opacity:.5;cursor:not-allowed}.asset-type-spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:asset-type-spin .6s linear infinite;margin-right:8px}@keyframes asset-type-spin{to{transform:rotate(360deg)}}.asset-type-spin{animation:asset-type-spin 1s linear infinite}.asset-type-confirm-icon{text-align:center;margin-bottom:20px}.asset-type-confirm-icon .asset-type-text-success{color:var(--success, #16a34a)}.asset-type-confirm-icon .asset-type-text-danger{color:var(--danger, #dc2626)}.asset-type-confirm-message{font-size:15px;color:var(--tx2, #475569);text-align:center;line-height:1.6}.asset-type-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:24px;flex-wrap:wrap;gap:16px}.asset-type-pagination-info{font-size:14px;color:var(--tx3, #64748b)}.asset-type-pagination-buttons{display:flex;gap:6px}.asset-type-pagination-btn{width:40px;height:40px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.asset-type-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.asset-type-pagination-btn.asset-type-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.asset-type-pagination-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:1200px){.asset-type-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.asset-type-page-hdr{flex-direction:column}.asset-type-page-actions{width:100%;justify-content:flex-start}.asset-type-filters-bar{flex-direction:column;align-items:stretch}.asset-type-search-wrapper,.asset-type-filter-group{width:100%}.asset-type-grid-2{grid-template-columns:1fr}.asset-type-stats-grid{grid-template-columns:1fr;gap:16px}.asset-type-modal{max-width:95%}.asset-type-lookup-table td{min-width:120px}.asset-type-lookup-table td:first-child{min-width:40px}.asset-type-action-buttons{justify-content:flex-start}.asset-type-pagination{flex-direction:column;align-items:stretch}.asset-type-pagination-buttons{justify-content:center}.asset-type-modal-hdr,.asset-type-modal-body,.asset-type-modal-foot{padding:16px 20px}.asset-type-modal-title{font-size:18px}.asset-type-btn{padding:10px 16px}}@media(max-width:480px){.asset-type-toast{min-width:auto;width:calc(100vw - 40px)}.asset-type-stats-card{padding:16px}.asset-type-stats-icon{width:44px;height:44px}.asset-type-stats-value{font-size:24px}.asset-type-drag-hint{font-size:11px}.asset-type-status-toggle{flex-direction:column;align-items:flex-start}}@media print{.asset-type-page-actions,.asset-type-filters-bar,.asset-type-action-buttons,.asset-type-drag-hint,.asset-type-toast-container{display:none!important}.asset-type-card{box-shadow:none;border:1px solid #000}.asset-type-lookup-table th{background:#f0f0f0}}.alert-type-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.alert-type-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #ffffff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:alert-type-toast-slide-in .3s ease;border-left:4px solid var(--primary, #2563eb);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.alert-type-toast-success{border-left-color:var(--success, #16a34a)}.alert-type-toast-error{border-left-color:var(--danger, #dc2626)}.alert-type-toast-warning{border-left-color:var(--warning, #d97706)}.alert-type-toast-info{border-left-color:var(--primary, #2563eb)}.alert-type-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.alert-type-toast-success .alert-type-toast-icon{color:var(--success, #16a34a)}.alert-type-toast-error .alert-type-toast-icon{color:var(--danger, #dc2626)}.alert-type-toast-warning .alert-type-toast-icon{color:var(--warning, #d97706)}.alert-type-toast-info .alert-type-toast-icon{color:var(--primary, #2563eb)}.alert-type-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.alert-type-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;transition:color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.alert-type-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes alert-type-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.alert-type-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.alert-type-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.alert-type-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.alert-type-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.alert-type-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}.alert-type-stats-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.alert-type-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.alert-type-stats-primary{border-left:4px solid var(--primary, #2563eb)}.alert-type-stats-success{border-left:4px solid var(--success, #16a34a)}.alert-type-stats-warning{border-left:4px solid var(--warning, #d97706)}.alert-type-stats-danger{border-left:4px solid var(--danger, #dc2626)}.alert-type-stats-info{border-left:4px solid var(--primary, #2563eb)}.alert-type-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--bg, #f8fafc)}.alert-type-stats-primary .alert-type-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.alert-type-stats-success .alert-type-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.alert-type-stats-warning .alert-type-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.alert-type-stats-danger .alert-type-stats-icon{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626)}.alert-type-stats-info .alert-type-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.alert-type-stats-content{flex:1}.alert-type-stats-title{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.alert-type-stats-value{font-size:30px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.alert-type-stats-sub{font-size:12px;color:var(--tx2, #475569);margin-top:4px;display:flex;align-items:center;gap:4px}.alert-type-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #ffffff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.alert-type-search-wrapper{position:relative;flex:1;min-width:280px}.alert-type-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.alert-type-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.alert-type-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.alert-type-search-input::placeholder{color:var(--tx3, #94a3b8)}.alert-type-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.alert-type-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.alert-type-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.alert-type-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.alert-type-card:hover{box-shadow:0 8px 24px #00000014}.alert-type-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.alert-type-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.alert-type-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.alert-type-lookup-table th:hover{background:var(--bg-hover, #e2e8f0);color:var(--tx1, #0f172a)}.alert-type-lookup-table td{padding:16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #ffffff);transition:background-color .2s}.alert-type-lookup-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.alert-type-sort-icon{margin-left:8px;color:var(--tx3, #94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.alert-type-sort-icon.alert-type-asc{transform:rotate(0)}.alert-type-sort-icon.alert-type-desc{transform:rotate(180deg)}.alert-type-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block;white-space:nowrap}.alert-type-severity-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:30px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.alert-type-severity-badge svg{width:14px;height:14px}.alert-type-severity-danger{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger-border, #fecaca)}.alert-type-severity-warning{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border-color:var(--warning-border, #fde68a)}.alert-type-description-cell{max-width:300px;white-space:normal;word-wrap:break-word;line-height:1.5;color:var(--tx1, #0f172a)}.alert-type-date-info{font-size:12px;color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.alert-type-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.alert-type-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.alert-type-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.alert-type-action-btn.alert-type-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.alert-type-action-btn:disabled{opacity:.5;cursor:not-allowed}.alert-type-status-toggle{display:flex;align-items:center;gap:12px}.alert-type-status-label{font-size:13px;font-weight:500}.alert-type-status-label.alert-type-active{color:var(--success, #16a34a)}.alert-type-status-label.alert-type-inactive{color:var(--danger, #dc2626)}.alert-type-modern-switch{position:relative;display:inline-block;cursor:pointer}.alert-type-modern-switch.alert-type-small input+.alert-type-switch-slider{width:40px;height:22px}.alert-type-modern-switch.alert-type-small input+.alert-type-switch-slider .alert-type-switch-handle{width:18px;height:18px}.alert-type-modern-switch.alert-type-small.alert-type-checked input+.alert-type-switch-slider .alert-type-switch-handle{transform:translate(18px)}.alert-type-modern-switch.alert-type-medium input+.alert-type-switch-slider{width:52px;height:28px}.alert-type-modern-switch.alert-type-medium input+.alert-type-switch-slider .alert-type-switch-handle{width:24px;height:24px}.alert-type-modern-switch.alert-type-medium.alert-type-checked input+.alert-type-switch-slider .alert-type-switch-handle{transform:translate(24px)}.alert-type-modern-switch input{opacity:0;width:0;height:0;position:absolute}.alert-type-modern-switch .alert-type-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.alert-type-modern-switch.alert-type-checked .alert-type-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.alert-type-modern-switch .alert-type-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.alert-type-modern-switch.alert-type-disabled{opacity:.5;cursor:not-allowed}.alert-type-switch{position:relative;display:inline-block;width:48px;height:24px;margin-right:8px}.alert-type-switch input{opacity:0;width:0;height:0}.alert-type-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--tx3, #94a3b8);transition:.2s}.alert-type-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.2s}.alert-type-switch input:checked+.alert-type-slider{background-color:var(--primary, #2563eb)}.alert-type-switch input:checked+.alert-type-slider:before{transform:translate(24px)}.alert-type-slider.alert-type-round{border-radius:24px}.alert-type-slider.alert-type-round:before{border-radius:50%}.alert-type-toggle-switch{display:flex;align-items:center;gap:8px}.alert-type-toggle-label{font-size:13px;color:var(--tx2, #475569)}.alert-type-severity-options{display:flex;gap:16px;flex-wrap:wrap;margin-top:4px}.alert-type-severity-option{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 12px;border-radius:8px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);transition:all .2s;flex:1;min-width:100px}.alert-type-severity-option:hover{background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb)}.alert-type-severity-option input[type=radio]{width:16px;height:16px;accent-color:var(--primary, #2563eb);cursor:pointer}.alert-type-severity-radio{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:600}.alert-type-severity-radio svg{width:16px;height:16px}.alert-type-severity-danger{color:var(--danger, #dc2626)}.alert-type-severity-warning{color:var(--warning, #d97706)}.alert-type-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.alert-type-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.alert-type-pagination-buttons{display:flex;gap:6px}.alert-type-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.alert-type-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.alert-type-pagination-btn.alert-type-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.alert-type-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.alert-type-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #ffffff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.alert-type-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.alert-type-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.alert-type-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.alert-type-skeleton-table{background:var(--bg-card, #ffffff);border-radius:16px;padding:24px}.alert-type-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.alert-type-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:alert-type-shimmer 1.5s infinite;border-radius:4px}@keyframes alert-type-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.alert-type-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:alert-type-modal-fade-in .2s ease}@keyframes alert-type-modal-fade-in{0%{opacity:0}to{opacity:1}}.alert-type-modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:alert-type-modal-scale-in .3s ease}@keyframes alert-type-modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.alert-type-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.alert-type-modal-title{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.alert-type-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.alert-type-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.alert-type-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.alert-type-modal-body{padding:20px 28px}.alert-type-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.alert-type-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.alert-type-form-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.alert-type-required{color:var(--danger, #dc2626);margin-left:2px;font-size:14px}.alert-type-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:12px;border:1px solid var(--primary-border, #bfdbfe);text-transform:none;letter-spacing:normal;margin-left:8px}.alert-type-form-hint{font-size:11px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.alert-type-input,select.alert-type-input,textarea.alert-type-input{background:var(--bg-input, #ffffff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.alert-type-input:focus,select.alert-type-input:focus,textarea.alert-type-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.alert-type-input.alert-type-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}textarea.alert-type-input{resize:vertical;min-height:80px}.alert-type-error-message{color:var(--danger, #dc2626);font-size:11px;margin-top:4px;display:block}.alert-type-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.alert-type-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.alert-type-btn-sm{font-size:12px;padding:8px 14px}.alert-type-btn-primary{background:var(--primary, #2563eb);color:#fff}.alert-type-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.alert-type-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.alert-type-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.alert-type-btn-danger{background:var(--danger, #dc2626);color:#fff}.alert-type-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.alert-type-btn:disabled{opacity:.5;cursor:not-allowed}.alert-type-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:alert-type-spin .6s linear infinite;margin-right:6px}@keyframes alert-type-spin{to{transform:rotate(360deg)}}.alert-type-spin{animation:alert-type-spin 1s linear infinite}.alert-type-confirm-icon{text-align:center;margin-bottom:16px}.alert-type-confirm-icon .alert-type-text-success{color:var(--success, #16a34a)}.alert-type-confirm-icon .alert-type-text-danger{color:var(--danger, #dc2626)}.alert-type-confirm-message{font-size:14px;color:var(--tx2, #475569);text-align:center;line-height:1.6}@media(max-width:1200px){.alert-type-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:992px){.alert-type-severity-options{flex-direction:column;gap:8px}.alert-type-severity-option{width:100%}}@media(max-width:768px){.alert-type-page-hdr{flex-direction:column}.alert-type-page-actions{width:100%;justify-content:flex-start}.alert-type-filters-bar{flex-direction:column;align-items:stretch}.alert-type-search-wrapper{width:100%}.alert-type-filter-group{width:100%;flex-direction:column;align-items:stretch}.alert-type-filter-select{width:100%}.alert-type-stats-grid{grid-template-columns:1fr;gap:16px}.alert-type-modal{max-width:95%}.alert-type-lookup-table td{min-width:120px}.alert-type-lookup-table td:nth-child(3){min-width:200px}.alert-type-pagination{flex-direction:column;align-items:stretch}.alert-type-pagination-buttons{justify-content:center}.alert-type-action-buttons{justify-content:flex-start}.alert-type-grid-2{grid-template-columns:1fr}.alert-type-modal-hdr,.alert-type-modal-body,.alert-type-modal-foot{padding:16px 20px}.alert-type-modal-title{font-size:16px}.alert-type-btn{padding:8px 16px}}@media(max-width:480px){.alert-type-toast{min-width:auto;width:calc(100vw - 40px)}.alert-type-stats-card{padding:16px}.alert-type-stats-icon{width:44px;height:44px}.alert-type-stats-value{font-size:24px}.alert-type-code-badge{font-size:11px;padding:3px 6px}.alert-type-severity-badge{padding:4px 8px;font-size:11px}.alert-type-description-cell{font-size:13px}}@media print{.alert-type-page-actions,.alert-type-filters-bar,.alert-type-action-buttons,.alert-type-status-toggle,.alert-type-toast-container,.alert-type-modal-bg{display:none!important}.alert-type-card{box-shadow:none;border:1px solid #000}.alert-type-lookup-table th{background:#f0f0f0}.alert-type-lookup-table td{border-bottom:1px solid #ddd}}.session-status-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.session-status-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #ffffff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:session-status-toast-slide-in .3s ease;border-left:4px solid var(--primary, #2563eb);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.session-status-toast-success{border-left-color:var(--success, #16a34a)}.session-status-toast-error{border-left-color:var(--danger, #dc2626)}.session-status-toast-warning{border-left-color:var(--warning, #d97706)}.session-status-toast-info{border-left-color:var(--primary, #2563eb)}.session-status-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.session-status-toast-success .session-status-toast-icon{color:var(--success, #16a34a)}.session-status-toast-error .session-status-toast-icon{color:var(--danger, #dc2626)}.session-status-toast-warning .session-status-toast-icon{color:var(--warning, #d97706)}.session-status-toast-info .session-status-toast-icon{color:var(--primary, #2563eb)}.session-status-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.session-status-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;transition:color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.session-status-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes session-status-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.session-status-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.session-status-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.session-status-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.session-status-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.session-status-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.session-status-stats-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.session-status-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.session-status-stats-primary{border-left:4px solid var(--primary, #2563eb)}.session-status-stats-success{border-left:4px solid var(--success, #16a34a)}.session-status-stats-warning{border-left:4px solid var(--warning, #d97706)}.session-status-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--bg, #f8fafc)}.session-status-stats-primary .session-status-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.session-status-stats-success .session-status-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.session-status-stats-warning .session-status-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.session-status-stats-content{flex:1}.session-status-stats-title{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.session-status-stats-value{font-size:30px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.session-status-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #ffffff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.session-status-search-wrapper{position:relative;flex:1;min-width:280px}.session-status-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.session-status-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.session-status-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.session-status-search-input::placeholder{color:var(--tx3, #94a3b8)}.session-status-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.session-status-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.session-status-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.session-status-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.session-status-card:hover{box-shadow:0 8px 24px #00000014}.session-status-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.session-status-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.session-status-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.session-status-lookup-table th:hover{background:var(--bg-hover, #e2e8f0);color:var(--tx1, #0f172a)}.session-status-lookup-table td{padding:16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #ffffff);transition:background-color .2s}.session-status-lookup-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.session-status-sort-icon{margin-left:8px;color:var(--tx3, #94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.session-status-sort-icon.session-status-asc{transform:rotate(0)}.session-status-sort-icon.session-status-desc{transform:rotate(180deg)}.session-status-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block;white-space:nowrap}.session-status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:30px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.session-status-badge svg{width:12px;height:12px}.session-status-badge-pending{background:var(--pending-light, #fef3c7);color:var(--pending, #f59e0b);border-color:var(--warning-border, #fde68a)}.session-status-badge-active{background:var(--active-light, #d1fae5);color:var(--active, #10b981);border-color:var(--success-border, #bbf7d0)}.session-status-badge-closed{background:var(--closed-light, #f3f4f6);color:var(--closed, #6b7280);border-color:var(--border, #e2e8f0)}.session-status-badge-flagged{background:var(--flagged-light, #fee2e2);color:var(--flagged, #ef4444);border-color:var(--danger-border, #fecaca)}.session-status-badge-abandoned{background:var(--abandoned-light, #ede9fe);color:var(--abandoned, #7c3aed);border-color:#ddd6fe}.session-status-badge-default{background:var(--bg, #f8fafc);color:var(--tx2, #475569);border-color:var(--border, #e2e8f0)}.session-status-description-cell{max-width:300px;white-space:normal;word-wrap:break-word;line-height:1.5;color:var(--tx1, #0f172a)}.session-status-date-info{font-size:12px;color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.session-status-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.session-status-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.session-status-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.session-status-action-btn.session-status-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.session-status-action-btn:disabled{opacity:.5;cursor:not-allowed}.session-status-status-toggle{display:flex;align-items:center;gap:12px}.session-status-status-label{font-size:13px;font-weight:500}.session-status-status-label.session-status-active{color:var(--success, #16a34a)}.session-status-status-label.session-status-inactive{color:var(--danger, #dc2626)}.session-status-modern-switch{position:relative;display:inline-block;cursor:pointer}.session-status-modern-switch.session-status-small input+.session-status-switch-slider{width:40px;height:22px}.session-status-modern-switch.session-status-small input+.session-status-switch-slider .session-status-switch-handle{width:18px;height:18px}.session-status-modern-switch.session-status-small.session-status-checked input+.session-status-switch-slider .session-status-switch-handle{transform:translate(18px)}.session-status-modern-switch.session-status-medium input+.session-status-switch-slider{width:52px;height:28px}.session-status-modern-switch.session-status-medium input+.session-status-switch-slider .session-status-switch-handle{width:24px;height:24px}.session-status-modern-switch.session-status-medium.session-status-checked input+.session-status-switch-slider .session-status-switch-handle{transform:translate(24px)}.session-status-modern-switch input{opacity:0;width:0;height:0;position:absolute}.session-status-modern-switch .session-status-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.session-status-modern-switch.session-status-checked .session-status-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.session-status-modern-switch .session-status-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.session-status-modern-switch.session-status-disabled{opacity:.5;cursor:not-allowed}.session-status-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.session-status-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.session-status-pagination-buttons{display:flex;gap:6px}.session-status-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.session-status-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.session-status-pagination-btn.session-status-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.session-status-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.session-status-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #ffffff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.session-status-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.session-status-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.session-status-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.session-status-skeleton-table{background:var(--bg-card, #ffffff);border-radius:16px;padding:24px}.session-status-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.session-status-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:session-status-shimmer 1.5s infinite;border-radius:4px}@keyframes session-status-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.session-status-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:session-status-modal-fade-in .2s ease}@keyframes session-status-modal-fade-in{0%{opacity:0}to{opacity:1}}.session-status-modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:session-status-modal-scale-in .3s ease}@keyframes session-status-modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.session-status-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.session-status-modal-title{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.session-status-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.session-status-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.session-status-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.session-status-modal-body{padding:20px 28px}.session-status-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.session-status-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.session-status-form-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.session-status-required{color:var(--danger, #dc2626);margin-left:2px;font-size:14px}.session-status-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:12px;border:1px solid var(--primary-border, #bfdbfe);text-transform:none;letter-spacing:normal;margin-left:8px}.session-status-form-hint{font-size:11px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.session-status-input,select.session-status-input,textarea.session-status-input{background:var(--bg-input, #ffffff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.session-status-input:focus,select.session-status-input:focus,textarea.session-status-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.session-status-input.session-status-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}textarea.session-status-input{resize:vertical;min-height:80px}.session-status-error-message{color:var(--danger, #dc2626);font-size:11px;margin-top:4px;display:block}.session-status-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.session-status-btn-sm{font-size:12px;padding:8px 14px}.session-status-btn-primary{background:var(--primary, #2563eb);color:#fff}.session-status-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.session-status-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.session-status-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.session-status-btn-danger{background:var(--danger, #dc2626);color:#fff}.session-status-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.session-status-btn:disabled{opacity:.5;cursor:not-allowed}.session-status-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:session-status-spin .6s linear infinite;margin-right:6px}@keyframes session-status-spin{to{transform:rotate(360deg)}}.session-status-spin{animation:session-status-spin 1s linear infinite}.session-status-confirm-icon{text-align:center;margin-bottom:16px}.session-status-confirm-icon .session-status-text-success{color:var(--success, #16a34a)}.session-status-confirm-icon .session-status-text-danger{color:var(--danger, #dc2626)}.session-status-confirm-message{font-size:14px;color:var(--tx2, #475569);text-align:center;line-height:1.6}@media(max-width:1024px){.session-status-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.session-status-page-hdr{flex-direction:column}.session-status-page-actions{width:100%;justify-content:flex-start}.session-status-filters-bar{flex-direction:column;align-items:stretch}.session-status-search-wrapper,.session-status-filter-group,.session-status-filter-select{width:100%}.session-status-stats-grid{grid-template-columns:1fr;gap:16px}.session-status-modal{max-width:95%}.session-status-lookup-table td{min-width:120px}.session-status-lookup-table td:nth-child(3){min-width:200px}.session-status-pagination{flex-direction:column;align-items:stretch}.session-status-pagination-buttons{justify-content:center}.session-status-action-buttons{justify-content:flex-start}.session-status-modal-hdr,.session-status-modal-body,.session-status-modal-foot{padding:16px 20px}.session-status-modal-title{font-size:16px}.session-status-btn{padding:8px 16px}}@media(max-width:480px){.session-status-toast{min-width:auto;width:calc(100vw - 40px)}.session-status-stats-card{padding:16px}.session-status-stats-icon{width:44px;height:44px}.session-status-stats-value{font-size:24px}.session-status-code-badge{font-size:11px;padding:3px 6px}.session-status-badge{padding:4px 8px;font-size:11px}.session-status-description-cell{font-size:13px}}@media print{.session-status-page-actions,.session-status-filters-bar,.session-status-action-buttons,.session-status-status-toggle,.session-status-toast-container,.session-status-modal-bg{display:none!important}.session-status-card{box-shadow:none;border:1px solid #000}.session-status-lookup-table th{background:#f0f0f0}.session-status-lookup-table td{border-bottom:1px solid #ddd}}.cell-status-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.cell-status-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #ffffff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:cell-status-toast-slide-in .3s ease;border-left:4px solid var(--primary, #2563eb);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cell-status-toast-success{border-left-color:var(--success, #16a34a)}.cell-status-toast-error{border-left-color:var(--danger, #dc2626)}.cell-status-toast-warning{border-left-color:var(--warning, #d97706)}.cell-status-toast-info{border-left-color:var(--primary, #2563eb)}.cell-status-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.cell-status-toast-success .cell-status-toast-icon{color:var(--success, #16a34a)}.cell-status-toast-error .cell-status-toast-icon{color:var(--danger, #dc2626)}.cell-status-toast-warning .cell-status-toast-icon{color:var(--warning, #d97706)}.cell-status-toast-info .cell-status-toast-icon{color:var(--primary, #2563eb)}.cell-status-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.cell-status-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;transition:color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.cell-status-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes cell-status-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.cell-status-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.cell-status-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.cell-status-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.cell-status-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.cell-status-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.cell-status-stats-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.cell-status-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.cell-status-stats-primary{border-left:4px solid var(--primary, #2563eb)}.cell-status-stats-success{border-left:4px solid var(--success, #16a34a)}.cell-status-stats-warning{border-left:4px solid var(--warning, #d97706)}.cell-status-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--bg, #f8fafc)}.cell-status-stats-primary .cell-status-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.cell-status-stats-success .cell-status-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.cell-status-stats-warning .cell-status-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.cell-status-stats-content{flex:1}.cell-status-stats-title{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.cell-status-stats-value{font-size:30px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.cell-status-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #ffffff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.cell-status-search-wrapper{position:relative;flex:1;min-width:280px}.cell-status-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.cell-status-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.cell-status-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.cell-status-search-input::placeholder{color:var(--tx3, #94a3b8)}.cell-status-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.cell-status-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.cell-status-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.cell-status-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.cell-status-card:hover{box-shadow:0 8px 24px #00000014}.cell-status-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.cell-status-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.cell-status-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.cell-status-lookup-table th:hover{background:var(--bg-hover, #e2e8f0);color:var(--tx1, #0f172a)}.cell-status-lookup-table td{padding:16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #ffffff);transition:background-color .2s}.cell-status-lookup-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.cell-status-sort-icon{margin-left:8px;color:var(--tx3, #94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.cell-status-sort-icon.cell-status-asc{transform:rotate(0)}.cell-status-sort-icon.cell-status-desc{transform:rotate(180deg)}.cell-status-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block;white-space:nowrap}.cell-status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:30px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.cell-status-badge svg{width:12px;height:12px}.cell-status-badge-available{background:var(--available-light, #d1fae5);color:var(--available, #10b981);border-color:var(--success-border, #bbf7d0)}.cell-status-badge-occupied{background:var(--occupied-light, #fef3c7);color:var(--occupied, #f59e0b);border-color:var(--warning-border, #fde68a)}.cell-status-badge-stacked{background:var(--stacked-light, #ede9fe);color:var(--stacked, #8b5cf6);border-color:#ddd6fe}.cell-status-badge-maintenance{background:var(--maintenance-light, #f3f4f6);color:var(--maintenance, #6b7280);border-color:var(--border, #e2e8f0)}.cell-status-badge-default{background:var(--bg, #f8fafc);color:var(--tx2, #475569);border-color:var(--border, #e2e8f0)}.cell-status-description-cell{max-width:300px;white-space:normal;word-wrap:break-word;line-height:1.5;color:var(--tx1, #0f172a)}.cell-status-date-info{font-size:12px;color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.cell-status-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.cell-status-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cell-status-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.cell-status-action-btn.cell-status-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.cell-status-action-btn:disabled{opacity:.5;cursor:not-allowed}.cell-status-status-toggle{display:flex;align-items:center;gap:12px}.cell-status-status-label{font-size:13px;font-weight:500}.cell-status-status-label.cell-status-active{color:var(--success, #16a34a)}.cell-status-status-label.cell-status-inactive{color:var(--danger, #dc2626)}.cell-status-modern-switch{position:relative;display:inline-block;cursor:pointer}.cell-status-modern-switch.cell-status-small input+.cell-status-switch-slider{width:40px;height:22px}.cell-status-modern-switch.cell-status-small input+.cell-status-switch-slider .cell-status-switch-handle{width:18px;height:18px}.cell-status-modern-switch.cell-status-small.cell-status-checked input+.cell-status-switch-slider .cell-status-switch-handle{transform:translate(18px)}.cell-status-modern-switch.cell-status-medium input+.cell-status-switch-slider{width:52px;height:28px}.cell-status-modern-switch.cell-status-medium input+.cell-status-switch-slider .cell-status-switch-handle{width:24px;height:24px}.cell-status-modern-switch.cell-status-medium.cell-status-checked input+.cell-status-switch-slider .cell-status-switch-handle{transform:translate(24px)}.cell-status-modern-switch input{opacity:0;width:0;height:0;position:absolute}.cell-status-modern-switch .cell-status-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.cell-status-modern-switch.cell-status-checked .cell-status-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.cell-status-modern-switch .cell-status-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.cell-status-modern-switch.cell-status-disabled{opacity:.5;cursor:not-allowed}.cell-status-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.cell-status-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.cell-status-pagination-buttons{display:flex;gap:6px}.cell-status-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cell-status-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.cell-status-pagination-btn.cell-status-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.cell-status-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.cell-status-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #ffffff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.cell-status-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.cell-status-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.cell-status-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.cell-status-skeleton-table{background:var(--bg-card, #ffffff);border-radius:16px;padding:24px}.cell-status-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.cell-status-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:cell-status-shimmer 1.5s infinite;border-radius:4px}@keyframes cell-status-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.cell-status-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:cell-status-modal-fade-in .2s ease}@keyframes cell-status-modal-fade-in{0%{opacity:0}to{opacity:1}}.cell-status-modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:cell-status-modal-scale-in .3s ease}@keyframes cell-status-modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.cell-status-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.cell-status-modal-title{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.cell-status-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.cell-status-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.cell-status-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.cell-status-modal-body{padding:20px 28px}.cell-status-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.cell-status-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.cell-status-form-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.cell-status-required{color:var(--danger, #dc2626);margin-left:2px;font-size:14px}.cell-status-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:12px;border:1px solid var(--primary-border, #bfdbfe);text-transform:none;letter-spacing:normal;margin-left:8px}.cell-status-form-hint{font-size:11px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.cell-status-input,select.cell-status-input,textarea.cell-status-input{background:var(--bg-input, #ffffff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.cell-status-input:focus,select.cell-status-input:focus,textarea.cell-status-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cell-status-input.cell-status-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}textarea.cell-status-input{resize:vertical;min-height:80px}.cell-status-error-message{color:var(--danger, #dc2626);font-size:11px;margin-top:4px;display:block}.cell-status-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.cell-status-btn-sm{font-size:12px;padding:8px 14px}.cell-status-btn-primary{background:var(--primary, #2563eb);color:#fff}.cell-status-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.cell-status-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.cell-status-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.cell-status-btn-danger{background:var(--danger, #dc2626);color:#fff}.cell-status-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.cell-status-btn:disabled{opacity:.5;cursor:not-allowed}.cell-status-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:cell-status-spin .6s linear infinite;margin-right:6px}@keyframes cell-status-spin{to{transform:rotate(360deg)}}.cell-status-spin{animation:cell-status-spin 1s linear infinite}.cell-status-confirm-icon{text-align:center;margin-bottom:16px}.cell-status-confirm-icon .cell-status-text-success{color:var(--success, #16a34a)}.cell-status-confirm-icon .cell-status-text-danger{color:var(--danger, #dc2626)}.cell-status-confirm-message{font-size:14px;color:var(--tx2, #475569);text-align:center;line-height:1.6}@media(max-width:1024px){.cell-status-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.cell-status-page-hdr{flex-direction:column}.cell-status-page-actions{width:100%;justify-content:flex-start}.cell-status-filters-bar{flex-direction:column;align-items:stretch}.cell-status-search-wrapper,.cell-status-filter-group,.cell-status-filter-select{width:100%}.cell-status-stats-grid{grid-template-columns:1fr;gap:16px}.cell-status-modal{max-width:95%}.cell-status-lookup-table td{min-width:120px}.cell-status-lookup-table td:nth-child(3){min-width:200px}.cell-status-pagination{flex-direction:column;align-items:stretch}.cell-status-pagination-buttons{justify-content:center}.cell-status-action-buttons{justify-content:flex-start}.cell-status-modal-hdr,.cell-status-modal-body,.cell-status-modal-foot{padding:16px 20px}.cell-status-modal-title{font-size:16px}.cell-status-btn{padding:8px 16px}}@media(max-width:480px){.cell-status-toast{min-width:auto;width:calc(100vw - 40px)}.cell-status-stats-card{padding:16px}.cell-status-stats-icon{width:44px;height:44px}.cell-status-stats-value{font-size:24px}.cell-status-code-badge{font-size:11px;padding:3px 6px}.cell-status-badge{padding:4px 8px;font-size:11px}.cell-status-description-cell{font-size:13px}}@media print{.cell-status-page-actions,.cell-status-filters-bar,.cell-status-action-buttons,.cell-status-status-toggle,.cell-status-toast-container,.cell-status-modal-bg{display:none!important}.cell-status-card{box-shadow:none;border:1px solid #000}.cell-status-lookup-table th{background:#f0f0f0}.cell-status-lookup-table td{border-bottom:1px solid #ddd}}.stack-position-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.stack-position-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #ffffff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:stack-position-toast-slide-in .3s ease;border-left:4px solid var(--primary, #2563eb);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stack-position-toast-success{border-left-color:var(--success, #16a34a)}.stack-position-toast-error{border-left-color:var(--danger, #dc2626)}.stack-position-toast-warning{border-left-color:var(--warning, #d97706)}.stack-position-toast-info{border-left-color:var(--primary, #2563eb)}.stack-position-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.stack-position-toast-success .stack-position-toast-icon{color:var(--success, #16a34a)}.stack-position-toast-error .stack-position-toast-icon{color:var(--danger, #dc2626)}.stack-position-toast-warning .stack-position-toast-icon{color:var(--warning, #d97706)}.stack-position-toast-info .stack-position-toast-icon{color:var(--primary, #2563eb)}.stack-position-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.stack-position-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;transition:color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.stack-position-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes stack-position-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.stack-position-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.stack-position-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.stack-position-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.stack-position-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.stack-position-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.stack-position-stats-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.stack-position-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.stack-position-stats-primary{border-left:4px solid var(--primary, #2563eb)}.stack-position-stats-success{border-left:4px solid var(--success, #16a34a)}.stack-position-stats-warning{border-left:4px solid var(--warning, #d97706)}.stack-position-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--bg, #f8fafc)}.stack-position-stats-primary .stack-position-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.stack-position-stats-success .stack-position-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.stack-position-stats-warning .stack-position-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.stack-position-stats-content{flex:1}.stack-position-stats-title{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.stack-position-stats-value{font-size:30px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.stack-position-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #ffffff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.stack-position-search-wrapper{position:relative;flex:1;min-width:280px}.stack-position-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.stack-position-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.stack-position-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.stack-position-search-input::placeholder{color:var(--tx3, #94a3b8)}.stack-position-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.stack-position-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.stack-position-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.stack-position-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.stack-position-card:hover{box-shadow:0 8px 24px #00000014}.stack-position-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.stack-position-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.stack-position-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.stack-position-lookup-table th:hover{background:var(--bg-hover, #e2e8f0);color:var(--tx1, #0f172a)}.stack-position-lookup-table td{padding:16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #ffffff);transition:background-color .2s}.stack-position-lookup-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.stack-position-lookup-table tr.stack-position-dragging{opacity:.5;background:var(--primary-light, #dbeafe)}.stack-position-lookup-table tr.stack-position-dragging td{background:var(--primary-light, #dbeafe)}.stack-position-sort-icon{margin-left:8px;color:var(--tx3, #94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.stack-position-sort-icon.stack-position-asc{transform:rotate(0)}.stack-position-sort-icon.stack-position-desc{transform:rotate(180deg)}.stack-position-drag-handle{color:var(--tx3, #94a3b8);cursor:grab;transition:color .2s}.stack-position-drag-handle:hover{color:var(--primary, #2563eb)}.stack-position-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg, #f8fafc);border-radius:8px;color:var(--tx3, #64748b);font-size:12px;border:1px dashed var(--border, #e2e8f0);margin-bottom:16px}.stack-position-drag-hint svg{color:var(--primary, #2563eb)}.stack-position-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block;white-space:nowrap}.stack-position-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:var(--bg, #f8fafc);color:var(--tx2, #475569);border:1px solid var(--border, #e2e8f0)}.stack-position-icon svg{width:16px;height:16px}.stack-position-label-cell{font-weight:500;color:var(--tx1, #0f172a)}.stack-position-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2, #475569);padding:0 8px}.stack-position-date-info{font-size:12px;color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.stack-position-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.stack-position-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.stack-position-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.stack-position-action-btn.stack-position-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.stack-position-action-btn:disabled{opacity:.5;cursor:not-allowed}.stack-position-status-toggle{display:flex;align-items:center;gap:12px}.stack-position-status-label{font-size:13px;font-weight:500}.stack-position-status-label.stack-position-active{color:var(--success, #16a34a)}.stack-position-status-label.stack-position-inactive{color:var(--danger, #dc2626)}.stack-position-modern-switch{position:relative;display:inline-block;cursor:pointer}.stack-position-modern-switch.stack-position-small input+.stack-position-switch-slider{width:40px;height:22px}.stack-position-modern-switch.stack-position-small input+.stack-position-switch-slider .stack-position-switch-handle{width:18px;height:18px}.stack-position-modern-switch.stack-position-small.stack-position-checked input+.stack-position-switch-slider .stack-position-switch-handle{transform:translate(18px)}.stack-position-modern-switch.stack-position-medium input+.stack-position-switch-slider{width:52px;height:28px}.stack-position-modern-switch.stack-position-medium input+.stack-position-switch-slider .stack-position-switch-handle{width:24px;height:24px}.stack-position-modern-switch.stack-position-medium.stack-position-checked input+.stack-position-switch-slider .stack-position-switch-handle{transform:translate(24px)}.stack-position-modern-switch input{opacity:0;width:0;height:0;position:absolute}.stack-position-modern-switch .stack-position-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.stack-position-modern-switch.stack-position-checked .stack-position-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.stack-position-modern-switch .stack-position-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.stack-position-modern-switch.stack-position-disabled{opacity:.5;cursor:not-allowed}.stack-position-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.stack-position-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.stack-position-pagination-buttons{display:flex;gap:6px}.stack-position-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.stack-position-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.stack-position-pagination-btn.stack-position-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.stack-position-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.stack-position-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #ffffff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.stack-position-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.stack-position-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.stack-position-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.stack-position-skeleton-table{background:var(--bg-card, #ffffff);border-radius:16px;padding:24px}.stack-position-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.stack-position-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:stack-position-shimmer 1.5s infinite;border-radius:4px}@keyframes stack-position-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.stack-position-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:stack-position-modal-fade-in .2s ease}@keyframes stack-position-modal-fade-in{0%{opacity:0}to{opacity:1}}.stack-position-modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:stack-position-modal-scale-in .3s ease}@keyframes stack-position-modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.stack-position-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.stack-position-modal-title{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.stack-position-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.stack-position-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.stack-position-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.stack-position-modal-body{padding:20px 28px}.stack-position-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.stack-position-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.stack-position-form-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.stack-position-required{color:var(--danger, #dc2626);margin-left:2px;font-size:14px}.stack-position-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:12px;border:1px solid var(--primary-border, #bfdbfe);text-transform:none;letter-spacing:normal;margin-left:8px}.stack-position-form-hint{font-size:11px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.stack-position-input,select.stack-position-input,textarea.stack-position-input{background:var(--bg-input, #ffffff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.stack-position-input:focus,select.stack-position-input:focus,textarea.stack-position-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.stack-position-input.stack-position-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}textarea.stack-position-input{resize:vertical;min-height:80px}.stack-position-error-message{color:var(--danger, #dc2626);font-size:11px;margin-top:4px;display:block}.stack-position-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stack-position-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.stack-position-btn-sm{font-size:12px;padding:8px 14px}.stack-position-btn-primary{background:var(--primary, #2563eb);color:#fff}.stack-position-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.stack-position-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.stack-position-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.stack-position-btn-danger{background:var(--danger, #dc2626);color:#fff}.stack-position-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.stack-position-btn:disabled{opacity:.5;cursor:not-allowed}.stack-position-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:stack-position-spin .6s linear infinite;margin-right:6px}@keyframes stack-position-spin{to{transform:rotate(360deg)}}.stack-position-spin{animation:stack-position-spin 1s linear infinite}.stack-position-confirm-icon{text-align:center;margin-bottom:16px}.stack-position-confirm-icon .stack-position-text-success{color:var(--success, #16a34a)}.stack-position-confirm-icon .stack-position-text-danger{color:var(--danger, #dc2626)}.stack-position-confirm-message{font-size:14px;color:var(--tx2, #475569);text-align:center;line-height:1.6}@media(max-width:1024px){.stack-position-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.stack-position-page-hdr{flex-direction:column}.stack-position-page-actions{width:100%;justify-content:flex-start}.stack-position-filters-bar{flex-direction:column;align-items:stretch}.stack-position-search-wrapper,.stack-position-filter-group,.stack-position-filter-select{width:100%}.stack-position-stats-grid{grid-template-columns:1fr;gap:16px}.stack-position-modal{max-width:95%}.stack-position-lookup-table td{min-width:100px}.stack-position-lookup-table td:nth-child(4){min-width:150px}.stack-position-pagination{flex-direction:column;align-items:stretch}.stack-position-pagination-buttons{justify-content:center}.stack-position-action-buttons{justify-content:flex-start}.stack-position-grid-2{grid-template-columns:1fr}.stack-position-modal-hdr,.stack-position-modal-body,.stack-position-modal-foot{padding:16px 20px}.stack-position-modal-title{font-size:16px}.stack-position-btn{padding:8px 16px}}@media(max-width:480px){.stack-position-toast{min-width:auto;width:calc(100vw - 40px)}.stack-position-stats-card{padding:16px}.stack-position-stats-icon{width:44px;height:44px}.stack-position-stats-value{font-size:24px}.stack-position-code-badge{font-size:11px;padding:3px 6px}.stack-position-icon{width:28px;height:28px}.stack-position-sort-order{min-width:28px;height:28px;font-size:12px}}@media print{.stack-position-page-actions,.stack-position-filters-bar,.stack-position-action-buttons,.stack-position-status-toggle,.stack-position-drag-handle,.stack-position-drag-hint,.stack-position-toast-container,.stack-position-modal-bg{display:none!important}.stack-position-card{box-shadow:none;border:1px solid #000}.stack-position-lookup-table th{background:#f0f0f0}.stack-position-lookup-table td{border-bottom:1px solid #ddd}}.missing-asset-reason-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.missing-asset-reason-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #ffffff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:missing-asset-reason-toast-slide-in .3s ease;border-left:4px solid var(--primary, #2563eb);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.missing-asset-reason-toast-success{border-left-color:var(--success, #16a34a)}.missing-asset-reason-toast-error{border-left-color:var(--danger, #dc2626)}.missing-asset-reason-toast-warning{border-left-color:var(--warning, #d97706)}.missing-asset-reason-toast-info{border-left-color:var(--primary, #2563eb)}.missing-asset-reason-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.missing-asset-reason-toast-success .missing-asset-reason-toast-icon{color:var(--success, #16a34a)}.missing-asset-reason-toast-error .missing-asset-reason-toast-icon{color:var(--danger, #dc2626)}.missing-asset-reason-toast-warning .missing-asset-reason-toast-icon{color:var(--warning, #d97706)}.missing-asset-reason-toast-info .missing-asset-reason-toast-icon{color:var(--primary, #2563eb)}.missing-asset-reason-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.missing-asset-reason-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;transition:color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.missing-asset-reason-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes missing-asset-reason-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.missing-asset-reason-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.missing-asset-reason-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.missing-asset-reason-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.missing-asset-reason-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.missing-asset-reason-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.missing-asset-reason-stats-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.missing-asset-reason-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.missing-asset-reason-stats-primary{border-left:4px solid var(--primary, #2563eb)}.missing-asset-reason-stats-success{border-left:4px solid var(--success, #16a34a)}.missing-asset-reason-stats-warning{border-left:4px solid var(--warning, #d97706)}.missing-asset-reason-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--bg, #f8fafc)}.missing-asset-reason-stats-primary .missing-asset-reason-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.missing-asset-reason-stats-success .missing-asset-reason-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.missing-asset-reason-stats-warning .missing-asset-reason-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.missing-asset-reason-stats-content{flex:1}.missing-asset-reason-stats-title{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.missing-asset-reason-stats-value{font-size:30px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.missing-asset-reason-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #ffffff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.missing-asset-reason-search-wrapper{position:relative;flex:1;min-width:280px}.missing-asset-reason-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.missing-asset-reason-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.missing-asset-reason-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.missing-asset-reason-search-input::placeholder{color:var(--tx3, #94a3b8)}.missing-asset-reason-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.missing-asset-reason-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.missing-asset-reason-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.missing-asset-reason-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.missing-asset-reason-card:hover{box-shadow:0 8px 24px #00000014}.missing-asset-reason-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.missing-asset-reason-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.missing-asset-reason-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.missing-asset-reason-lookup-table th:hover{background:var(--bg-hover, #e2e8f0);color:var(--tx1, #0f172a)}.missing-asset-reason-lookup-table td{padding:16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #ffffff);transition:background-color .2s}.missing-asset-reason-lookup-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.missing-asset-reason-lookup-table tr.missing-asset-reason-dragging{opacity:.5;background:var(--primary-light, #dbeafe)}.missing-asset-reason-lookup-table tr.missing-asset-reason-dragging td{background:var(--primary-light, #dbeafe)}.missing-asset-reason-sort-icon{margin-left:8px;color:var(--tx3, #94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.missing-asset-reason-sort-icon.missing-asset-reason-asc{transform:rotate(0)}.missing-asset-reason-sort-icon.missing-asset-reason-desc{transform:rotate(180deg)}.missing-asset-reason-drag-handle{color:var(--tx3, #94a3b8);cursor:grab;transition:color .2s}.missing-asset-reason-drag-handle:hover{color:var(--primary, #2563eb)}.missing-asset-reason-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg, #f8fafc);border-radius:8px;color:var(--tx3, #64748b);font-size:12px;border:1px dashed var(--border, #e2e8f0);margin-bottom:16px}.missing-asset-reason-drag-hint svg{color:var(--primary, #2563eb)}.missing-asset-reason-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block;white-space:nowrap}.missing-asset-reason-reason-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.missing-asset-reason-reason-badge svg{width:12px;height:12px}.missing-asset-reason-badge-lost{background:var(--lost-light, #fee2e2);color:var(--lost, #ef4444);border-color:var(--danger-border, #fecaca)}.missing-asset-reason-badge-forgotten{background:var(--forgotten-light, #fef3c7);color:var(--forgotten, #f59e0b);border-color:var(--warning-border, #fde68a)}.missing-asset-reason-badge-stolen{background:var(--stolen-light, #ede9fe);color:var(--stolen, #7c3aed);border-color:#ddd6fe}.missing-asset-reason-badge-left{background:var(--left-light, #d1fae5);color:var(--left, #10b981);border-color:var(--success-border, #bbf7d0)}.missing-asset-reason-badge-other{background:var(--other-light, #f3f4f6);color:var(--other, #6b7280);border-color:var(--border, #e2e8f0)}.missing-asset-reason-label-cell{font-weight:500;color:var(--tx1, #0f172a)}.missing-asset-reason-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2, #475569);padding:0 8px}.missing-asset-reason-date-info{font-size:12px;color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.missing-asset-reason-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.missing-asset-reason-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.missing-asset-reason-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.missing-asset-reason-action-btn.missing-asset-reason-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.missing-asset-reason-action-btn:disabled{opacity:.5;cursor:not-allowed}.missing-asset-reason-status-toggle{display:flex;align-items:center;gap:12px}.missing-asset-reason-status-label{font-size:13px;font-weight:500}.missing-asset-reason-status-label.missing-asset-reason-active{color:var(--success, #16a34a)}.missing-asset-reason-status-label.missing-asset-reason-inactive{color:var(--danger, #dc2626)}.missing-asset-reason-modern-switch{position:relative;display:inline-block;cursor:pointer}.missing-asset-reason-modern-switch.missing-asset-reason-small input+.missing-asset-reason-switch-slider{width:40px;height:22px}.missing-asset-reason-modern-switch.missing-asset-reason-small input+.missing-asset-reason-switch-slider .missing-asset-reason-switch-handle{width:18px;height:18px}.missing-asset-reason-modern-switch.missing-asset-reason-small.missing-asset-reason-checked input+.missing-asset-reason-switch-slider .missing-asset-reason-switch-handle{transform:translate(18px)}.missing-asset-reason-modern-switch.missing-asset-reason-medium input+.missing-asset-reason-switch-slider{width:52px;height:28px}.missing-asset-reason-modern-switch.missing-asset-reason-medium input+.missing-asset-reason-switch-slider .missing-asset-reason-switch-handle{width:24px;height:24px}.missing-asset-reason-modern-switch.missing-asset-reason-medium.missing-asset-reason-checked input+.missing-asset-reason-switch-slider .missing-asset-reason-switch-handle{transform:translate(24px)}.missing-asset-reason-modern-switch input{opacity:0;width:0;height:0;position:absolute}.missing-asset-reason-modern-switch .missing-asset-reason-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.missing-asset-reason-modern-switch.missing-asset-reason-checked .missing-asset-reason-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.missing-asset-reason-modern-switch .missing-asset-reason-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.missing-asset-reason-modern-switch.missing-asset-reason-disabled{opacity:.5;cursor:not-allowed}.missing-asset-reason-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.missing-asset-reason-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.missing-asset-reason-pagination-buttons{display:flex;gap:6px}.missing-asset-reason-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.missing-asset-reason-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.missing-asset-reason-pagination-btn.missing-asset-reason-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.missing-asset-reason-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.missing-asset-reason-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #ffffff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.missing-asset-reason-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.missing-asset-reason-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.missing-asset-reason-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.missing-asset-reason-skeleton-table{background:var(--bg-card, #ffffff);border-radius:16px;padding:24px}.missing-asset-reason-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.missing-asset-reason-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:missing-asset-reason-shimmer 1.5s infinite;border-radius:4px}@keyframes missing-asset-reason-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.missing-asset-reason-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:missing-asset-reason-modal-fade-in .2s ease}@keyframes missing-asset-reason-modal-fade-in{0%{opacity:0}to{opacity:1}}.missing-asset-reason-modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:missing-asset-reason-modal-scale-in .3s ease}@keyframes missing-asset-reason-modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.missing-asset-reason-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.missing-asset-reason-modal-title{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.missing-asset-reason-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.missing-asset-reason-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.missing-asset-reason-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.missing-asset-reason-modal-body{padding:20px 28px}.missing-asset-reason-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.missing-asset-reason-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.missing-asset-reason-form-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.missing-asset-reason-required{color:var(--danger, #dc2626);margin-left:2px;font-size:14px}.missing-asset-reason-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:12px;border:1px solid var(--primary-border, #bfdbfe);text-transform:none;letter-spacing:normal;margin-left:8px}.missing-asset-reason-form-hint{font-size:11px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.missing-asset-reason-input,select.missing-asset-reason-input,textarea.missing-asset-reason-input{background:var(--bg-input, #ffffff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.missing-asset-reason-input:focus,select.missing-asset-reason-input:focus,textarea.missing-asset-reason-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.missing-asset-reason-input.missing-asset-reason-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}textarea.missing-asset-reason-input{resize:vertical;min-height:80px}.missing-asset-reason-error-message{color:var(--danger, #dc2626);font-size:11px;margin-top:4px;display:block}.missing-asset-reason-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.missing-asset-reason-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.missing-asset-reason-btn-sm{font-size:12px;padding:8px 14px}.missing-asset-reason-btn-primary{background:var(--primary, #2563eb);color:#fff}.missing-asset-reason-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.missing-asset-reason-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.missing-asset-reason-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.missing-asset-reason-btn-danger{background:var(--danger, #dc2626);color:#fff}.missing-asset-reason-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.missing-asset-reason-btn:disabled{opacity:.5;cursor:not-allowed}.missing-asset-reason-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:missing-asset-reason-spin .6s linear infinite;margin-right:6px}@keyframes missing-asset-reason-spin{to{transform:rotate(360deg)}}.missing-asset-reason-spin{animation:missing-asset-reason-spin 1s linear infinite}.missing-asset-reason-confirm-icon{text-align:center;margin-bottom:16px}.missing-asset-reason-confirm-icon .missing-asset-reason-text-success{color:var(--success, #16a34a)}.missing-asset-reason-confirm-icon .missing-asset-reason-text-danger{color:var(--danger, #dc2626)}.missing-asset-reason-confirm-message{font-size:14px;color:var(--tx2, #475569);text-align:center;line-height:1.6}@media(max-width:1024px){.missing-asset-reason-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.missing-asset-reason-page-hdr{flex-direction:column}.missing-asset-reason-page-actions{width:100%;justify-content:flex-start}.missing-asset-reason-filters-bar{flex-direction:column;align-items:stretch}.missing-asset-reason-search-wrapper,.missing-asset-reason-filter-group,.missing-asset-reason-filter-select{width:100%}.missing-asset-reason-stats-grid{grid-template-columns:1fr;gap:16px}.missing-asset-reason-modal{max-width:95%}.missing-asset-reason-lookup-table td{min-width:100px}.missing-asset-reason-lookup-table td:nth-child(4){min-width:200px}.missing-asset-reason-pagination{flex-direction:column;align-items:stretch}.missing-asset-reason-pagination-buttons{justify-content:center}.missing-asset-reason-action-buttons{justify-content:flex-start}.missing-asset-reason-grid-2{grid-template-columns:1fr}.missing-asset-reason-modal-hdr,.missing-asset-reason-modal-body,.missing-asset-reason-modal-foot{padding:16px 20px}.missing-asset-reason-modal-title{font-size:16px}.missing-asset-reason-btn{padding:8px 16px}}@media(max-width:480px){.missing-asset-reason-toast{min-width:auto;width:calc(100vw - 40px)}.missing-asset-reason-stats-card{padding:16px}.missing-asset-reason-stats-icon{width:44px;height:44px}.missing-asset-reason-stats-value{font-size:24px}.missing-asset-reason-code-badge{font-size:11px;padding:3px 6px}.missing-asset-reason-reason-badge{padding:3px 8px;font-size:10px}.missing-asset-reason-sort-order{min-width:28px;height:28px;font-size:12px}}@media print{.missing-asset-reason-page-actions,.missing-asset-reason-filters-bar,.missing-asset-reason-action-buttons,.missing-asset-reason-status-toggle,.missing-asset-reason-drag-handle,.missing-asset-reason-drag-hint,.missing-asset-reason-toast-container,.missing-asset-reason-modal-bg{display:none!important}.missing-asset-reason-card{box-shadow:none;border:1px solid #000}.missing-asset-reason-lookup-table th{background:#f0f0f0}.missing-asset-reason-lookup-table td{border-bottom:1px solid #ddd}}.cabinet-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.cabinet-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #ffffff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:cabinet-toast-slide-in .3s ease;border-left:4px solid var(--primary, #2563eb);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cabinet-toast-success{border-left-color:var(--success, #16a34a)}.cabinet-toast-error{border-left-color:var(--danger, #dc2626)}.cabinet-toast-warning{border-left-color:var(--warning, #d97706)}.cabinet-toast-info{border-left-color:var(--primary, #2563eb)}.cabinet-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.cabinet-toast-success .cabinet-toast-icon{color:var(--success, #16a34a)}.cabinet-toast-error .cabinet-toast-icon{color:var(--danger, #dc2626)}.cabinet-toast-warning .cabinet-toast-icon{color:var(--warning, #d97706)}.cabinet-toast-info .cabinet-toast-icon{color:var(--primary, #2563eb)}.cabinet-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.cabinet-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;transition:color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.cabinet-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes cabinet-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.cabinet-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.cabinet-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.cabinet-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.cabinet-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.cabinet-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.cabinet-stats-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.cabinet-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.cabinet-stats-primary{border-left:4px solid var(--primary, #2563eb)}.cabinet-stats-success{border-left:4px solid var(--success, #16a34a)}.cabinet-stats-warning{border-left:4px solid var(--warning, #d97706)}.cabinet-stats-danger{border-left:4px solid var(--danger, #dc2626)}.cabinet-stats-info{border-left:4px solid var(--info, #0891b2)}.cabinet-stats-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg, #f8fafc)}.cabinet-stats-primary .cabinet-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.cabinet-stats-success .cabinet-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.cabinet-stats-warning .cabinet-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.cabinet-stats-danger .cabinet-stats-icon{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626)}.cabinet-stats-info .cabinet-stats-icon{background:var(--info-light, #cffafe);color:var(--info, #0891b2)}.cabinet-stats-content{flex:1}.cabinet-stats-title{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.cabinet-stats-value{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.cabinet-stats-sub{font-size:11px;color:var(--tx3, #64748b);margin-top:4px}.cabinet-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #ffffff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.cabinet-search-wrapper{position:relative;flex:1;min-width:280px}.cabinet-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.cabinet-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.cabinet-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.cabinet-search-input::placeholder{color:var(--tx3, #94a3b8)}.cabinet-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.cabinet-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.cabinet-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.cabinet-cabinets-list{display:flex;flex-direction:column;gap:16px}.cabinet-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:20px;transition:all .2s;box-shadow:0 2px 8px #0000000a}.cabinet-card:hover{box-shadow:0 8px 24px #00000014}.cabinet-card.cabinet-inactive{opacity:.7;background:var(--bg, #f8fafc)}.cabinet-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:16px}.cabinet-title{display:flex;align-items:center;gap:12px}.cabinet-title svg{color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:8px;border-radius:12px;width:36px;height:36px}.cabinet-title h3{font-size:16px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:2px}.cabinet-code{font-size:12px;color:var(--tx3, #64748b);font-family:monospace}.cabinet-stats{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.cabinet-stat-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:20px;font-size:12px;color:var(--tx2, #475569)}.cabinet-stat-badge svg{width:14px;height:14px;color:var(--tx3, #64748b)}.cabinet-actions{display:flex;gap:8px;align-items:center}.cabinet-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cabinet-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.cabinet-action-btn.cabinet-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.cabinet-action-btn:disabled{opacity:.5;cursor:not-allowed}.cabinet-progress{height:6px;background:var(--bg, #f1f5f9);border-radius:3px;margin-bottom:20px;overflow:hidden}.cabinet-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary, #2563eb) 0%,var(--info, #0891b2) 100%);border-radius:3px;transition:width .3s ease}.cabinet-cells-section{margin-top:20px}.cabinet-cells-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cabinet-cells-header h4{font-size:14px;font-weight:600;color:var(--tx2, #475569);text-transform:uppercase;letter-spacing:.5px}.cabinet-cells-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}.cabinet-cell-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:12px;cursor:pointer;transition:all .2s;position:relative}.cabinet-cell-item:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001a;border-color:var(--primary, #2563eb)}.cabinet-cell-item.cabinet-available{border-left:4px solid var(--available, #10b981)}.cabinet-cell-item.cabinet-occupied{border-left:4px solid var(--occupied, #f59e0b)}.cabinet-cell-item.cabinet-stacked{border-left:4px solid var(--stacked, #8b5cf6)}.cabinet-cell-item.cabinet-maintenance{border-left:4px solid var(--maintenance, #6b7280)}.cabinet-cell-number{font-size:13px;font-weight:700;color:var(--tx2, #475569)}.cabinet-cell-status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:20px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap;position:relative}.cabinet-cell-status-badge svg{width:12px;height:12px}.cabinet-cell-status-badge .cabinet-stack-indicator{position:absolute;top:-8px;right:-8px;background:var(--stacked, #8b5cf6);color:#fff;font-size:8px;font-weight:700;padding:2px 4px;border-radius:10px;min-width:16px;text-align:center}.cabinet-cell-status-badge.cabinet-badge-available{background:var(--available-light, #d1fae5);color:var(--available, #10b981);border-color:var(--success-border, #bbf7d0)}.cabinet-cell-status-badge.cabinet-badge-occupied{background:var(--occupied-light, #fef3c7);color:var(--occupied, #f59e0b);border-color:var(--warning-border, #fde68a)}.cabinet-cell-status-badge.cabinet-badge-stacked{background:var(--stacked-light, #ede9fe);color:var(--stacked, #8b5cf6);border-color:#ddd6fe}.cabinet-cell-status-badge.cabinet-badge-maintenance{background:var(--maintenance-light, #f3f4f6);color:var(--maintenance, #6b7280);border-color:var(--border, #e2e8f0)}.cabinet-cell-notes-indicator{position:absolute;top:2px;right:2px;font-size:10px;opacity:.7}.cabinet-stack-badge{position:absolute;top:-6px;right:-6px;background:var(--stacked, #8b5cf6);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:12px;min-width:20px;text-align:center;box-shadow:0 2px 4px #0003}.cabinet-cell-quick-stats{display:flex;gap:16px;margin-bottom:16px;padding:12px;background:var(--bg, #f8fafc);border-radius:12px}.cabinet-quick-stat{flex:1;display:flex;flex-direction:column;gap:4px}.cabinet-quick-stat .cabinet-stat-label{font-size:11px;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.3px}.cabinet-stack-count-badge{font-size:18px;font-weight:700;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:2px 8px;border-radius:20px;display:inline-block;width:fit-content}.cabinet-status-description{display:flex;align-items:center;gap:8px;padding:12px;background:var(--bg, #f8fafc);border-radius:10px;margin-bottom:20px;font-size:13px;color:var(--tx2, #475569);border-left:3px solid var(--info, #0891b2)}.cabinet-status-description svg{color:var(--info, #0891b2);flex-shrink:0}.cabinet-stack-controls{margin-bottom:20px;padding:16px;background:var(--bg, #f8fafc);border-radius:12px}.cabinet-stack-count-controls{display:flex;align-items:center;gap:16px;margin-top:12px}.cabinet-stack-btn{width:44px;height:44px;border-radius:12px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cabinet-stack-btn:hover:not(:disabled){background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb);transform:scale(1.05)}.cabinet-stack-btn:disabled{opacity:.4;cursor:not-allowed}.cabinet-stack-display{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.cabinet-stack-value{font-size:28px;font-weight:700;color:var(--tx1, #0f172a);line-height:1}.cabinet-stack-label{font-size:12px;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.3px}.cabinet-stack-warning{margin-top:12px}.cabinet-warning-text{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--warning, #d97706);background:var(--warning-light, #fef3c7);padding:8px 12px;border-radius:8px}.cabinet-warning-text svg{flex-shrink:0}.cabinet-advanced-toggle{width:100%;margin:16px 0;border:1px dashed var(--border, #e2e8f0)!important}.cabinet-advanced-options{padding:16px;background:var(--bg, #f8fafc);border-radius:12px;margin-bottom:16px;animation:cabinet-slide-down .3s ease}@keyframes cabinet-slide-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.cabinet-status-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:8px}.cabinet-status-option{padding:10px;border:1px solid var(--border, #e2e8f0);border-radius:10px;background:var(--bg-card, #ffffff);cursor:pointer;transition:all .2s;display:flex;justify-content:center}.cabinet-status-option:hover{border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #0000000d}.cabinet-status-option.cabinet-selected{background:var(--primary-light, #dbeafe);border-color:var(--primary, #2563eb);box-shadow:0 0 0 2px var(--primary-light, #dbeafe)}.cabinet-bulk-update-tabs{display:flex;gap:8px;margin-bottom:20px;padding:4px;background:var(--bg, #f8fafc);border-radius:10px}.cabinet-bulk-update-tabs .cabinet-tab-btn{flex:1;padding:10px;background:transparent;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;color:var(--tx2, #475569);display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}.cabinet-bulk-update-tabs .cabinet-tab-btn:hover{background:var(--bg-hover, #f1f5f9)}.cabinet-bulk-update-tabs .cabinet-tab-btn.cabinet-active{background:var(--bg-card, #ffffff);color:var(--primary, #2563eb);box-shadow:0 2px 8px #0000000d}.cabinet-bulk-update-content{margin-bottom:20px}.cabinet-stack-count-bulk{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}.cabinet-stack-option{padding:10px;border:1px solid var(--border, #e2e8f0);border-radius:10px;background:var(--bg-card, #ffffff);cursor:pointer;font-size:12px;font-weight:500;color:var(--tx2, #475569);transition:all .2s}.cabinet-stack-option:hover{border-color:var(--primary, #2563eb);transform:translateY(-2px)}.cabinet-stack-option.cabinet-selected{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.cabinet-cells-selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;max-height:300px;overflow-y:auto;padding:4px;margin:12px 0}.cabinet-cell-selection-item{display:flex;align-items:center;gap:8px;padding:8px;border:1px solid var(--border, #e2e8f0);border-radius:8px;cursor:pointer;transition:all .2s}.cabinet-cell-selection-item:hover{background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb)}.cabinet-cell-selection-item.cabinet-selected{background:var(--primary-light, #dbeafe);border-color:var(--primary, #2563eb)}.cabinet-cell-checkbox{color:var(--tx3, #64748b)}.cabinet-cell-selection-item.cabinet-selected .cabinet-cell-checkbox{color:var(--primary, #2563eb)}.cabinet-cell-info{display:flex;flex-direction:column;gap:2px}.cabinet-selection-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.cabinet-select-all-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:20px;font-size:12px;color:var(--tx2, #475569);cursor:pointer;transition:all .2s}.cabinet-select-all-btn:hover{background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.cabinet-selection-count{font-size:12px;color:var(--tx3, #64748b);text-align:right;margin-top:8px;padding-top:8px;border-top:1px solid var(--border, #e2e8f0)}.cabinet-success-hint{color:var(--success, #16a34a)!important;background:var(--success-light, #dcfce7);padding:4px 8px;border-radius:20px;display:inline-block}.cabinet-pagination{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:20px;border-top:1px solid var(--border, #e2e8f0);flex-wrap:wrap;gap:16px}.cabinet-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.cabinet-pagination-buttons{display:flex;gap:6px}.cabinet-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #ffffff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cabinet-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.cabinet-pagination-btn.cabinet-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.cabinet-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.cabinet-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #ffffff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.cabinet-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.cabinet-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.cabinet-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.cabinet-skeleton-table{background:var(--bg-card, #ffffff);border-radius:16px;padding:24px}.cabinet-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.cabinet-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:cabinet-shimmer 1.5s infinite;border-radius:4px}@keyframes cabinet-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.cabinet-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:cabinet-modal-fade-in .2s ease}@keyframes cabinet-modal-fade-in{0%{opacity:0}to{opacity:1}}.cabinet-modal{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:cabinet-modal-scale-in .3s ease}@keyframes cabinet-modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.cabinet-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.cabinet-modal-title{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.cabinet-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.cabinet-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.cabinet-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.cabinet-modal-body{padding:20px 28px}.cabinet-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.cabinet-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.cabinet-form-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.cabinet-required{color:var(--danger, #dc2626);margin-left:2px;font-size:14px}.cabinet-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:12px;border:1px solid var(--primary-border, #bfdbfe);text-transform:none;letter-spacing:normal;margin-left:8px}.cabinet-form-hint{font-size:11px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.cabinet-input,select.cabinet-input,textarea.cabinet-input{background:var(--bg-input, #ffffff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.cabinet-input:focus,select.cabinet-input:focus,textarea.cabinet-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cabinet-input.cabinet-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}textarea.cabinet-input{resize:vertical;min-height:80px}.cabinet-error-message{color:var(--danger, #dc2626);font-size:11px;margin-top:4px;display:block}.cabinet-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.cabinet-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit}.cabinet-btn-sm{font-size:12px;padding:8px 14px}.cabinet-btn-primary{background:var(--primary, #2563eb);color:#fff}.cabinet-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.cabinet-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.cabinet-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.cabinet-btn-danger{background:var(--danger, #dc2626);color:#fff}.cabinet-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.cabinet-btn:disabled{opacity:.5;cursor:not-allowed}.cabinet-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:cabinet-spin .6s linear infinite;margin-right:6px}@keyframes cabinet-spin{to{transform:rotate(360deg)}}.cabinet-spin{animation:cabinet-spin 1s linear infinite}.cabinet-confirm-icon{text-align:center;margin-bottom:16px}.cabinet-confirm-icon .cabinet-text-success{color:var(--success, #16a34a)}.cabinet-confirm-icon .cabinet-text-danger{color:var(--danger, #dc2626)}.cabinet-confirm-message{font-size:14px;color:var(--tx2, #475569);text-align:center;line-height:1.6}.cabinet-status-toggle{display:flex;align-items:center;gap:12px}.cabinet-status-label{font-size:13px;font-weight:500}.cabinet-status-label.cabinet-active{color:var(--success, #16a34a)}.cabinet-status-label.cabinet-inactive{color:var(--danger, #dc2626)}.cabinet-modern-switch{position:relative;display:inline-block;cursor:pointer}.cabinet-modern-switch.cabinet-small input+.cabinet-switch-slider{width:40px;height:22px}.cabinet-modern-switch.cabinet-small input+.cabinet-switch-slider .cabinet-switch-handle{width:18px;height:18px}.cabinet-modern-switch.cabinet-small.cabinet-checked input+.cabinet-switch-slider .cabinet-switch-handle{transform:translate(18px)}.cabinet-modern-switch.cabinet-medium input+.cabinet-switch-slider{width:52px;height:28px}.cabinet-modern-switch.cabinet-medium input+.cabinet-switch-slider .cabinet-switch-handle{width:24px;height:24px}.cabinet-modern-switch.cabinet-medium.cabinet-checked input+.cabinet-switch-slider .cabinet-switch-handle{transform:translate(24px)}.cabinet-modern-switch input{opacity:0;width:0;height:0;position:absolute}.cabinet-modern-switch .cabinet-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.cabinet-modern-switch.cabinet-checked .cabinet-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.cabinet-modern-switch .cabinet-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.cabinet-modern-switch.cabinet-disabled{opacity:.5;cursor:not-allowed}@media(max-width:1200px){.cabinet-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:992px){.cabinet-cells-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.cabinet-status-options-grid{grid-template-columns:1fr}.cabinet-stack-count-bulk{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.cabinet-page-hdr{flex-direction:column}.cabinet-page-actions{width:100%;justify-content:flex-start}.cabinet-filters-bar{flex-direction:column;align-items:stretch}.cabinet-search-wrapper,.cabinet-filter-group,.cabinet-filter-select{width:100%}.cabinet-stats-grid{grid-template-columns:1fr;gap:12px}.cabinet-header{flex-direction:column;align-items:flex-start}.cabinet-stats,.cabinet-actions{width:100%;justify-content:flex-start}.cabinet-cells-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.cabinet-bulk-update-tabs{flex-direction:column}.cabinet-cells-selection-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.cabinet-modal{max-width:95%}.cabinet-pagination{flex-direction:column;align-items:stretch}.cabinet-pagination-buttons{justify-content:center}.cabinet-grid-2{grid-template-columns:1fr}.cabinet-modal-hdr,.cabinet-modal-body,.cabinet-modal-foot{padding:16px 20px}.cabinet-modal-title{font-size:16px}.cabinet-btn{padding:8px 16px}}@media(max-width:480px){.cabinet-toast{min-width:auto;width:calc(100vw - 40px)}.cabinet-stats-card{padding:16px}.cabinet-stats-icon{width:40px;height:40px}.cabinet-stats-value{font-size:20px}.cabinet-title h3{font-size:14px}.cabinet-stat-badge{font-size:11px;padding:3px 8px}.cabinet-cell-item{padding:8px 4px}.cabinet-cell-number{font-size:10px}.cabinet-cell-status-badge{font-size:8px;padding:2px 4px}.cabinet-stack-btn{width:36px;height:36px}.cabinet-stack-value{font-size:22px}.cabinet-cells-selection-grid{grid-template-columns:1fr}}@media print{.cabinet-page-actions,.cabinet-filters-bar,.cabinet-action-buttons,.cabinet-actions,.cabinet-toast-container,.cabinet-modal-bg,.cabinet-btn{display:none!important}.cabinet-card{break-inside:avoid;box-shadow:none;border:1px solid #000}.cabinet-cells-grid{grid-template-columns:repeat(5,1fr)}.cabinet-cell-status-badge{border:1px solid #000;background:none!important;color:#000!important}}.profile-page{padding:8px 0}.profile-header-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:var(--radius-lg, 16px);padding:28px 32px;margin-bottom:24px;display:flex;align-items:center;gap:28px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.08))}.profile-avatar-large{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,var(--primary, #2563eb) 0%,#7c3aed 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:38px;font-weight:700;text-transform:uppercase;box-shadow:0 8px 24px #2563eb4d;flex-shrink:0}.profile-title-section{flex:1}.profile-name{font-size:28px;font-weight:700;color:var(--tx1, #0f172a);margin-bottom:10px}.profile-meta{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.profile-staff-id{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--tx2, #475569);background:var(--bg, #f1f5f9);padding:6px 14px;border-radius:30px;width:fit-content;border:1px solid var(--border, #e2e8f0)}.profile-staff-id strong{color:var(--tx1, #0f172a);font-family:monospace;font-size:14px}.profile-content{display:flex;flex-direction:column;gap:24px}.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:8px}.info-item{display:flex;align-items:flex-start;gap:14px;padding:14px;background:var(--bg, #f8fafc);border-radius:var(--radius, 10px);border:1px solid var(--border, #e2e8f0);transition:all .2s}.info-item:hover{background:var(--bg-card, #ffffff);border-color:var(--primary-border, #bfdbfe);box-shadow:var(--shadow-sm, 0 2px 4px rgba(0,0,0,.05))}.info-icon{width:36px;height:36px;border-radius:50%;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);display:flex;align-items:center;justify-content:center;flex-shrink:0}.info-content{flex:1}.info-content label{display:block;font-size:11px;font-weight:600;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.info-content p{font-size:15px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.4;word-break:break-word}.text-muted{color:var(--tx3, #94a3b8);font-style:italic}.staff-id-display{font-family:monospace;font-size:14px;background:var(--bg-card, #ffffff);padding:4px 8px;border-radius:4px;border:1px solid var(--border, #e2e8f0);display:inline-block}.security-actions{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.security-info{display:flex;flex-direction:column;gap:6px}.security-hint,.security-warning{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--tx2, #475569)}.success-icon{color:var(--success, #16a34a)}.warning-icon{color:var(--warning, #d97706)}.password-form{max-width:500px}.form-title{font-size:16px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:20px}.password-input-wrapper{position:relative}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px}.password-toggle:hover{color:var(--primary, #2563eb)}.alert{display:flex;align-items:center;gap:10px;border-radius:var(--radius-sm, 6px);font-size:14px;font-weight:500}.alert-error{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border:1px solid var(--danger-border, #fecaca)}.alert-success{background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border:1px solid var(--success-border, #bbf7d0)}.form-actions{display:flex;gap:12px;margin-top:24px}.permissions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:20px}.permission-item{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg, #f8fafc);border-radius:var(--radius, 10px);border:1px solid var(--border, #e2e8f0);transition:all .15s}.permission-item:hover{background:var(--bg-card, #ffffff);border-color:var(--primary-border, #bfdbfe)}.permission-badge{height:28px;display:flex;flex-shrink:0}.permission-badge.granted{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.permission-badge.denied{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626)}.permission-name{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a)}.permission-status{font-size:12px;font-weight:600;padding:3px 8px;border-radius:20px;background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0)}.permission-status.allowed{color:var(--success, #16a34a);border-color:var(--success-border, #bbf7d0);background:var(--success-light, #dcfce7)}.permission-status.denied{color:var(--danger, #dc2626);border-color:var(--danger-border, #fecaca);background:var(--danger-light, #fee2e2)}.permission-icon{flex-shrink:0}.role-info{margin-top:16px;padding-top:16px;border-top:1px solid var(--border, #e2e8f0)}.role-description{font-size:14px;color:var(--tx2, #475569);line-height:1.6}.role-description strong{color:var(--primary, #2563eb);font-weight:600}@media(max-width:768px){.profile-header-card{flex-direction:column;text-align:center;padding:24px 20px}.profile-meta{justify-content:center}.profile-staff-id{margin:0 auto}.info-grid{grid-template-columns:1fr}.security-actions{flex-direction:column;align-items:stretch}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.permissions-grid{grid-template-columns:1fr}.permission-item{flex-wrap:wrap}}@media(max-width:480px){.profile-name{font-size:24px}.profile-avatar-large{width:70px;height:70px;font-size:30px}.permission-status{margin-left:auto}}.report-grid{display:grid;grid-template-columns:220px minmax(0,1fr);gap:20px;align-items:start;contain:content}.report-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px;gap:14px;flex-wrap:wrap;contain:layout}.report-title-wrapper{flex:1}.report-title{font-size:22px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:10px;line-height:1.3}.report-subtitle{font-size:13px;color:var(--tx3, #94a3b8);margin-top:3px}.report-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.report-card{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:var(--radius, 10px);padding:20px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, .08));transition:background .2s,border-color .2s;contain:content;will-change:transform}.report-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px}.report-card-title{font-size:15px;font-weight:700;color:var(--tx1, #0f172a)}.report-card-subtitle{font-size:12px;color:var(--tx3, #94a3b8);margin-top:2px}.report-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}.report-badge-gray{background:var(--bg, #f1f5f9);color:var(--tx3, #94a3b8);border:1px solid var(--border, #e2e8f0)}.report-badge-green{background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border:1px solid var(--success-border, #bbf7d0)}.report-badge-amber{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border:1px solid var(--warning-border, #fde68a)}.report-badge-blue{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border:1px solid var(--primary-border, #bfdbfe)}.report-count-badge{font-size:11px;font-weight:700;background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border-radius:20px;padding:3px 10px;white-space:nowrap;flex-shrink:0;border:1px solid var(--success-border, #bbf7d0)}.report-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:14px;font-weight:600;padding:10px 18px;border-radius:var(--radius-sm, 6px);border:none;cursor:pointer;transition:all .15s;white-space:nowrap;line-height:1;text-decoration:none;font-family:inherit;background:transparent;position:relative;overflow:hidden}.report-btn:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .3s,height .3s}.report-btn:active:after{width:200px;height:200px}.report-btn-sm{font-size:12px;padding:7px 14px}.report-btn-xs{font-size:11px;padding:5px 9px}.report-btn-primary{background:var(--primary, #2563eb);color:#fff}.report-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.report-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1px solid var(--border, #e2e8f0)}.report-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);transform:translateY(-1px)}.report-btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.report-btn--active-page{background:var(--primary, #2563eb);color:#fff;border-color:transparent}.report-export-wrap{position:relative}.report-export-menu{position:absolute;top:calc(100% + 5px);right:0;background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:var(--radius-md, 8px);box-shadow:0 4px 16px #0000001a;min-width:180px;z-index:200;overflow:hidden;animation:report-menu-in .14s ease}@keyframes report-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.report-export-item{display:flex;align-items:center;gap:9px;width:100%;padding:10px 14px;font-size:13px;color:var(--tx1, #0f172a);background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;transition:background .12s}.report-export-item:hover{background:var(--bg-hover, #f1f5f9)}.report-export-item+.report-export-item{border-top:1px solid var(--border, #e2e8f0)}.report-chevron-open{transform:rotate(180deg);transition:transform .15s}.report-sidebar{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:var(--radius-lg, 12px);padding:12px;position:sticky;top:12px;max-height:calc(100vh - 80px);overflow-y:auto}.report-sidebar-search-wrap{position:relative;margin-bottom:12px}.report-sidebar-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none;z-index:1}.report-sidebar-search-input{width:100%;padding:8px 10px 8px 32px;font-size:13px;background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:var(--radius-sm, 6px);color:var(--tx1, #0f172a);transition:all .15s}.report-sidebar-search-input:focus{outline:none;border-color:var(--primary, #2563eb);box-shadow:0 0 0 2px var(--primary-light, #dbeafe)}.report-group{margin-bottom:8px}.report-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:8px 10px 5px}.report-group-label-blue{color:var(--primary, #2563eb)}.report-group-label-purple{color:#534ab7}.report-group-label-teal{color:#0f6e56}.report-group-label-warning{color:var(--warning, #d97706)}.report-group-label-danger{color:var(--danger, #dc2626)}.report-nav-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;font-size:13px;color:var(--tx2, #475569);background:none;border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;font-family:inherit;text-align:left;transition:all .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.report-nav-item:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}.report-nav-item--active{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);font-weight:600}.report-nav-icon{width:24px;height:24px;border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.report-nav-icon-blue{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.report-nav-icon-danger{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626)}.report-nav-icon-purple{background:#eeedfe;color:#534ab7}.report-nav-icon-teal{background:#e1f5ee;color:#0f6e56}.report-nav-icon-warning{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.report-main{background:var(--bg-card, #ffffff);border:1px solid var(--border, #e2e8f0);border-radius:var(--radius-lg, 12px);padding:20px;min-height:400px}.report-main-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.report-main-title{font-size:16px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:7px;margin-bottom:4px}.report-main-desc{font-size:13px;color:var(--tx3, #94a3b8)}.report-filters{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;padding:16px;background:var(--bg-secondary, #f8fafc);border-radius:var(--radius-md, 8px);margin-bottom:16px;border:1px solid var(--border, #e2e8f0)}.report-filter-field{display:flex;flex-direction:column;gap:4px}.report-filter-label{font-size:12px;font-weight:600;color:var(--tx2, #475569)}.report-input,.report-select{background:var(--bg-card, #ffffff);color:var(--tx1, #0f172a);border:1px solid var(--border, #e2e8f0);border-radius:var(--radius-sm, 6px);padding:8px 12px;font-size:13px;font-family:inherit;min-width:140px;transition:all .15s}.report-input:focus,.report-select:focus{outline:none;border-color:var(--primary, #2563eb);box-shadow:0 0 0 2px var(--primary-light, #dbeafe)}.report-filter-actions{display:flex;gap:8px;align-items:center;align-self:flex-end}.report-table-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:10px}.report-table-header-label{font-size:13px;color:var(--tx3, #94a3b8)}.report-table-wrap{overflow-x:auto;border:1px solid var(--border, #e2e8f0);border-radius:var(--radius-md, 8px)}.report-table{width:100%;border-collapse:collapse;font-size:13px;min-width:600px}.report-th{position:sticky;top:0;background:var(--bg-secondary, #f8fafc);color:var(--tx2, #475569);font-size:12px;font-weight:700;text-align:left;padding:10px 12px;white-space:nowrap;border-bottom:1px solid var(--border, #e2e8f0);z-index:1;text-transform:uppercase;letter-spacing:.3px}.report-tr{transition:background .1s}.report-tr:hover{background:var(--bg-hover, #f1f5f9)}.report-tr:nth-child(2n){background:var(--bg-striped, #fafbfc)}.report-td{padding:10px 12px;color:var(--tx1, #0f172a);border-bottom:1px solid var(--border-light, #edf2f7);white-space:nowrap;max-width:260px;overflow:hidden;text-overflow:ellipsis;vertical-align:middle}.report-tr:last-child .report-td{border-bottom:none}.report-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:60px 20px;font-size:14px;color:var(--tx2, #475569);flex-wrap:wrap;text-align:center}.report-spinner{width:24px;height:24px;border:3px solid var(--primary-light, #dbeafe);border-top-color:var(--primary, #2563eb);border-radius:50%;animation:report-spin .8s linear infinite;will-change:transform}@keyframes report-spin{to{transform:rotate(360deg)}}.report-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:52px 20px;color:var(--tx3, #94a3b8);font-size:14px;text-align:center}.report-empty svg{opacity:.35;width:48px;height:48px;color:var(--tx3, #94a3b8)}.report-empty p{margin:0;max-width:280px}.report-run-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:52px 20px;text-align:center}.report-run-icon{color:var(--tx3, #94a3b8);opacity:.35;font-size:48px}.report-run-prompt p{font-size:14px;color:var(--tx3, #94a3b8);margin:0;max-width:300px}.report-pagination{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:16px;flex-wrap:wrap}.report-page-info{font-size:13px;color:var(--tx3, #94a3b8)}.report-page-btns{display:flex;gap:4px;flex-wrap:wrap}@media(prefers-color-scheme:dark){.report-nav-icon-purple{background:#26215c;color:#afa9ec}.report-nav-icon-teal{background:#04342c;color:#5dcaa5}.report-group-label-purple{color:#afa9ec}.report-group-label-teal{color:#5dcaa5}}@media(max-width:900px){.report-grid{grid-template-columns:1fr}.report-sidebar{position:static;max-height:none;margin-bottom:16px}}@media(max-width:860px){.report-sidebar{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}.report-group-label{grid-column:1 / -1}}@media(max-width:768px){.report-header{flex-direction:column}.report-filters{flex-direction:column;align-items:stretch}.report-input,.report-select{min-width:0;width:100%}.report-filter-actions{width:100%}.report-filter-actions .report-btn{flex:1}.report-main-header{flex-direction:column}.report-pagination{flex-direction:column;align-items:stretch}.report-page-info{text-align:center;order:2}.report-page-btns{order:1;justify-content:center}}@media(max-width:600px){.report-title{font-size:20px}.report-actions{width:100%}.report-actions .report-btn{flex:1}.report-table{font-size:12px;min-width:500px}.report-th,.report-td{padding:8px 10px}}@media(max-width:480px){.report-title{font-size:18px}.report-btn{font-size:13px;padding:8px 12px}.report-sidebar{grid-template-columns:1fr}.report-export-menu{left:0;right:auto;width:100%}}@media(max-width:375px){.report-table{min-width:400px}}@media(max-width:768px){.report-btn,.report-nav-item,.report-export-item,.report-page-btns .report-btn{min-height:44px}}@media(max-height:480px)and (orientation:landscape){.report-sidebar{max-height:none}.report-run-prompt,.report-empty,.report-loading{padding:24px 16px}}@media(prefers-reduced-motion:reduce){.report-spinner,.report-btn:after,.report-export-menu{animation:none!important;transition:none!important}}.report-will-change{will-change:transform,opacity}.report-no-select{-webkit-user-select:none;user-select:none}@media print{.report-sidebar,.report-filters,.report-btn,.report-pagination{display:none!important}.report-main{border:none;padding:0}}.student-mgt{max-width:600px;margin:0 auto;padding:1rem}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header h1{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;margin:0}.stats-badge{background:#f3f4f6;padding:.5rem 1rem;border-radius:2rem;font-size:.875rem}.divider{margin:0 .5rem;color:#d1d5db}.search-panel{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.search-form{display:flex;gap:.5rem}.search-input-wrapper{flex:1;position:relative}.search-input-wrapper svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#9ca3af}.search-input-wrapper input{width:100%;padding:.75rem .75rem .75rem 2.5rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem}.search-input-wrapper input:focus{outline:none;border-color:#3b82f6}.search-form button{padding:0 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-weight:500;cursor:pointer}.search-form button:disabled{opacity:.5;cursor:not-allowed}.student-card{margin-top:1.5rem;padding:1.5rem;background:#f9fafb;border-radius:.75rem;border:1px solid #e5e7eb}.student-info{display:flex;gap:1rem;margin-bottom:1.5rem}.avatar{width:48px;height:48px;background:#3b82f6;color:#fff;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600}.details h3{margin:0 0 .25rem;font-size:1.125rem}.details p{margin:0 0 .5rem;color:#6b7280;font-size:.875rem}.course-badge{display:inline-block;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500}.course-badge.short{background:#fef3c7;color:#92400e}.course-badge.academic{background:#e0f2fe;color:#0369a1}.action button{width:100%;padding:.75rem;border:none;border-radius:.5rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer}.btn-assign{background:#3b82f6;color:#fff}.btn-print{background:#10b981;color:#fff}.pending-note{margin-top:1rem;padding:.75rem;background:#fef3c7;border-radius:.5rem;text-align:center;font-size:.875rem;color:#92400e}@media(max-width:480px){.search-form{flex-direction:column}.search-form button{padding:.75rem}}.qrv3-page{font-family:Plus Jakarta Sans,system-ui,sans-serif;max-width:1200px;margin:0 auto}.qrv3-hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}.qrv3-hdr__left{flex:1}.qrv3-hdr__right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.qrv3-hdr__title{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:800;color:var(--tx1, #0f172a);letter-spacing:-.5px}.qrv3-hdr__icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#6366f1,#4f46e5);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #6366f159;flex-shrink:0}.qrv3-hdr__sub{font-size:13px;color:var(--tx3, #64748b);margin-top:4px;margin-left:48px}.qrv3-logo-status{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--tx3, #94a3b8);background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:20px;padding:4px 10px}.qrv3-logo-status code{font-family:DM Mono,monospace;font-size:10px;color:#6366f1;background:#6366f11a;padding:1px 5px;border-radius:4px}.qrv3-kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.qrv3-kpi{background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:14px;padding:14px 14px 12px 16px;display:flex;align-items:center;gap:12px;position:relative;overflow:hidden;animation:qrv3-kpi-in .4s ease var(--kd, 0ms) both}.qrv3-kpi:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--kc, #6366f1);border-radius:14px 0 0 14px}@keyframes qrv3-kpi-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.qrv3-kpi__icon{width:40px;height:40px;border-radius:11px;background:color-mix(in srgb,var(--kc) 12%,transparent);color:var(--kc, #6366f1);display:flex;align-items:center;justify-content:center;flex-shrink:0}.qrv3-kpi__val{font-size:26px;font-weight:800;line-height:1;color:var(--kc, #6366f1);font-family:DM Mono,monospace;letter-spacing:-1px}.qrv3-kpi__lbl{font-size:11px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}.qrv3-tabs{display:flex;gap:2px;padding:4px;background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:12px;margin-bottom:16px}.qrv3-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 12px;border-radius:8px;border:none;background:transparent;color:var(--tx3, #64748b);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s;font-family:inherit;position:relative}.qrv3-tab:hover:not(.qrv3-tab--active){background:var(--bg-card, #fff);color:var(--tx1, #0f172a)}.qrv3-tab--active{background:var(--bg-card, #fff);color:#6366f1;box-shadow:0 2px 8px #00000014;font-weight:700}.qrv3-tab__badge{min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#6366f1;color:#fff;font-size:10px;font-weight:800;display:inline-flex;align-items:center;justify-content:center}.qrv3-panel{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #0000000a}.qrv3-panel-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;gap:12px;color:var(--tx3, #94a3b8);font-size:14px}.qrv3-wizard{padding:0}.qrv3-steps{display:flex;align-items:center;padding:20px 24px 0}.qrv3-step{display:flex;align-items:center;gap:7px;flex-shrink:0}.qrv3-step__dot{width:26px;height:26px;border-radius:50%;background:var(--bg-input, #f1f5f9);border:2px solid var(--border, #e2e8f0);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--tx3, #94a3b8);transition:all .2s}.qrv3-step--active .qrv3-step__dot{background:#6366f1;border-color:#6366f1;color:#fff}.qrv3-step--done .qrv3-step__dot{background:#16a34a;border-color:#16a34a;color:#fff}.qrv3-step__lbl{font-size:12px;font-weight:600;color:var(--tx3, #94a3b8)}.qrv3-step--active .qrv3-step__lbl{color:#6366f1}.qrv3-step--done .qrv3-step__lbl{color:#16a34a}.qrv3-step__line{flex:1;height:2px;background:var(--border, #e2e8f0);margin:0 8px;border-radius:2px}.qrv3-step__line--done{background:#16a34a}.qrv3-wizard-step{padding:24px}.qrv3-wizard-step__hdr{margin-bottom:20px}.qrv3-wizard-step__hdr h2{font-size:17px;font-weight:800;color:var(--tx1, #0f172a);margin-bottom:4px}.qrv3-wizard-step__hdr p{font-size:13px;color:var(--tx3, #64748b)}.qrv3-wizard-foot{display:flex;justify-content:flex-end;gap:8px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border, #e2e8f0)}.qrv3-purpose-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:4px}.qrv3-purpose-card{padding:16px;border-radius:12px;border:2px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);cursor:pointer;transition:all .18s;text-align:left;position:relative;font-family:inherit}.qrv3-purpose-card:hover{border-color:#6366f1;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.qrv3-purpose-card--active{border-width:2px}.qrv3-purpose-card__icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}.qrv3-purpose-card__label{font-size:14px;font-weight:700;color:var(--tx1, #0f172a);margin-bottom:4px}.qrv3-purpose-card__desc{font-size:12px;color:var(--tx3, #64748b);line-height:1.4}.qrv3-purpose-card__check{position:absolute;top:10px;right:10px;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.qrv3-qty-layout{display:grid;grid-template-columns:1fr 200px;gap:24px;align-items:start}.qrv3-qty-row{display:flex;align-items:center;gap:8px;margin-bottom:14px}.qrv3-qty-btn{width:38px;height:38px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.qrv3-qty-btn:hover{background:var(--bg-input, #f1f5f9);border-color:#6366f1;color:#6366f1}.qrv3-qty-input{flex:1;text-align:center;font-size:22px;font-weight:800;font-family:DM Mono,monospace;width:100px}.qrv3-qty-presets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}.qrv3-preset{padding:5px 12px;border-radius:20px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.qrv3-preset:hover{border-color:#6366f1;color:#6366f1}.qrv3-preset--active{background:#6366f1;color:#fff;border-color:#6366f1}.qrv3-qty-summary{display:flex;gap:0;background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:10px;overflow:hidden;margin-bottom:18px}.qrv3-qty-summary__item{flex:1;padding:12px 14px;text-align:center;border-right:1px solid var(--border, #e2e8f0)}.qrv3-qty-summary__item:last-child{border-right:none}.qrv3-qty-summary__val{display:block;font-size:20px;font-weight:800;color:#6366f1;font-family:DM Mono,monospace}.qrv3-qty-summary__lbl{font-size:10px;font-weight:600;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.4px;margin-top:3px}.qrv3-qty-preview{background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:14px;text-align:center}.qrv3-qty-preview__label{display:flex;align-items:center;justify-content:center;gap:4px;font-size:10px;font-weight:700;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px}.qrv3-qty-preview__qr{display:flex;justify-content:center;margin-bottom:10px}.qrv3-qty-preview__purpose{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;margin-bottom:8px}.qrv3-qty-preview__note{font-size:10px;color:var(--tx3, #94a3b8);line-height:1.5;margin:0;text-align:center}.qrv3-qr-cell{background:#fff;border:1px solid var(--border, #e2e8f0);border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;width:120px;height:120px}.qrv3-qr-cell img{width:100%;height:100%;object-fit:contain;display:block}.qrv3-qr-cell--loading{background:var(--bg-input, #f8fafc)}.qrv3-gen-loading{text-align:center;padding:40px 20px}.qrv3-gen-loading__ring{width:72px;height:72px;border-radius:50%;background:#6366f11a;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;animation:qrv3-gen-pulse 2s ease-in-out infinite}@keyframes qrv3-gen-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.qrv3-gen-loading h2{font-size:18px;font-weight:800;color:var(--tx1, #0f172a);margin-bottom:6px}.qrv3-gen-loading p{font-size:13px;color:var(--tx3, #64748b);margin-bottom:20px}.qrv3-progress-bar{height:5px;background:var(--border, #e2e8f0);border-radius:3px;overflow:hidden;max-width:280px;margin:0 auto}.qrv3-progress-bar__fill{height:100%;background:linear-gradient(90deg,#6366f1,#4f46e5);border-radius:3px;animation:qrv3-progress 2s ease-in-out infinite}@keyframes qrv3-progress{0%{width:30%}50%{width:80%}to{width:30%}}.qrv3-gen-error{display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 20px;gap:10px}.qrv3-gen-error h2{font-size:16px;font-weight:700;color:#0f172a}.qrv3-gen-error p{font-size:13px;color:#64748b}.qrv3-gen-success{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 20px 16px;gap:6px}.qrv3-gen-success__icon{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a;display:flex;align-items:center;justify-content:center;margin-bottom:4px;animation:qrv3-bounce .4s cubic-bezier(.4,0,.2,1)}@keyframes qrv3-bounce{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.qrv3-gen-success h2{font-size:18px;font-weight:800;color:#0f172a}.qrv3-gen-success p{font-size:13px;color:#475569}.qrv3-gen-success code{font-family:DM Mono,monospace;background:#f1f5f9;padding:2px 7px;border-radius:5px}.qrv3-gen-result{margin:16px 24px;background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:10px;overflow:hidden}.qrv3-gen-result__grid{display:flex;flex-direction:column}.qrv3-gen-result__row{display:flex;align-items:center;gap:12px;padding:9px 14px;border-bottom:1px solid var(--border, #f1f5f9)}.qrv3-gen-result__row:last-child{border-bottom:none}.qrv3-gen-result__row:nth-child(odd){background:var(--bg-card, #fff)}.qrv3-gen-result__k{font-size:11px;font-weight:700;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.4px;min-width:90px}.qrv3-gen-result__v{font-size:12px;font-weight:600;color:var(--tx1, #0f172a)}.qrv3-gen-actions{display:flex;justify-content:center;gap:8px;padding:0 24px 24px;flex-wrap:wrap}.qrv3-history{display:flex;flex-direction:column}.qrv3-history-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:14px 16px;border-bottom:1px solid var(--border, #e2e8f0);background:var(--bg-input, #f8fafc)}.qrv3-search-box{position:relative;flex:1;min-width:200px;max-width:320px}.qrv3-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.qrv3-search-input{width:100%;padding:8px 32px 8px 34px;background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13px;outline:none;transition:all .2s;font-family:inherit}.qrv3-search-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.qrv3-search-input::placeholder{color:var(--tx3, #94a3b8)}.qrv3-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--tx3);cursor:pointer;display:flex;padding:2px;border-radius:4px;transition:all .15s}.qrv3-search-clear:hover{color:#dc2626;background:#fee2e2}.qrv3-filter-chips{display:flex;gap:4px;flex-wrap:wrap}.qrv3-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:20px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.qrv3-chip:hover{border-color:#6366f1;color:#6366f1}.qrv3-chip--active{background:#6366f1;color:#fff;border-color:#6366f1}.qrv3-chip__count{background:#ffffff40;border-radius:10px;padding:0 5px;font-size:10px}.qrv3-chip--active .qrv3-chip__count{background:#ffffff4d}.qrv3-table-wrap{overflow-x:auto}.qrv3-table{width:100%;border-collapse:separate;border-spacing:0}.qrv3-table thead tr{background:linear-gradient(to bottom,#f8fafc,#f1f5f9)}.qrv3-table th{padding:11px 14px;font-size:11px;font-weight:700;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:2px solid var(--border, #e2e8f0);white-space:nowrap}.qrv3-table td{padding:11px 14px;font-size:13px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle}.qrv3-tr{animation:qrv3-row-in .18s ease both}.qrv3-tr:hover td{background:#fafbff}.qrv3-table tr:last-child td{border-bottom:none}@keyframes qrv3-row-in{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}.qrv3-batch-code{font-size:11px;color:var(--tx1, #0f172a)}.qrv3-date{font-size:12px;color:var(--tx3, #94a3b8)}.qrv3-mono{font-family:DM Mono,monospace}.qrv3-row-acts{display:flex;align-items:center;gap:4px;justify-content:flex-end}.qrv3-act{width:28px;height:28px;border-radius:7px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.qrv3-act:hover{background:#eff6ff;color:#6366f1;border-color:#6366f1;transform:translateY(-1px)}.qrv3-act--danger:hover{background:#fee2e2;color:#dc2626;border-color:#fecaca}.qrv3-table-foot{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border, #e2e8f0);background:var(--bg-input, #fafbfc);flex-wrap:wrap;gap:8px}.qrv3-table-info{font-size:12px;color:var(--tx3, #94a3b8)}.qrv3-pager{display:flex;gap:3px;align-items:center}.qrv3-pager__btn{width:30px;height:30px;border-radius:7px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit}.qrv3-pager__btn:hover:not(:disabled){background:var(--bg-input, #f1f5f9);border-color:#6366f1;color:#6366f1}.qrv3-pager__btn--active{background:#6366f1!important;color:#fff!important;border-color:#6366f1!important}.qrv3-pager__btn--dots{border-color:transparent;background:none;color:var(--tx3, #94a3b8);cursor:default}.qrv3-pager__btn:disabled{opacity:.4;cursor:not-allowed}.qrv3-print-wrap{font-family:Plus Jakarta Sans,system-ui,sans-serif;background:var(--bg, #f1f5f9);min-height:100vh;padding:20px}.qrv3-print-hdr{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}.qrv3-print-hdr__left{display:flex;align-items:center;gap:12px}.qrv3-print-hdr__right{display:flex;gap:8px}.qrv3-print-title{font-size:16px;font-weight:800;color:var(--tx1, #0f172a);font-family:DM Mono,monospace}.qrv3-print-sub{font-size:12px;color:var(--tx3, #64748b);margin-top:2px}.qrv3-print-info{display:flex;align-items:flex-start;gap:8px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:9px;padding:10px 13px;font-size:12px;color:#1d4ed8;margin-bottom:14px;line-height:1.55}.qrv3-print-nav{display:flex;align-items:center;gap:12px;margin-bottom:14px}.qrv3-print-page-label{font-size:13px;color:var(--tx2, #475569);font-weight:600}.qrv3-print-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:20px;box-shadow:0 2px 12px #0000000a}.qrv3-print-loading{display:flex;flex-direction:column;align-items:center;padding:48px;gap:12px;color:var(--tx3, #94a3b8);font-size:14px}.qrv3-print-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:3px}.qrv3-print-grid .qrv3-qr-cell{width:100%;height:auto;aspect-ratio:1}.qrv3-purposes{padding:20px}.qrv3-purposes-layout{display:grid;grid-template-columns:380px 1fr;gap:20px;align-items:start}.qrv3-purposes__form{background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:18px}.qrv3-purposes__form-title{font-size:14px;font-weight:800;color:var(--tx1, #0f172a);margin-bottom:14px}.qrv3-purposes__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.qrv3-purposes__list-title{font-size:14px;font-weight:800;color:var(--tx1, #0f172a);margin-bottom:12px}.qrv3-purpose-row{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);margin-bottom:6px;transition:all .15s}.qrv3-purpose-row:hover{background:var(--bg-input, #f8fafc)}.qrv3-purpose-row--inactive{opacity:.55}.qrv3-purpose-row__icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.qrv3-purpose-row__label{font-size:13px;font-weight:700;color:var(--tx1, #0f172a)}.qrv3-purpose-row__code{font-size:11px;color:var(--tx3, #94a3b8);margin-top:2px}.qrv3-purpose-row__acts{display:flex;gap:4px;margin-left:auto}.qrv3-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap}.qrv3-badge svg{width:10px;height:10px}.qrv3-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:qrv3-bg-in .2s ease;font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes qrv3-bg-in{0%{opacity:0}to{opacity:1}}.qrv3-modal{background:var(--bg-card, #fff);border-radius:18px;max-width:440px;width:100%;padding:28px;text-align:center;box-shadow:0 32px 64px -20px #00000059;animation:qrv3-modal-in .22s cubic-bezier(.4,0,.2,1)}@keyframes qrv3-modal-in{0%{opacity:0;transform:scale(.96) translateY(6px)}to{opacity:1;transform:none}}.qrv3-modal__icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.qrv3-modal__icon--danger{background:#fee2e2;color:#dc2626}.qrv3-modal__title{font-size:16px;font-weight:800;color:var(--tx1, #0f172a);margin-bottom:8px}.qrv3-modal__body{font-size:13px;color:var(--tx2, #475569);line-height:1.6;margin-bottom:18px}.qrv3-modal__foot{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.qrv3-field-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.qrv3-field-label{font-size:12px;font-weight:700;color:var(--tx2, #475569)}.qrv3-opt{font-size:10px;font-weight:500;color:var(--tx3, #94a3b8);background:var(--bg-input, #f1f5f9);padding:1px 6px;border-radius:6px;margin-left:4px}.qrv3-text-input{padding:9px 12px;background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13px;outline:none;transition:all .2s;font-family:inherit}.qrv3-text-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.qrv3-text-input:disabled{opacity:.5;background:var(--bg-input, #f8fafc)}.qrv3-text-input::placeholder{color:var(--tx3, #94a3b8)}.qrv3-field-err{font-size:12px;color:#dc2626;background:#fee2e2;border:1px solid #fecaca;border-radius:7px;padding:8px 11px;margin-bottom:12px}.qrv3-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:9px;border:1.5px solid transparent;font-size:13px;font-weight:700;cursor:pointer;transition:all .17s;font-family:Plus Jakarta Sans,system-ui,sans-serif;white-space:nowrap}.qrv3-btn--sm{font-size:12px;padding:6px 12px}.qrv3-btn--primary{background:#6366f1;color:#fff;border-color:#6366f1}.qrv3-btn--primary:hover:not(:disabled){background:#4f46e5;transform:translateY(-1px);box-shadow:0 4px 12px #6366f159}.qrv3-btn--outline{background:transparent;color:var(--tx2, #475569);border-color:var(--border, #e2e8f0)}.qrv3-btn--outline:hover:not(:disabled){border-color:#6366f1;color:#6366f1}.qrv3-btn--ghost{background:var(--bg-card, #fff);color:var(--tx2, #475569);border-color:var(--border, #e2e8f0)}.qrv3-btn--ghost:hover:not(:disabled){background:var(--bg-input, #f8fafc);border-color:#cbd5e1}.qrv3-btn--danger{background:#dc2626;color:#fff;border-color:#dc2626}.qrv3-btn--danger:hover:not(:disabled){background:#b91c1c}.qrv3-btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.qrv3-spinner{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(99,102,241,.15);border-top-color:#6366f1;border-radius:50%;animation:qrv3-spin .6s linear infinite}.qrv3-spinner-xs{display:inline-block;width:11px;height:11px;border:2px solid rgba(0,0,0,.1);border-top-color:#6366f1;border-radius:50%;animation:qrv3-spin .6s linear infinite}@keyframes qrv3-spin{to{transform:rotate(360deg)}}.qrv3-spin{animation:qrv3-spin 1s linear infinite}.qrv3-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 24px;color:var(--tx3, #94a3b8)}.qrv3-empty h3{font-size:15px;font-weight:700;color:var(--tx1, #0f172a);margin:12px 0 6px}.qrv3-empty p{font-size:13px;color:var(--tx3, #64748b);margin:0}.qrv3-error-bar{display:flex;align-items:center;gap:8px;background:#fff5f5;border:1px solid #fecaca;border-radius:9px;padding:10px 14px;color:#dc2626;font-size:13px;font-weight:500;margin-bottom:14px}.qrv3-error-bar span{flex:1}.qrv3-skel{display:inline-block;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;border-radius:5px;animation:qrv3-shimmer 1.4s linear infinite}@keyframes qrv3-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:1024px){.qrv3-kpi-strip{grid-template-columns:repeat(2,1fr)}.qrv3-purposes-layout{grid-template-columns:1fr}}@media(max-width:768px){.qrv3-kpi-strip{grid-template-columns:repeat(2,1fr)}.qrv3-purpose-grid{grid-template-columns:1fr 1fr}.qrv3-qty-layout{grid-template-columns:1fr}.qrv3-qty-preview{display:none}.qrv3-hdr{flex-direction:column}.qrv3-print-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:480px){.qrv3-kpi-strip{grid-template-columns:1fr 1fr}.qrv3-purpose-grid{grid-template-columns:1fr}.qrv3-print-grid{grid-template-columns:repeat(3,1fr)}}@media print{.qrv3-print-hdr,.qrv3-print-nav,.qrv3-print-info{display:none!important}.qrv3-print-wrap{padding:0;background:#fff}.qrv3-print-card{box-shadow:none;border:none;border-radius:0;padding:10px}.qrv3-print-grid{grid-template-columns:repeat(8,1fr);gap:2px}}.qrv3-kpi__body,.qrv3-purpose-row__body{flex:1;min-width:0}.qrv3-purposes__list,.qrv3-qty-controls{display:flex;flex-direction:column}.qrv3-qty-preview__meta{display:flex;flex-direction:column;align-items:center;gap:6px}:root{--qra-primary: #2563eb;--qra-primary-light: #dbeafe;--qra-primary-dark: #1d4ed8;--qra-success: #16a34a;--qra-success-light: #dcfce7;--qra-warning: #d97706;--qra-warning-light: #fef3c7;--qra-danger: #dc2626;--qra-danger-light: #fee2e2;--qra-amber: #d97706;--qra-usb: #0891b2;--qra-usb-light: #e0f2fe;--qra-usb-border: #bae6fd;--qra-surface-0: #ffffff;--qra-surface-1: #f8fafc;--qra-surface-2: #f1f5f9;--qra-border: #e2e8f0;--qra-border-strong: #cbd5e1;--qra-ink-1: #0f172a;--qra-ink-2: #1e293b;--qra-ink-3: #475569;--qra-ink-4: #94a3b8;--qra-cam-bg: #0f172a;--qra-cam-border: #1e293b;--qra-radius-sm: 8px;--qra-radius: 12px;--qra-radius-lg: 16px;--qra-radius-xl: 20px;--qra-shadow-sm: 0 1px 4px rgba(0, 0, 0, .06);--qra-shadow: 0 4px 16px rgba(0, 0, 0, .08);--qra-shadow-lg: 0 12px 40px rgba(0, 0, 0, .14);--qra-shadow-xl: 0 24px 64px rgba(0, 0, 0, .22)}.qra-page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}.qra-page-header__left{flex:1}.qra-page-header__right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.qra-page-title{display:flex;align-items:center;gap:10px;font-size:22px;font-weight:800;color:var(--qra-ink-1);letter-spacing:-.4px}.qra-title-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--qra-primary),var(--qra-primary-dark));display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #2563eb47;flex-shrink:0}.qra-page-sub{font-size:13px;color:var(--qra-ink-4);margin-top:4px;margin-left:48px}.qra-header-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;border-radius:var(--qra-radius-sm);border:1.5px solid var(--qra-border);background:var(--qra-surface-0);color:var(--qra-ink-3);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s;white-space:nowrap;font-family:inherit;text-decoration:none}.qra-header-btn:hover{border-color:var(--qra-primary);color:var(--qra-primary);background:var(--qra-primary-light)}.qra-sound-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 13px;border-radius:var(--qra-radius-sm);border:1.5px solid var(--qra-border);font-size:12px;font-weight:600;cursor:pointer;transition:all .18s;white-space:nowrap;font-family:inherit}.qra-sound-btn--on{background:var(--qra-primary-light);color:var(--qra-primary);border-color:#bfdbfe}.qra-sound-btn--off{background:var(--qra-surface-1);color:var(--qra-ink-4)}.qra-layout{display:grid;grid-template-columns:1fr 320px;gap:20px;align-items:start}.qra-layout__main{display:flex;flex-direction:column;gap:16px;min-width:0}.qra-layout__side{display:flex;flex-direction:column;gap:16px}.qra-flow-card{background:var(--qra-surface-0);border:1px solid var(--qra-border);border-radius:var(--qra-radius-lg);padding:20px;box-shadow:var(--qra-shadow);display:flex;flex-direction:column;gap:14px}.qra-flow-card--search{border-left:4px solid var(--qra-primary)}.qra-flow-card--scan{border-left:4px solid var(--qra-usb)}.qra-flow-card--confirm{border-left:4px solid var(--qra-success)}.qra-flow-card--success{border-left:4px solid var(--qra-success);text-align:center}.qra-flow-header{display:flex;align-items:center;gap:8px}.qra-flow-step{font-size:11px;font-weight:600;color:var(--qra-ink-4);margin-left:auto}.qra-flow-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;white-space:nowrap}.qra-flow-badge--search{background:#eff6ff;color:var(--qra-primary)}.qra-flow-badge--scan{background:var(--qra-usb-light);color:var(--qra-usb)}.qra-flow-badge--confirm{background:var(--qra-success-light);color:var(--qra-success)}.qra-search-container{width:100%}.qra-search-wrapper{display:flex;align-items:center;gap:8px;background:var(--qra-surface-1);border:1.5px solid var(--qra-border);border-radius:var(--qra-radius);padding:4px 4px 4px 12px;transition:border-color .2s,box-shadow .2s}.qra-search-wrapper:focus-within{border-color:var(--qra-primary);box-shadow:0 0 0 3px #2563eb1a}.qra-search-icon{color:var(--qra-ink-4)}.qra-search-input{flex:1;border:none;background:transparent;padding:10px 0;font-size:14px;color:var(--qra-ink-1);outline:none;font-family:inherit}.qra-search-input::placeholder{color:var(--qra-ink-4)}.qra-student-section{display:flex;flex-direction:column;gap:10px}.qra-person{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--qra-surface-1);border:1px solid var(--qra-border);border-radius:var(--qra-radius)}.qra-person--compact{padding:8px 12px}.qra-person__avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#dbeafe;color:var(--qra-primary);overflow:hidden}.qra-person__avatar img{width:100%;height:100%;object-fit:cover}.qra-person--compact .qra-person__avatar{width:36px;height:36px}.qra-person__info{flex:1;min-width:0}.qra-person__name{font-size:15px;font-weight:700;color:var(--qra-ink-1)}.qra-person--compact .qra-person__name{font-size:13px}.qra-person__sub{font-size:11px;color:var(--qra-ink-4);margin-top:2px}.qra-person__type{font-size:10px;font-weight:700;padding:3px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.4px}.qra-person__type--assigned{background:var(--qra-success-light);color:var(--qra-success)}.qra-person__type--pending{background:#fef3c7;color:var(--qra-warning)}.qra-details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}.qra-detail-item{font-size:12px;padding:6px 8px;background:var(--qra-surface-1);border-radius:var(--qra-radius-sm)}.qra-detail-label{font-weight:600;color:var(--qra-ink-4);margin-right:6px}.qra-detail-value{color:var(--qra-ink-2)}.qra-existing-qr{margin-top:8px;padding:12px;background:var(--qra-surface-1);border:1px solid var(--qra-border);border-radius:var(--qra-radius)}.qra-existing-qr__header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--qra-ink-2);margin-bottom:8px}.qra-existing-qr__preview{display:flex;align-items:center;gap:12px;padding:8px;background:var(--qra-surface-0);border-radius:var(--qra-radius-sm);margin-bottom:8px}.qra-existing-qr__preview img{width:60px;height:60px}.qra-existing-qr__details{display:flex;gap:16px;font-size:11px}.qra-existing-qr__row{display:flex;gap:4px}.qra-existing-qr__label{color:var(--qra-ink-4)}.qra-existing-qr__value{font-weight:500;color:var(--qra-ink-2)}.qra-usb-section{background:var(--qra-usb-light);border:1.5px solid var(--qra-usb-border);border-radius:var(--qra-radius);padding:14px 16px;display:flex;flex-direction:column;gap:10px}.qra-usb-section__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.qra-usb-badge{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--qra-usb)}.qra-usb-default-pill{display:inline-flex;align-items:center;padding:2px 8px;background:var(--qra-usb);color:#fff;border-radius:10px;font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}.qra-usb-hint{font-size:11px;color:#0e7490}.qra-usb-input-row{display:flex;gap:8px;align-items:center}.qra-usb-input-wrap{flex:1;display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--qra-usb-border);border-radius:var(--qra-radius-sm);padding:4px 10px;transition:border-color .2s,box-shadow .2s}.qra-usb-input-wrap:focus-within{border-color:var(--qra-usb);box-shadow:0 0 0 3px #0891b21f}.qra-usb-input-wrap--loading{border-color:var(--qra-warning);background:var(--qra-warning-light)}.qra-usb-icon{color:var(--qra-usb);flex-shrink:0}.qra-usb-input{flex:1;border:none;background:transparent;padding:9px 0;font-size:14px;font-family:monospace;color:var(--qra-ink-1);outline:none;letter-spacing:.5px}.qra-usb-input::placeholder{color:var(--qra-ink-4);font-family:inherit;letter-spacing:0;font-size:13px}.qra-usb-input:disabled{opacity:.55;cursor:not-allowed}.qra-usb-spinner{flex-shrink:0}.qra-usb-status{display:flex;align-items:center;gap:7px;font-size:11px;color:#0e7490;font-weight:500}.qra-usb-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;transition:background .3s}.qra-usb-dot--ready{background:var(--qra-usb);animation:qra-pulse-dot 2s infinite}.qra-usb-dot--loading{background:var(--qra-warning);animation:qra-pulse-dot .7s infinite}.qra-scan-divider{display:flex;align-items:center;gap:12px}.qra-scan-divider__line{flex:1;height:1px;background:var(--qra-border)}.qra-cam-opt-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:20px;border:1.5px solid var(--qra-border);background:var(--qra-surface-0);color:var(--qra-ink-3);font-size:12px;font-weight:700;cursor:pointer;transition:all .18s;white-space:nowrap;font-family:inherit}.qra-cam-opt-btn:hover:not(:disabled){border-color:var(--qra-primary);background:var(--qra-primary-light);color:var(--qra-primary)}.qra-cam-opt-btn--active{border-color:var(--qra-danger);background:#fff1f2;color:var(--qra-danger)}.qra-cam-opt-btn--active:hover:not(:disabled){background:var(--qra-danger-light)}.qra-cam-opt-btn:disabled{opacity:.45;cursor:not-allowed}.qra-camera-panel{background:var(--qra-cam-bg);border-radius:var(--qra-radius);overflow:hidden;border:1px solid var(--qra-cam-border);box-shadow:var(--qra-shadow-lg);animation:qra-cam-expand .22s ease}@keyframes qra-cam-expand{0%{opacity:0;transform:translateY(-8px) scaleY(.96)}to{opacity:1;transform:translateY(0) scaleY(1)}}.qra-camera-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.06);flex-wrap:wrap}.qra-camera-toolbar__label{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:#ffffff8c}.qra-camera-toolbar__right{display:flex;align-items:center;gap:8px}.qra-cam-select{padding:7px 10px;border-radius:var(--qra-radius-sm);border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#e2e8f0;font-size:12px;font-family:inherit;outline:none;cursor:pointer}.qra-cam-select:focus{border-color:var(--qra-primary)}.qra-cam-toggle{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border-radius:var(--qra-radius-sm);border:none;font-size:12px;font-weight:700;cursor:pointer;transition:all .18s;font-family:inherit;white-space:nowrap}.qra-cam-toggle--stop{background:#dc262633;color:#fca5a5;border:1px solid rgba(220,38,38,.3)}.qra-cam-toggle--stop:hover{background:#dc26264d}.qra-cam-toggle--torch{background:#ffffff1a;color:#ffffffa6;border:1px solid rgba(255,255,255,.12)}.qra-cam-toggle--torch:hover{background:#fff3}.qra-cam-toggle--torch-on{background:#facc1533;color:#fde047;border-color:#facc154d}.qra-cam-viewport{position:relative;background:#000;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:min-height .3s ease}.qra-cam-viewport--active{min-height:260px}.qra-cam-viewport #qra-cam-reader,.qra-cam-viewport>div>div{width:100%!important}.qra-cam-starting{display:flex;flex-direction:column;align-items:center;gap:12px;color:#ffffff80;padding:50px 20px;min-height:200px;justify-content:center}.qra-cam-err-overlay{display:flex;flex-direction:column;align-items:center;gap:12px;color:#fca5a5;padding:40px 20px;text-align:center}.qra-cam-err-overlay p{font-size:13px;margin:0}.qra-cam-overlay{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.qra-cam-overlay--idle{background:#0f172ab3;color:#fff9}.qra-cam-overlay--info{background:#2563ebcc;color:#fff}.qra-cam-overlay--warning{background:#d97706d9;color:#fff}.qra-cam-overlay--success{background:#16a34ad9;color:#fff}.qra-cam-corners{position:absolute;inset:20px;pointer-events:none}.qra-cam-corners span{position:absolute;width:22px;height:22px;border-color:#fff6;border-style:solid}.qra-cam-corners span:nth-child(1){top:0;left:0;border-width:2px 0 0 2px}.qra-cam-corners span:nth-child(2){top:0;right:0;border-width:2px 2px 0 0}.qra-cam-corners span:nth-child(3){bottom:0;left:0;border-width:0 0 2px 2px}.qra-cam-corners span:nth-child(4){bottom:0;right:0;border-width:0 2px 2px 0}.qra-alert-card{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:var(--qra-radius);border:1.5px solid transparent;animation:qra-slide-in .2s ease}.qra-alert-card--error{background:var(--qra-danger-light);border-color:#fecaca}.qra-alert-card--warning{background:var(--qra-warning-light);border-color:#fde68a}.qra-alert-card--success{background:var(--qra-success-light);border-color:#bbf7d0}.qra-alert-card--info{background:var(--qra-primary-light);border-color:#bfdbfe}.qra-alert-card__icon{flex-shrink:0;margin-top:2px}.qra-alert-card--error .qra-alert-card__icon{color:var(--qra-danger)}.qra-alert-card--warning .qra-alert-card__icon{color:var(--qra-warning)}.qra-alert-card--success .qra-alert-card__icon{color:var(--qra-success)}.qra-alert-card--info .qra-alert-card__icon{color:var(--qra-primary)}.qra-alert-card__body{flex:1}.qra-alert-card__title{font-size:13px;font-weight:700;color:var(--qra-ink-1)}.qra-alert-card__desc{font-size:12px;color:var(--qra-ink-3);margin-top:2px;line-height:1.5}.qra-qr-preview{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:var(--qra-surface-1);border-radius:var(--qra-radius)}.qra-qr-preview img{width:140px;height:140px}.qra-selected-qr{padding:12px;background:var(--qra-surface-1);border-radius:var(--qra-radius)}.qra-selected-qr__header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--qra-ink-2);margin-bottom:8px}.qra-selected-qr__meta{display:flex;gap:12px;font-size:11px;color:var(--qra-ink-4)}.qra-form-group{display:flex;flex-direction:column;gap:6px}.qra-form-group label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--qra-ink-3)}.qra-input{padding:9px 12px;border:1.5px solid var(--qra-border);border-radius:var(--qra-radius-sm);font-size:13px;color:var(--qra-ink-1);background:var(--qra-surface-0);outline:none;font-family:inherit;width:100%;transition:border-color .2s}.qra-input:focus{border-color:var(--qra-primary);box-shadow:0 0 0 3px #2563eb1a}.qra-success-icon{display:flex;justify-content:center;margin:12px 0;color:var(--qra-success)}.qra-success-title{font-size:18px;font-weight:800;color:var(--qra-ink-1);margin:0}.qra-success-message{font-size:13px;color:var(--qra-ink-3);margin:4px 0 0}.qra-success-qr{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:var(--qra-surface-1);border-radius:var(--qra-radius);margin:8px 0}.qra-success-qr img{width:120px;height:120px}.qra-side-card{background:var(--qra-surface-0);border:1px solid var(--qra-border);border-radius:var(--qra-radius-lg);padding:16px;box-shadow:var(--qra-shadow-sm);display:flex;flex-direction:column;gap:12px}.qra-side-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.qra-side-card__title{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:700;color:var(--qra-ink-1)}.qra-side-card__sub{font-size:11px;color:var(--qra-ink-4)}.qra-view-link{font-size:11px;color:var(--qra-primary);text-decoration:none;font-weight:600}.qra-view-link:hover{text-decoration:underline}.qra-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.qra-stat-item{text-align:center;padding:10px;background:var(--qra-surface-1);border-radius:var(--qra-radius-sm)}.qra-stat-label{font-size:11px;color:var(--qra-ink-4);font-weight:500;margin-bottom:4px}.qra-stat-value{font-size:22px;font-weight:800;color:var(--qra-ink-1)}.qra-batch-list{display:flex;flex-direction:column;gap:6px}.qra-batch-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--qra-surface-1);border-radius:var(--qra-radius-sm)}.qra-batch-code{font-size:12px;font-weight:700;color:var(--qra-ink-2)}.qra-batch-purpose{font-size:11px;color:var(--qra-ink-4)}.qra-batch-stats{display:flex;align-items:baseline;gap:1px}.qra-batch-available{font-size:14px;font-weight:800;color:var(--qra-primary)}.qra-batch-total{font-size:11px;color:var(--qra-ink-4)}.qra-recent-list{display:flex;flex-direction:column;gap:4px}.qra-recent-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--qra-radius-sm);text-decoration:none;transition:background .15s;border:1px solid transparent}.qra-recent-item:hover{background:var(--qra-surface-1);border-color:var(--qra-border)}.qra-recent-avatar{width:30px;height:30px;border-radius:50%;background:var(--qra-primary-light);color:var(--qra-primary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.qra-recent-info{flex:1;min-width:0}.qra-recent-name{font-size:12px;font-weight:700;color:var(--qra-ink-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qra-recent-reg{font-size:11px;color:var(--qra-ink-4)}.qra-recent-badge{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--qra-ink-4);white-space:nowrap}.qra-empty-sessions{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;color:var(--qra-ink-4);font-size:13px}.qra-quick-divider{display:flex;align-items:center;gap:10px}.qra-quick-divider span{font-size:11px;color:var(--qra-ink-4);font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.qra-quick-divider:before,.qra-quick-divider:after{content:"";flex:1;height:1px;background:var(--qra-border)}.qra-quick-actions{display:flex;flex-direction:column;gap:4px}.qra-quick-action{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--qra-radius-sm);text-decoration:none;border:1px solid var(--qra-border);background:var(--qra-surface-0);transition:all .15s;color:var(--qra-ink-2)}.qra-quick-action:hover{border-color:var(--qra-primary);background:var(--qra-primary-light)}.qra-quick-action svg{color:var(--qra-primary);flex-shrink:0}.qra-quick-action-title{font-size:13px;font-weight:700;color:var(--qra-ink-1)}.qra-quick-action-desc{font-size:11px;color:var(--qra-ink-4)}.qra-quick-action>svg:last-child{margin-left:auto;color:var(--qra-ink-4)}.qra-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:var(--qra-radius-sm);border:1.5px solid transparent;font-size:13px;font-weight:700;cursor:pointer;transition:all .18s;font-family:inherit;white-space:nowrap;text-decoration:none}.qra-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.qra-btn--sm{font-size:12px;padding:6px 13px}.qra-btn--xs{font-size:11px;padding:4px 9px}.qra-btn--grow{flex:1}.qra-btn--full{width:100%;justify-content:center}.qra-btn--primary{background:var(--qra-primary);color:#fff;border-color:var(--qra-primary)}.qra-btn--primary:hover:not(:disabled){background:var(--qra-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.qra-btn--success{background:var(--qra-success);color:#fff;border-color:var(--qra-success)}.qra-btn--success:hover:not(:disabled){background:#15803d;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}.qra-btn--danger{background:var(--qra-danger);color:#fff;border-color:var(--qra-danger)}.qra-btn--danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.qra-btn--ghost{background:var(--qra-surface-0);color:var(--qra-ink-3);border-color:var(--qra-border)}.qra-btn--ghost:hover:not(:disabled){background:var(--qra-surface-1)}.qra-icon-btn{width:30px;height:30px;border-radius:8px;border:1.5px solid var(--qra-border);background:var(--qra-surface-1);color:var(--qra-ink-3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.qra-icon-btn:hover{background:var(--qra-surface-2);color:var(--qra-ink-1)}.qra-icon-btn--sm{width:26px;height:26px}.qra-action-row{display:flex;gap:10px;flex-wrap:wrap}.qra-spinner{width:28px;height:28px;border:3px solid rgba(37,99,235,.15);border-top-color:var(--qra-primary);border-radius:50%;animation:qra-spin .6s linear infinite;flex-shrink:0}.qra-spinner-xs{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:currentColor;border-radius:50%;animation:qra-spin .55s linear infinite;flex-shrink:0}.qra-btn--ghost .qra-spinner-xs{border-color:#0000001a;border-top-color:var(--qra-ink-3)}.qra-dialog-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.qra-dialog{background:var(--qra-surface-0);border-radius:var(--qra-radius-xl);box-shadow:var(--qra-shadow-xl);padding:28px 24px;width:100%;max-width:380px;text-align:center;animation:qra-scale-in .22s ease}.qra-dialog__icon{width:60px;height:60px;border-radius:50%;background:#fee2e2;color:var(--qra-danger);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.qra-dialog__title{font-size:18px;font-weight:800;color:var(--qra-ink-1);margin-bottom:8px}.qra-dialog__msg{font-size:14px;color:var(--qra-ink-3);line-height:1.6;margin-bottom:20px}.qra-dialog__actions{display:flex;gap:10px;justify-content:center}.qra-toast-wrap{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;width:340px;max-width:calc(100vw - 32px);pointer-events:none}.qra-toast{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--qra-radius);border:1px solid transparent;box-shadow:0 6px 20px #0000001f;font-size:13px;font-weight:500;pointer-events:all;animation:qra-slide-in .22s ease}.qra-toast--success{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.qra-toast--error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.qra-toast--warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.qra-toast--info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.qra-toast__icon{flex-shrink:0;margin-top:1px}.qra-toast__msg{flex:1;line-height:1.45}.qra-toast__close{background:none;border:none;cursor:pointer;opacity:.5;transition:opacity .15s;color:inherit;padding:0;display:flex}.qra-toast__close:hover{opacity:1}@keyframes qra-spin{to{transform:rotate(360deg)}}@keyframes qra-scale-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes qra-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes qra-pulse-dot{0%,to{opacity:1}50%{opacity:.3}}@media(max-width:1024px){.qra-layout{grid-template-columns:1fr}.qra-layout__side{display:grid;grid-template-columns:1fr 1fr}}@media(max-width:768px){.qra-page-header{flex-direction:column;gap:12px}.qra-page-sub{margin-left:0}.qra-layout__side,.qra-details-grid{grid-template-columns:1fr}.qra-usb-section__header{flex-direction:column;align-items:flex-start}}@media(max-width:480px){.qra-action-row{flex-direction:column}.qra-camera-toolbar{flex-direction:column;align-items:stretch}.qra-cam-select{width:100%}.qra-usb-input-row{flex-wrap:wrap}}.stu-info-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px;gap:14px;flex-wrap:wrap}.stu-info-page-title{font-size:22px;font-weight:700;color:var(--tx1);display:flex;align-items:center;gap:10px;line-height:1.3}.stu-info-page-subtitle{font-size:13px;color:var(--tx3);margin-top:3px}.stu-info-page-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.stu-info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}.stu-info-card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.stu-info-card-title{font-size:15px;font-weight:700;color:var(--tx1)}.stu-info-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}.stu-info-stats-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:12px;transition:all .15s}.stu-info-stats-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stu-info-stats-primary{border-left:3px solid var(--primary)}.stu-info-stats-success{border-left:3px solid var(--success)}.stu-info-stats-warning{border-left:3px solid var(--warning)}.stu-info-stats-danger{border-left:3px solid var(--danger)}.stu-info-stats-info{border-left:3px solid var(--info)}.stu-info-stats-icon{width:42px;height:42px;border-radius:21px;background:var(--bg);display:flex;align-items:center;justify-content:center}.stu-info-stats-primary .stu-info-stats-icon{color:var(--primary)}.stu-info-stats-success .stu-info-stats-icon{color:var(--success)}.stu-info-stats-warning .stu-info-stats-icon{color:var(--warning)}.stu-info-stats-danger .stu-info-stats-icon{color:var(--danger)}.stu-info-stats-info .stu-info-stats-icon{color:var(--info)}.stu-info-stats-content{flex:1}.stu-info-stats-title{font-size:12px;font-weight:600;color:var(--tx3);margin-bottom:2px;text-transform:uppercase;letter-spacing:.3px}.stu-info-stats-value{font-size:24px;font-weight:700;color:var(--tx1);line-height:1;margin-bottom:2px}.stu-info-stats-subtitle{font-size:11px;color:var(--tx3)}.stu-info-stats-trend{display:flex;align-items:center;gap:2px;font-size:10px;margin-top:4px}.stu-info-stats-trend.up{color:var(--success)}.stu-info-stats-trend.down{color:var(--danger)}.stu-info-quick-stats{display:flex;gap:20px;background:var(--bg);border-radius:var(--radius-sm);padding:10px 16px;margin-bottom:16px;border:1px solid var(--border)}.stu-info-quick-stat{display:flex;align-items:center;gap:6px}.stu-info-quick-label{font-size:12px;color:var(--tx3)}.stu-info-quick-value{font-size:14px;font-weight:600;color:var(--tx1)}.stu-info-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.stu-info-badge-primary{background:var(--primary-light);color:var(--primary);border:1px solid var(--primary-border)}.stu-info-badge-success{background:var(--success-light);color:var(--success);border:1px solid var(--success-border)}.stu-info-badge-warning{background:var(--warning-light);color:var(--warning);border:1px solid var(--warning-border)}.stu-info-badge-danger{background:var(--danger-light);color:var(--danger);border:1px solid var(--danger-border)}.stu-info-badge-secondary{background:var(--bg);color:var(--tx3);border:1px solid var(--border)}.stu-info-badge-info{background:var(--info-light);color:var(--info);border:1px solid var(--info-border)}.stu-info-status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600}.stu-info-status-success{background:var(--success-light);color:var(--success)}.stu-info-status-warning{background:var(--warning-light);color:var(--warning)}.stu-info-status-danger{background:var(--danger-light);color:var(--danger)}.stu-info-status-secondary{background:var(--bg);color:var(--tx3)}.stu-info-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:600;padding:8px 14px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none;font-family:inherit;background:transparent}.stu-info-btn-sm{font-size:12px;padding:5px 10px}.stu-info-btn-lg{font-size:14px;padding:10px 20px}.stu-info-btn-primary{background:var(--primary);color:#fff}.stu-info-btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.stu-info-btn-success{background:var(--success);color:#fff}.stu-info-btn-success:hover:not(:disabled){background:#15803d;box-shadow:0 4px 12px #16a34a4d;transform:translateY(-1px)}.stu-info-btn-danger{background:var(--danger);color:#fff}.stu-info-btn-danger:hover:not(:disabled){background:#b91c1c;box-shadow:0 4px 12px #dc26264d;transform:translateY(-1px)}.stu-info-btn-ghost{background:transparent;color:var(--tx2);border:1px solid var(--border)}.stu-info-btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--tx1);transform:translateY(-1px)}.stu-info-btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.stu-info-filters-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.stu-info-search-wrapper{position:relative;flex:1;min-width:250px}.stu-info-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--tx3)}.stu-info-search-input{width:100%;padding:10px 10px 10px 36px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--bg-input);transition:all .15s}.stu-info-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.stu-info-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--tx3);cursor:pointer;font-size:18px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:10px}.stu-info-search-clear:hover{background:var(--bg-hover);color:var(--tx1)}.stu-info-filter-group{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px}.stu-info-filter-icon{margin-left:6px;color:var(--tx3)}.stu-info-filter-select{padding:6px 24px 6px 8px;border:none;background:transparent;font-size:13px;color:var(--tx1);cursor:pointer;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center}.stu-info-table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.stu-info-students-table{width:100%;border-collapse:collapse;font-size:13px}.stu-info-students-table th{text-align:left;padding:12px 16px;background:var(--bg);color:var(--tx2);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid var(--border)}.stu-info-students-table td{padding:14px 16px;border-bottom:1px solid var(--border);color:var(--tx1);vertical-align:middle}.stu-info-student-info{display:flex;align-items:center;gap:12px}.stu-info-student-avatar{width:36px;height:36px;border-radius:18px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--primary);flex-shrink:0}.stu-info-student-name{font-weight:600;color:var(--tx1);margin-bottom:2px}.stu-info-student-email{font-size:11px;color:var(--tx3)}.stu-info-regno{font-family:monospace;font-size:12px;background:var(--bg);padding:2px 6px;border-radius:4px;color:var(--tx2)}.stu-info-expiry-cell{display:flex;align-items:center;gap:4px}.stu-info-last-scanned{font-size:11px;color:var(--tx3)}.stu-info-action-buttons{display:flex;gap:6px}.stu-info-action-btn{width:30px;height:30px;border-radius:15px;border:1px solid var(--border);background:transparent;color:var(--tx2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}.stu-info-action-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff;transform:translateY(-2px)}.stu-info-action-btn.stu-info-primary{color:var(--primary);border-color:var(--primary-light)}.stu-info-action-btn.stu-info-primary:hover{background:var(--primary);color:#fff}.stu-info-grid-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:20px}.stu-info-student-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .15s}.stu-info-student-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stu-info-card-header{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg);border-bottom:1px solid var(--border)}.stu-info-student-avatar{width:48px;height:48px;border-radius:24px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:var(--primary);flex-shrink:0}.stu-info-student-info{flex:1;min-width:0}.stu-info-student-name{font-size:16px;font-weight:600;color:var(--tx1);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stu-info-student-regno{font-size:12px;color:var(--tx3);font-family:monospace}.stu-info-card-menu{background:transparent;border:none;color:var(--tx3);cursor:pointer;padding:4px;border-radius:4px}.stu-info-card-menu:hover{background:var(--bg-hover);color:var(--tx1)}.stu-info-card-body{padding:16px}.stu-info-student-details{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.stu-info-detail-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--tx2)}.stu-info-truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stu-info-card-badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.stu-info-last-scanned{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--tx3);padding-top:8px;border-top:1px dashed var(--border)}.stu-info-card-footer{display:flex;gap:6px;padding:12px 16px;background:var(--bg);border-top:1px solid var(--border)}.stu-info-pagination{display:flex;align-items:center;justify-content:space-between;margin-top:20px;flex-wrap:wrap;gap:12px}.stu-info-pagination-info{font-size:12px;color:var(--tx3)}.stu-info-pagination-buttons{display:flex;gap:4px}.stu-info-pagination-btn{min-width:32px;height:32px;border-radius:16px;border:1px solid var(--border);background:#fff;color:var(--tx2);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.stu-info-pagination-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--tx1)}.stu-info-pagination-btn.stu-info-active{background:var(--primary);border-color:var(--primary);color:#fff}.stu-info-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.stu-info-pagination-ellipsis{padding:0 4px;color:var(--tx3);display:flex;align-items:center}.stu-info-pagination-limit select{padding:6px 24px 6px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;color:var(--tx1);background:#fff;cursor:pointer;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center}.stu-info-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.stu-info-empty-icon{color:var(--tx3);opacity:.5;margin-bottom:16px}.stu-info-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1);margin-bottom:8px}.stu-info-empty-state p{color:var(--tx3);margin-bottom:20px}.stu-info-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:stu-info-fade-in .2s}@keyframes stu-info-fade-in{0%{opacity:0}to{opacity:1}}.stu-info-modal{background:#fff;border-radius:var(--radius);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:stu-info-slide-up .3s}.stu-info-modal-lg{max-width:700px}@keyframes stu-info-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.stu-info-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.stu-info-modal-title{font-size:18px;font-weight:600;color:var(--tx1);display:flex;align-items:center;gap:8px}.stu-info-modal-close-btn{background:transparent;border:none;font-size:24px;color:var(--tx3);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:16px}.stu-info-modal-close-btn:hover{background:var(--bg-hover);color:var(--tx1)}.stu-info-modal-body{padding:20px}.stu-info-modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:16px 20px;border-top:1px solid var(--border)}.stu-info-details-header{display:flex;gap:20px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}.stu-info-details-avatar{width:64px;height:64px;border-radius:32px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:600;color:var(--primary);flex-shrink:0}.stu-info-details-title{flex:1}.stu-info-details-title h2{font-size:22px;font-weight:700;color:var(--tx1);margin-bottom:4px}.stu-info-details-regno{font-size:14px;color:var(--tx3);margin-bottom:8px;font-family:monospace}.stu-info-details-badges{display:flex;gap:8px;flex-wrap:wrap}.stu-info-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}.stu-info-details-section h3{font-size:14px;font-weight:600;color:var(--tx2);margin-bottom:12px;padding-bottom:4px;border-bottom:1px solid var(--border)}.stu-info-details-row{display:flex;margin-bottom:8px;font-size:13px}.stu-info-details-label{width:100px;color:var(--tx3);flex-shrink:0}.stu-info-details-value{color:var(--tx1);font-weight:500;word-break:break-word}.stu-info-mono{font-family:monospace;font-size:11px;background:var(--bg);padding:2px 4px;border-radius:4px}.stu-info-qr-display{margin-top:20px;padding:16px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border)}.stu-info-qr-display h3{font-size:14px;font-weight:600;color:var(--tx2);margin-bottom:12px}.stu-info-qr-code-box{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.stu-info-qr-preview{width:100px;height:100px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--tx1)}.stu-info-qr-actions{display:flex;gap:8px;flex-wrap:wrap}.stu-info-form-group{margin-bottom:16px}.stu-info-form-group label{display:block;font-size:13px;font-weight:600;color:var(--tx2);margin-bottom:6px}.stu-info-input,.stu-info-select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:#fff;transition:all .15s}.stu-info-input:focus,.stu-info-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.stu-info-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--tx2);cursor:pointer}.stu-info-checkbox input{width:16px;height:16px;cursor:pointer}.stu-info-skeleton-table{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.stu-info-skeleton-row{display:flex;gap:16px;padding:12px 0;border-bottom:1px solid var(--border)}.stu-info-skeleton-row:last-child{border-bottom:none}.stu-info-skeleton-cell{height:20px;position:relative;overflow:hidden;background:var(--bg);border-radius:4px}.stu-info-skeleton-shimmer{position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:stu-info-shimmer 1.5s infinite}@keyframes stu-info-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.stu-info-grid-skeleton{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.stu-info-skeleton-card{height:280px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);position:relative;overflow:hidden}.stu-info-skeleton-card:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:stu-info-shimmer 1.5s infinite}.stu-info-toast-container{position:fixed;top:20px;right:20px;z-index:1100;display:flex;flex-direction:column;gap:10px}.stu-info-toast{min-width:280px;background:#fff;border-radius:var(--radius-sm);padding:12px 16px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px;animation:stu-info-toast-in .3s ease;border-left:4px solid}.stu-info-toast-success{border-left-color:var(--success)}.stu-info-toast-error{border-left-color:var(--danger)}.stu-info-toast-warning{border-left-color:var(--warning)}.stu-info-toast-info{border-left-color:var(--info)}@keyframes stu-info-toast-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.stu-info-toast-icon{flex-shrink:0}.stu-info-toast-success .stu-info-toast-icon{color:var(--success)}.stu-info-toast-error .stu-info-toast-icon{color:var(--danger)}.stu-info-toast-warning .stu-info-toast-icon{color:var(--warning)}.stu-info-toast-info .stu-info-toast-icon{color:var(--info)}.stu-info-toast-message{flex:1;font-size:13px;color:var(--tx1)}.stu-info-toast-close{background:transparent;border:none;color:var(--tx3);cursor:pointer;font-size:18px;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:10px}.stu-info-toast-close:hover{background:var(--bg-hover);color:var(--tx1)}.stu-info-view-toggle{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:2px}.stu-info-view-btn{width:30px;height:30px;border-radius:4px;border:none;background:transparent;color:var(--tx3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.stu-info-view-btn:hover{background:var(--bg-hover);color:var(--tx1)}.stu-info-view-btn.stu-info-active{background:var(--primary);color:#fff}.stu-info-text-success{color:var(--success)}.stu-info-text-warning{color:var(--warning)}.stu-info-text-danger{color:var(--danger)}.stu-info-text-primary{color:var(--primary)}.stu-info-text-info{color:var(--info)}.stu-info-spin{animation:stu-info-spin 1s linear infinite}@keyframes stu-info-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:900px){.stu-info-stats-grid{grid-template-columns:repeat(2,1fr)}.stu-info-details-grid{grid-template-columns:1fr}}@media(max-width:768px){.stu-info-page-hdr{flex-direction:column}.stu-info-filters-bar{flex-direction:column;align-items:stretch}.stu-info-filter-group{width:100%}.stu-info-filter-select{flex:1}.stu-info-pagination{flex-direction:column;align-items:center}.stu-info-details-header{flex-direction:column;align-items:center;text-align:center}.stu-info-details-badges{justify-content:center}.stu-info-qr-code-box{flex-direction:column;text-align:center}.stu-info-modal-foot{flex-direction:column}}@media(max-width:480px){.stu-info-stats-grid{grid-template-columns:1fr}.stu-info-quick-stats{flex-direction:column;gap:8px}.stu-info-action-buttons,.stu-info-card-footer{flex-wrap:wrap}.stu-info-card-footer .stu-info-btn{flex:1}}@media print{.stu-info-page-actions,.stu-info-filters-bar,.stu-info-pagination,.stu-info-action-buttons,.stu-info-card-footer,.stu-info-modal-foot{display:none!important}}.ses-toast-wrap{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;font-family:Plus Jakarta Sans,system-ui,sans-serif}.ses-toast{display:flex;align-items:center;gap:11px;padding:13px 16px;background:#fff;border-radius:12px;box-shadow:0 8px 30px #0f172a24,0 1px 4px #0f172a0f;min-width:280px;max-width:380px;border-left:3.5px solid #2563eb;animation:ses-toast-slide .28s cubic-bezier(.4,0,.2,1)}.ses-toast--success{border-left-color:#16a34a}.ses-toast--error{border-left-color:#dc2626}.ses-toast--warning{border-left-color:#d97706}.ses-toast__icon{flex-shrink:0;display:flex}.ses-toast--success .ses-toast__icon{color:#16a34a}.ses-toast--error .ses-toast__icon{color:#dc2626}.ses-toast--warning .ses-toast__icon{color:#d97706}.ses-toast--info .ses-toast__icon{color:#2563eb}.ses-toast__msg{flex:1;font-size:13px;font-weight:500;color:#0f172a;line-height:1.45}.ses-toast__x{background:none;border:none;color:#94a3b8;cursor:pointer;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s}.ses-toast__x:hover{background:#f1f5f9;color:#0f172a}@keyframes ses-toast-slide{0%{transform:translate(110%);opacity:0}to{transform:none;opacity:1}}.ses-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap;font-family:Plus Jakarta Sans,system-ui,sans-serif}.ses-page-hdr__left{flex:1}.ses-page-hdr__right{display:flex;gap:8px;align-items:center}.ses-page-title{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:800;color:#0f172a;letter-spacing:-.5px}.ses-title-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #2563eb4d;flex-shrink:0}.ses-page-sub{font-size:13px;color:#64748b;margin-top:4px;margin-left:48px}.ses-kpi-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:22px}.ses-kpi{position:relative;background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:14px 14px 12px 16px;display:flex;align-items:center;gap:12px;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .15s;animation:ses-kpi-in .4s cubic-bezier(.4,0,.2,1) var(--delay, 0ms) both;font-family:Plus Jakarta Sans,system-ui,sans-serif;cursor:default;text-align:left}.ses-kpi--click{cursor:pointer}.ses-kpi--click:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.ses-kpi--active{border-color:var(--accent, #2563eb);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 12%,transparent)}.ses-kpi__bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent, #2563eb);border-radius:14px 0 0 14px}.ses-kpi__icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ses-kpi__val{font-size:24px;font-weight:800;letter-spacing:-1px;line-height:1;font-family:DM Mono,monospace}.ses-kpi__lbl{font-size:10px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-top:3px}.ses-kpi__sub{font-size:10px;color:#94a3b8;margin-top:2px}@keyframes ses-kpi-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.ses-fbar{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:11px 14px;margin-bottom:16px;flex-wrap:wrap;font-family:Plus Jakarta Sans,system-ui,sans-serif}.ses-mode-toggle{display:flex;gap:1px;background:#f1f5f9;border-radius:8px;padding:2px;flex-shrink:0}.ses-mode-btn{display:flex;align-items:center;gap:6px;padding:6px 11px;border-radius:6px;border:none;background:transparent;color:#64748b;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.ses-mode-btn--active{background:#fff;color:#2563eb;box-shadow:0 1px 4px #00000014}.ses-search-box{position:relative;flex:1;min-width:200px;max-width:320px}.ses-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.ses-search-input{width:100%;padding:8px 34px 8px 36px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;color:#0f172a;font-size:13px;outline:none;transition:all .2s;font-family:inherit}.ses-search-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;background:#fff}.ses-search-input::placeholder{color:#94a3b8}.ses-search-clear{position:absolute;right:9px;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;border-radius:4px;padding:2px;transition:all .15s}.ses-search-clear:hover{color:#dc2626;background:#fee2e2}.ses-qr-box{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ses-cam-preview{width:280px;background:#000;border-radius:10px;overflow:hidden;border:2px solid #e2e8f0}.ses-cam-preview--qr{aspect-ratio:1}.ses-cam-error{font-size:12px;color:#dc2626}.ses-filter-chips{display:flex;gap:5px;flex-wrap:wrap;align-items:center}.ses-chip{display:inline-flex;align-items:center;padding:6px 12px;border-radius:20px;border:1.5px solid #e2e8f0;background:#fff;color:#475569;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.ses-chip:hover{border-color:#2563eb;color:#2563eb}.ses-chip--active{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 2px 8px #2563eb40}.ses-view-toggle{display:flex;gap:1px;background:#f1f5f9;border-radius:8px;padding:2px;flex-shrink:0}.ses-view-btn{width:30px;height:30px;border-radius:6px;border:none;background:transparent;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.ses-view-btn--active{background:#fff;color:#2563eb;box-shadow:0 1px 4px #00000014}.ses-count{font-size:12px;color:#94a3b8;margin-left:auto;white-space:nowrap}.ses-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid transparent;white-space:nowrap;font-family:Plus Jakarta Sans,system-ui,sans-serif}.ses-badge--active{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.ses-badge--pending{background:#fef3c7;color:#b45309;border-color:#fde68a}.ses-badge--closed{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}.ses-badge--flagged{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.ses-badge--alert{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ses-badge--stacked{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.ses-badge--verified{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.ses-badge--missing{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ses-badge--asset{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.ses-badge--xs{padding:2px 6px;font-size:9px}.ses-pulse{display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor;animation:ses-pulse-anim 1.6s ease-in-out infinite}@keyframes ses-pulse-anim{0%,to{opacity:1}50%{opacity:.35}}.ses-dur{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:700;color:#0f172a;font-family:DM Mono,monospace}.ses-dur--alert{color:#dc2626}.ses-cell-code{font-family:DM Mono,monospace;font-size:12px;font-weight:600;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 8px;border-radius:7px;color:#0f172a}.ses-cell-code--sm{font-size:11px;padding:1px 6px}.ses-person-cell{display:flex;align-items:center;gap:9px}.ses-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.ses-avatar--sm{width:28px;height:28px;font-size:10px}.ses-avatar--lg{width:46px;height:46px;font-size:16px}.ses-person-name{font-size:13px;font-weight:700;color:#0f172a}.ses-person-sub{font-size:11px;color:#64748b;font-family:DM Mono,monospace;margin-top:1px}.ses-mono{font-size:12px;color:#475569;font-family:DM Mono,monospace;white-space:nowrap}.ses-muted{color:#94a3b8}.ses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.ses-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;overflow:hidden;transition:box-shadow .2s,border-color .2s;animation:ses-card-in .22s ease both;font-family:Plus Jakarta Sans,system-ui,sans-serif}.ses-card:hover{box-shadow:0 6px 20px #00000014}.ses-card--alert{border-color:#fecaca;background:#fff8f8}.ses-card--alert:hover{box-shadow:0 6px 20px #dc26261f}@keyframes ses-card-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.ses-card__hdr{display:flex;align-items:center;gap:10px;padding:14px 14px 8px;cursor:pointer;-webkit-user-select:none;user-select:none}.ses-card__avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}.ses-card__identity{flex:1;min-width:0}.ses-card__name{font-size:13px;font-weight:700;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ses-card__meta{display:flex;align-items:center;gap:5px;margin-top:3px;flex-wrap:wrap}.ses-card__right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}.ses-card__body{padding:0 14px 8px}.ses-card__assets-strip{display:flex;align-items:center;gap:5px;font-size:11px;color:#7c3aed;background:#ede9fe;border-radius:6px;padding:3px 8px;width:fit-content;margin-bottom:6px}.ses-card__assets-detail{border-top:1px solid #f1f5f9;padding-top:8px;display:flex;flex-direction:column;gap:5px}.ses-card__asset-row{display:flex;align-items:center;gap:6px;font-size:12px;color:#475569}.ses-card__foot{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-top:1px solid #f1f5f9;background:#fafbfc}.ses-card__expand{display:flex;align-items:center;gap:4px;font-size:11px;color:#94a3b8;background:none;border:none;cursor:pointer;font-family:inherit;transition:color .15s;padding:2px 0}.ses-card__expand:hover{color:#2563eb}.ses-card__actions{display:flex;gap:5px}.ses-act{width:30px;height:30px;border-radius:7px;border:1.5px solid #e2e8f0;background:#fff;color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.ses-act:hover{background:#eff6ff;color:#2563eb;border-color:#2563eb;transform:translateY(-1px)}.ses-act--add:hover{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.ses-act--out:hover{background:#dcfce7;color:#16a34a;border-color:#bbf7d0}.ses-act:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.ses-row-acts{display:flex;gap:5px;justify-content:flex-end}.ses-table-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden;box-shadow:0 2px 12px #0000000a}.ses-table-scroll{overflow-y:auto}.ses-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.ses-table thead tr{background:linear-gradient(to bottom,#f8fafc,#f1f5f9);position:sticky;top:0;z-index:2}.ses-table th{padding:11px 12px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:2px solid #e2e8f0;white-space:nowrap;-webkit-user-select:none;user-select:none}.ses-table--row{width:100%;border-collapse:separate;border-spacing:0}.ses-table--row td{padding:12px;font-size:13px;color:#475569;border-bottom:1px solid #f1f5f9;vertical-align:middle;background:#fff;transition:background .1s}.ses-tr:hover td{background:#f8fafc}.ses-tr--alert td{background:#fff8f8}.ses-tr--alert:hover td{background:#fee2e2}.ses-tr-expand td{padding:0;border-bottom:1px solid #e2e8f0}.ses-inline-detail{padding:14px 16px;background:#f8fafc;border-top:1px solid #f1f5f9}.ses-inline-detail__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:10px}.ses-inline-detail__grid>div{display:flex;flex-direction:column;gap:3px}.ses-inline-detail__grid span{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px}.ses-inline-detail__grid strong{font-size:13px;font-weight:600;color:#0f172a}.ses-inline-assets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.ses-inline-asset{display:flex;align-items:center;gap:5px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:4px 9px;font-size:11px;color:#475569}.ses-inline-asset code{font-family:DM Mono,monospace;font-size:10px;color:#64748b}.ses-inline-notes{display:flex;align-items:center;gap:5px;font-size:12px;color:#64748b;background:#eff6ff;border-radius:6px;padding:5px 10px}.ses-expand-btn{width:24px;height:24px;border:none;background:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:5px;transition:all .15s}.ses-expand-btn:hover{background:#f1f5f9;color:#2563eb}.ses-skel-table{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:16px 20px}.ses-skel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.ses-skel-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:16px;animation:ses-row-in .25s ease both}.ses-skel-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid #f1f5f9;animation:ses-row-in .25s ease both}.ses-skel-row:last-child{border-bottom:none}.ses-skel{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;border-radius:6px;animation:ses-shimmer 1.4s linear infinite}.ses-skel--circle{width:34px;height:34px;border-radius:50%;flex-shrink:0}.ses-skel--wide{flex:1;max-width:200px;height:11px}.ses-skel--mid{width:100px;height:11px}.ses-skel--short{width:70px;height:11px}@keyframes ses-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes ses-row-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.ses-empty{text-align:center;padding:60px 24px;background:#fff;border:2px dashed #e2e8f0;border-radius:14px;font-family:Plus Jakarta Sans,system-ui,sans-serif}.ses-empty__ring{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);display:flex;align-items:center;justify-content:center;color:#94a3b8;margin:0 auto 18px}.ses-empty__title{font-size:16px;font-weight:700;color:#0f172a;margin-bottom:6px}.ses-empty__body{font-size:13px;color:#64748b;max-width:340px;margin:0 auto 18px;line-height:1.6}.ses-overlay{position:fixed;inset:0;background:#00000085;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:ses-ovl-in .2s ease;font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes ses-ovl-in{0%{opacity:0}to{opacity:1}}.ses-modal{background:#fff;border-radius:20px;box-shadow:0 32px 64px -20px #00000061,0 0 0 1px #0000000a;width:100%;max-height:92vh;overflow-y:auto;animation:ses-modal-in .22s cubic-bezier(.4,0,.2,1)}.ses-modal--lg{max-width:660px}.ses-modal--sm{max-width:520px}@keyframes ses-modal-in{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:none}}.ses-modal__hdr{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 14px;border-bottom:1px solid #f1f5f9;gap:12px}.ses-modal__hdr-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.ses-modal__hdr-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 3px 10px #2563eb40;flex-shrink:0}.ses-modal__title{font-size:16px;font-weight:800;color:#0f172a;letter-spacing:-.2px}.ses-modal__sub{font-size:12px;color:#64748b;margin-top:1px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}.ses-modal__close{width:32px;height:32px;border-radius:50%;border:1.5px solid #e2e8f0;background:#f8fafc;color:#475569;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.ses-modal__close:hover:not(:disabled){background:#fee2e2;color:#dc2626;border-color:#dc2626;transform:rotate(90deg)}.ses-modal__close:disabled{opacity:.5;cursor:not-allowed}.ses-modal__tabs{display:flex;gap:1px;padding:0 24px;border-bottom:1px solid #e2e8f0;background:#fafbfc}.ses-modal__tab{padding:10px 16px;background:none;border:none;border-bottom:2px solid transparent;color:#64748b;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap;margin-bottom:-1px}.ses-modal__tab:hover{color:#0f172a}.ses-modal__tab--active{color:#2563eb;border-bottom-color:#2563eb}.ses-modal__body{padding:20px 24px}.ses-modal__foot{padding:14px 24px;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.ses-detail-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.ses-detail-row{display:flex;flex-direction:column;gap:3px;padding:10px 14px;border-bottom:1px solid #f1f5f9}.ses-detail-row:nth-child(odd){background:#f8fafc}.ses-detail-row:nth-last-child(-n+2){border-bottom:none}.ses-detail-k{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px}.ses-detail-v{font-size:13px;font-weight:600;color:#0f172a;display:flex;align-items:center;gap:6px}.ses-notes-box{margin-top:14px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:12px 14px}.ses-notes-box__lbl{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:#1d4ed8;margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px}.ses-notes-box p{font-size:13px;color:#1e40af;margin:0;line-height:1.6}.ses-assets-list{display:flex;flex-direction:column;gap:8px}.ses-asset-row{display:flex;align-items:center;gap:10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px 14px;transition:background .15s}.ses-asset-row--verified{background:#f0fdf4;border-color:#bbf7d0}.ses-asset-row--missing{background:#fff8f8;border-color:#fecaca}.ses-asset-row__icon{color:#64748b;flex-shrink:0}.ses-asset-row--verified .ses-asset-row__icon{color:#16a34a}.ses-asset-row--missing .ses-asset-row__icon{color:#dc2626}.ses-asset-row__info{flex:1;min-width:0}.ses-asset-row__type{font-size:13px;font-weight:700;color:#0f172a}.ses-asset-row__code{font-family:DM Mono,monospace;font-size:11px;color:#64748b;word-break:break-all}.ses-asset-row__meta{font-size:11px;color:#94a3b8;margin-top:2px}.ses-asset-row__status{flex-shrink:0}.ses-timeline{display:flex;flex-direction:column;gap:0;position:relative}.ses-timeline:before{content:"";position:absolute;left:15px;top:20px;bottom:20px;width:1.5px;background:#e2e8f0;z-index:0}.ses-tl-item{display:flex;align-items:flex-start;gap:12px;position:relative;padding-bottom:20px}.ses-tl-item:last-child{padding-bottom:0}.ses-tl-dot{width:30px;height:30px;border-radius:50%;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff;z-index:1;position:relative}.ses-tl-dot--checkin{background:#dbeafe;border-color:#bfdbfe;color:#1d4ed8}.ses-tl-dot--confirm{background:#dcfce7;border-color:#bbf7d0;color:#15803d}.ses-tl-dot--asset{background:#ede9fe;border-color:#ddd6fe;color:#7c3aed}.ses-tl-dot--checkout{background:#f1f5f9;border-color:#e2e8f0;color:#475569}.ses-tl-content{flex:1;padding-top:4px}.ses-tl-label{font-size:13px;font-weight:600;color:#0f172a}.ses-tl-time{font-size:11px;color:#94a3b8;font-family:DM Mono,monospace;margin-top:2px}.ses-tl-sub{font-size:11px;color:#64748b;margin-top:3px}.ses-steps{display:flex;align-items:center;padding:12px 24px 0;border-bottom:1px solid #f1f5f9}.ses-step{display:flex;align-items:center;gap:7px;flex:1}.ses-step:last-child{flex:0}.ses-step__dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;background:#f1f5f9;color:#94a3b8;border:2px solid #e2e8f0;transition:all .25s}.ses-step--active .ses-step__dot{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 2px 8px #2563eb4d}.ses-step--done .ses-step__dot{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.ses-step__lbl{font-size:11px;font-weight:600;color:#94a3b8;white-space:nowrap}.ses-step--active .ses-step__lbl{color:#2563eb}.ses-step--done .ses-step__lbl{color:#15803d}.ses-step__line{flex:1;height:1px;background:#e2e8f0;margin:0 8px}.ses-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;padding:4px 0}.ses-type-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;border:1.5px solid #e2e8f0;border-radius:12px;background:#fff;cursor:pointer;transition:all .18s;font-family:inherit}.ses-type-card:hover{border-color:#2563eb;background:#eff6ff;transform:translateY(-2px);box-shadow:0 6px 16px #2563eb26}.ses-type-card__icon{color:#475569}.ses-type-card:hover .ses-type-card__icon{color:#2563eb}.ses-type-card__lbl{font-size:12px;font-weight:600;color:#0f172a;text-align:center}.ses-scan-target-lbl{font-size:13px;color:#64748b;margin-bottom:12px}.ses-scan-divider{display:flex;align-items:center;gap:10px;margin:14px 0;color:#94a3b8;font-size:12px}.ses-scan-divider:before,.ses-scan-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.ses-scan-input-row{display:flex;gap:8px}.ses-scan-preview-val{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:12px;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:6px 10px}.ses-scan-preview-val code{font-family:DM Mono,monospace;font-size:11px;color:#15803d}.ses-input-clear{position:relative;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;padding:0 8px;transition:color .15s}.ses-input-clear:hover{color:#dc2626}.ses-confirm-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px}.ses-confirm-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.ses-confirm-k{font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.4px}.ses-confirm-v{font-size:13px;font-weight:600;color:#0f172a}.ses-confirm-code{font-family:DM Mono,monospace;font-size:12px;color:#0f172a;background:#fff;border:1px solid #e2e8f0;padding:2px 8px;border-radius:6px;word-break:break-all}.ses-checkout-no-assets{text-align:center;padding:32px;display:flex;flex-direction:column;align-items:center;gap:12px;color:#16a34a;font-size:14px;font-weight:600}.ses-checkout-progress{display:flex;align-items:center;gap:12px;margin-bottom:16px;font-size:12px;font-weight:600;color:#475569}.ses-checkout-progress__bar{flex:1;height:6px;background:#f1f5f9;border-radius:3px;overflow:hidden}.ses-checkout-progress__fill{height:100%;background:#2563eb;border-radius:3px;transition:width .4s ease}.ses-verify-list{display:flex;flex-direction:column;gap:8px}.ses-verify-row{display:flex;align-items:center;gap:10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px 14px}.ses-verify-row--done{background:#f0fdf4;border-color:#bbf7d0}.ses-verify-row--missing{background:#fff8f8;border-color:#fecaca}.ses-verify-row__icon{color:#64748b;flex-shrink:0}.ses-verify-row--done .ses-verify-row__icon{color:#16a34a}.ses-verify-row--missing .ses-verify-row__icon{color:#dc2626}.ses-verify-row__info{flex:1;min-width:0}.ses-verify-row__type{font-size:13px;font-weight:700;color:#0f172a}.ses-verify-row__code{font-family:DM Mono,monospace;font-size:11px;color:#64748b;word-break:break-all}.ses-verify-row__action{flex-shrink:0}.ses-missing-panel{margin-top:14px;background:#fff5f5;border:1.5px solid #fecaca;border-radius:12px;padding:14px}.ses-missing-panel__hdr{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:#dc2626;margin-bottom:14px}.ses-missing-panel__x{background:none;border:none;color:#dc2626;cursor:pointer;margin-left:auto;display:flex;align-items:center;transition:opacity .15s}.ses-missing-panel__x:hover{opacity:.7}.ses-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ses-fg{display:flex;flex-direction:column;gap:5px}.ses-fg--full{grid-column:1/-1}.ses-fg>label{font-size:12px;font-weight:700;color:#475569}.ses-input{background:#fff;border:1.5px solid #e2e8f0;border-radius:9px;color:#0f172a;font-size:13px;padding:9px 12px;outline:none;width:100%;transition:all .2s;font-family:inherit}.ses-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}select.ses-input{cursor:pointer}textarea.ses-input{resize:vertical}.ses-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:700;padding:9px 18px;border-radius:9px;border:1.5px solid transparent;cursor:pointer;transition:all .17s;font-family:inherit;white-space:nowrap}.ses-btn--sm{font-size:12px;padding:6px 12px}.ses-btn--block{width:100%;justify-content:center}.ses-btn--primary{background:#2563eb;color:#fff;border-color:#2563eb}.ses-btn--primary:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.ses-btn--success{background:#16a34a;color:#fff;border-color:#16a34a}.ses-btn--success:hover:not(:disabled){background:#15803d;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}.ses-btn--danger{background:#dc2626;color:#fff;border-color:#dc2626}.ses-btn--danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.ses-btn--ghost{background:#fff;color:#475569;border-color:#e2e8f0}.ses-btn--ghost:hover:not(:disabled){background:#f8fafc;color:#0f172a;border-color:#cbd5e1}.ses-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.ses-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ses-spin .55s linear infinite}.ses-spinner--sm{width:10px;height:10px;border-width:1.5px}@keyframes ses-spin{to{transform:rotate(360deg)}}.ses-spin{animation:ses-spin 1s linear infinite}@media(max-width:1200px){.ses-kpi-strip{grid-template-columns:repeat(3,1fr)}}@media(max-width:1024px){.ses-kpi-strip{grid-template-columns:repeat(3,1fr)}.ses-inline-detail__grid{grid-template-columns:1fr 1fr}}@media(max-width:768px){.ses-kpi-strip{grid-template-columns:repeat(2,1fr)}.ses-fbar{flex-direction:column;align-items:stretch}.ses-filter-chips{overflow-x:auto;scrollbar-width:none}.ses-filter-chips::-webkit-scrollbar{display:none}.ses-modal--lg,.ses-modal--sm{max-width:98%}.ses-modal__hdr,.ses-modal__body,.ses-modal__foot{padding:14px 16px}.ses-steps{padding:10px 16px 0}.ses-detail-grid,.ses-form-grid{grid-template-columns:1fr}}@media(max-width:480px){.ses-kpi-strip{grid-template-columns:1fr 1fr}.ses-grid{grid-template-columns:1fr}}@media print{.ses-toast-wrap,.ses-page-hdr__right,.ses-fbar,.ses-row-acts,.ses-card__actions,.ses-overlay{display:none!important}.ses-table-card,.ses-kpi{box-shadow:none;border-color:#e2e8f0}}.ref-departments-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.ref-departments-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card,#fff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:ref-departments-toast-in .3s ease;border-left:4px solid var(--primary,#2563eb)}.ref-departments-toast-success{border-left-color:var(--success,#16a34a)}.ref-departments-toast-error{border-left-color:var(--danger,#dc2626)}.ref-departments-toast-warning{border-left-color:var(--warning,#d97706)}.ref-departments-toast-info{border-left-color:var(--primary,#2563eb)}.ref-departments-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.ref-departments-toast-success .ref-departments-toast-icon{color:var(--success,#16a34a)}.ref-departments-toast-error .ref-departments-toast-icon{color:var(--danger,#dc2626)}.ref-departments-toast-warning .ref-departments-toast-icon{color:var(--warning,#d97706)}.ref-departments-toast-info .ref-departments-toast-icon{color:var(--primary,#2563eb)}.ref-departments-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1,#0f172a);line-height:1.5}.ref-departments-toast-close{background:none;border:none;color:var(--tx3,#94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s}.ref-departments-toast-close:hover{background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a)}@keyframes ref-departments-toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ref-departments-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.ref-departments-page-title{font-size:24px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:12px}.ref-departments-page-subtitle{font-size:14px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-departments-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-departments-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.ref-departments-stats-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.ref-departments-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.ref-departments-stats-primary{border-left:4px solid var(--primary,#2563eb)}.ref-departments-stats-success{border-left:4px solid var(--success,#16a34a)}.ref-departments-stats-warning{border-left:4px solid var(--warning,#d97706)}.ref-departments-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.ref-departments-stats-primary .ref-departments-stats-icon{background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb)}.ref-departments-stats-success .ref-departments-stats-icon{background:var(--success-light,#dcfce7);color:var(--success,#16a34a)}.ref-departments-stats-warning .ref-departments-stats-icon{background:var(--warning-light,#fef3c7);color:var(--warning,#d97706)}.ref-departments-stats-content{flex:1}.ref-departments-stats-title{font-size:13px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.ref-departments-stats-value{font-size:30px;font-weight:700;color:var(--tx1,#0f172a);line-height:1.2}.ref-departments-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card,#fff);padding:16px 20px;border-radius:12px;border:1px solid var(--border,#e2e8f0);box-shadow:0 2px 6px #00000005}.ref-departments-search-wrapper{position:relative;flex:1;min-width:280px}.ref-departments-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3,#94a3b8);pointer-events:none}.ref-departments-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;outline:none;transition:all .2s}.ref-departments-search-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-departments-search-input::placeholder{color:var(--tx3,#94a3b8)}.ref-departments-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-departments-filter-select{padding:10px 14px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.ref-departments-filter-select:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-departments-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.ref-departments-card:hover{box-shadow:0 8px 24px #00000014}.ref-departments-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.ref-departments-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.ref-departments-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg,#f8fafc);white-space:nowrap;border-bottom:2px solid var(--border,#e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.ref-departments-lookup-table th:hover{background:var(--bg-hover,#e2e8f0);color:var(--tx1,#0f172a)}.ref-departments-lookup-table td{padding:16px;font-size:14px;color:var(--tx2,#475569);border-bottom:1px solid var(--border,#e2e8f0);vertical-align:middle;background:var(--bg-card,#fff);transition:background-color .2s}.ref-departments-lookup-table tr:hover td{background:var(--bg-hover,#f1f5f9)}.ref-departments-lookup-table tr.ref-departments-dragging{opacity:.5}.ref-departments-lookup-table tr.ref-departments-dragging td{background:var(--primary-light,#dbeafe)}.ref-departments-sort-icon{margin-left:8px;color:var(--tx3,#94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.ref-departments-drag-handle{color:var(--tx3,#94a3b8);cursor:grab;transition:color .2s}.ref-departments-drag-handle:hover{color:var(--primary,#2563eb)}.ref-departments-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg,#f8fafc);border-radius:8px;color:var(--tx3,#64748b);font-size:12px;border:1px dashed var(--border,#e2e8f0);margin-bottom:16px}.ref-departments-drag-hint svg{color:var(--primary,#2563eb)}.ref-departments-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary,#2563eb);background:var(--primary-light,#dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border,#bfdbfe);display:inline-block;white-space:nowrap}.ref-departments-type-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.ref-departments-type-badge svg{width:12px;height:12px}.ref-departments-badge-blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.ref-departments-badge-green{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.ref-departments-badge-purple{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.ref-departments-badge-amber{background:#fef3c7;color:#b45309;border-color:#fde68a}.ref-departments-badge-teal{background:#ccfbf1;color:#0f766e;border-color:#99f6e4}.ref-departments-badge-red{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ref-departments-badge-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa}.ref-departments-badge-gray{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.ref-departments-badge-pink{background:#fce7f3;color:#be185d;border-color:#fbcfe8}.ref-departments-badge-gold,.ref-departments-badge-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a}.ref-departments-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg,#f8fafc);border:1px solid var(--border,#e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2,#475569);padding:0 8px}.ref-departments-label-cell{font-weight:500;color:var(--tx1,#0f172a)}.ref-departments-date-info{font-size:12px;color:var(--tx2,#475569);background:var(--bg,#f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.ref-departments-status-toggle{display:flex;align-items:center;gap:12px}.ref-departments-status-label{font-size:13px;font-weight:500}.ref-departments-status-label.ref-departments-active{color:var(--success,#16a34a)}.ref-departments-status-label.ref-departments-inactive{color:var(--danger,#dc2626)}.ref-departments-modern-switch{position:relative;display:inline-block;cursor:pointer}.ref-departments-modern-switch.ref-departments-small input+.ref-departments-switch-slider{width:40px;height:22px}.ref-departments-modern-switch.ref-departments-small input+.ref-departments-switch-slider .ref-departments-switch-handle{width:18px;height:18px}.ref-departments-modern-switch input{opacity:0;width:0;height:0;position:absolute}.ref-departments-modern-switch .ref-departments-switch-slider{position:relative;display:block;background:var(--bg-input,#e2e8f0);border:2px solid var(--border,#cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.ref-departments-modern-switch input:checked+.ref-departments-switch-slider{background:var(--primary,#2563eb);border-color:var(--primary,#2563eb)}.ref-departments-modern-switch .ref-departments-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.ref-departments-modern-switch input:checked+.ref-departments-switch-slider .ref-departments-switch-handle{transform:translate(18px)}.ref-departments-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.ref-departments-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-departments-action-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--primary,#2563eb);border-color:var(--primary,#2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.ref-departments-action-btn.ref-departments-danger:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626)}.ref-departments-action-btn:disabled{opacity:.5;cursor:not-allowed}.ref-departments-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.ref-departments-pagination-info{font-size:13px;color:var(--tx3,#64748b)}.ref-departments-pagination-buttons{display:flex;gap:6px}.ref-departments-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-departments-pagination-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);border-color:var(--primary,#2563eb);color:var(--primary,#2563eb);transform:translateY(-1px)}.ref-departments-pagination-btn.ref-departments-active{background:var(--primary,#2563eb);color:#fff;border-color:var(--primary,#2563eb)}.ref-departments-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.ref-departments-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card,#fff);border-radius:20px;border:2px dashed var(--border,#e2e8f0)}.ref-departments-empty-icon{color:var(--tx3,#94a3b8);margin-bottom:20px;width:64px;height:64px}.ref-departments-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1,#0f172a);margin-bottom:8px}.ref-departments-empty-state p{font-size:14px;color:var(--tx3,#64748b);margin-bottom:24px}.ref-departments-skeleton-table{background:var(--bg-card,#fff);border-radius:16px;padding:24px}.ref-departments-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border,#e2e8f0)}.ref-departments-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg,#f1f5f9) 25%,var(--bg-hover,#e2e8f0) 50%,var(--bg,#f1f5f9) 75%);background-size:200% 100%;animation:ref-departments-shimmer 1.5s infinite;border-radius:4px}@keyframes ref-departments-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ref-departments-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:ref-departments-modal-fade .2s ease}@keyframes ref-departments-modal-fade{0%{opacity:0}to{opacity:1}}.ref-departments-modal{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:ref-departments-modal-scale .3s ease}@keyframes ref-departments-modal-scale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ref-departments-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.ref-departments-modal-title{font-size:18px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:8px}.ref-departments-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border,#e2e8f0);background:var(--bg,#f8fafc);color:var(--tx2,#475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.ref-departments-modal-close-btn:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626);transform:rotate(90deg)}.ref-departments-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.ref-departments-modal-body{padding:20px 28px}.ref-departments-modal-foot{padding:20px 28px;border-top:1px solid var(--border,#e2e8f0);display:flex;justify-content:flex-end;gap:12px}.ref-departments-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.ref-departments-form-label{font-size:13px;font-weight:600;color:var(--tx2,#475569);display:flex;align-items:center;gap:8px}.ref-departments-required{color:var(--danger,#dc2626);margin-left:2px;font-size:14px}.ref-departments-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb);border-radius:12px;border:1px solid var(--primary-border,#bfdbfe);margin-left:8px}.ref-departments-form-hint{font-size:11px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-departments-input,.ref-departments-input:is(select,textarea){background:var(--bg-input,#fff);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.ref-departments-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 3px var(--primary-light,#dbeafe)}.ref-departments-input.ref-departments-error{border-color:var(--danger,#dc2626);background:var(--danger-light,#fee2e2)}textarea.ref-departments-input{resize:vertical;min-height:80px}.ref-departments-error-message{color:var(--danger,#dc2626);font-size:11px;margin-top:4px;display:block}.ref-departments-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ref-departments-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;font-family:inherit}.ref-departments-btn-sm{font-size:12px;padding:8px 14px}.ref-departments-btn-primary{background:var(--primary,#2563eb);color:#fff}.ref-departments-btn-primary:hover:not(:disabled){background:var(--primary-hover,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.ref-departments-btn-ghost{background:transparent;color:var(--tx2,#475569);border:1.5px solid var(--border,#e2e8f0)}.ref-departments-btn-ghost:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a);border-color:var(--tx2,#475569)}.ref-departments-btn-danger{background:var(--danger,#dc2626);color:#fff}.ref-departments-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.ref-departments-btn:disabled{opacity:.5;cursor:not-allowed}.ref-departments-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ref-departments-spin .6s linear infinite;margin-right:6px}@keyframes ref-departments-spin{to{transform:rotate(360deg)}}.ref-departments-spin{animation:ref-departments-spin 1s linear infinite}.ref-departments-confirm-icon{text-align:center;margin-bottom:16px}.ref-departments-confirm-message{font-size:14px;color:var(--tx2,#475569);text-align:center;line-height:1.6}.ref-departments-text-success{color:var(--success,#16a34a)}.ref-departments-text-danger{color:var(--danger,#dc2626)}.ref-departments-severity-red{background:#fee2e2;color:#dc2626;border-color:#fecaca;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-departments-severity-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-departments-severity-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-departments-bool-yes{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.ref-departments-bool-no{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}@media(max-width:1024px){.ref-departments-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.ref-departments-page-hdr{flex-direction:column}.ref-departments-page-actions{width:100%;justify-content:flex-start}.ref-departments-filters-bar{flex-direction:column;align-items:stretch}.ref-departments-search-wrapper,.ref-departments-filter-group,.ref-departments-filter-select{width:100%}.ref-departments-stats-grid{grid-template-columns:1fr;gap:16px}.ref-departments-grid-2{grid-template-columns:1fr}.ref-departments-pagination{flex-direction:column;align-items:stretch}.ref-departments-pagination-buttons{justify-content:center}.ref-departments-modal-hdr,.ref-departments-modal-body,.ref-departments-modal-foot{padding:16px 20px}}@media print{.ref-departments-page-actions,.ref-departments-filters-bar,.ref-departments-action-buttons,.ref-departments-status-toggle,.ref-departments-drag-handle,.ref-departments-drag-hint,.ref-departments-toast-container,.ref-departments-modal-bg{display:none!important}.ref-departments-card{box-shadow:none;border:1px solid #000}}.ref-genders-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.ref-genders-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card,#fff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:ref-genders-toast-in .3s ease;border-left:4px solid var(--primary,#2563eb)}.ref-genders-toast-success{border-left-color:var(--success,#16a34a)}.ref-genders-toast-error{border-left-color:var(--danger,#dc2626)}.ref-genders-toast-warning{border-left-color:var(--warning,#d97706)}.ref-genders-toast-info{border-left-color:var(--primary,#2563eb)}.ref-genders-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.ref-genders-toast-success .ref-genders-toast-icon{color:var(--success,#16a34a)}.ref-genders-toast-error .ref-genders-toast-icon{color:var(--danger,#dc2626)}.ref-genders-toast-warning .ref-genders-toast-icon{color:var(--warning,#d97706)}.ref-genders-toast-info .ref-genders-toast-icon{color:var(--primary,#2563eb)}.ref-genders-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1,#0f172a);line-height:1.5}.ref-genders-toast-close{background:none;border:none;color:var(--tx3,#94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s}.ref-genders-toast-close:hover{background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a)}@keyframes ref-genders-toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ref-genders-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.ref-genders-page-title{font-size:24px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:12px}.ref-genders-page-subtitle{font-size:14px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-genders-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-genders-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.ref-genders-stats-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.ref-genders-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.ref-genders-stats-primary{border-left:4px solid var(--primary,#2563eb)}.ref-genders-stats-success{border-left:4px solid var(--success,#16a34a)}.ref-genders-stats-warning{border-left:4px solid var(--warning,#d97706)}.ref-genders-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.ref-genders-stats-primary .ref-genders-stats-icon{background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb)}.ref-genders-stats-success .ref-genders-stats-icon{background:var(--success-light,#dcfce7);color:var(--success,#16a34a)}.ref-genders-stats-warning .ref-genders-stats-icon{background:var(--warning-light,#fef3c7);color:var(--warning,#d97706)}.ref-genders-stats-content{flex:1}.ref-genders-stats-title{font-size:13px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.ref-genders-stats-value{font-size:30px;font-weight:700;color:var(--tx1,#0f172a);line-height:1.2}.ref-genders-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card,#fff);padding:16px 20px;border-radius:12px;border:1px solid var(--border,#e2e8f0);box-shadow:0 2px 6px #00000005}.ref-genders-search-wrapper{position:relative;flex:1;min-width:280px}.ref-genders-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3,#94a3b8);pointer-events:none}.ref-genders-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;outline:none;transition:all .2s}.ref-genders-search-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-genders-search-input::placeholder{color:var(--tx3,#94a3b8)}.ref-genders-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-genders-filter-select{padding:10px 14px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.ref-genders-filter-select:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-genders-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.ref-genders-card:hover{box-shadow:0 8px 24px #00000014}.ref-genders-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.ref-genders-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.ref-genders-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg,#f8fafc);white-space:nowrap;border-bottom:2px solid var(--border,#e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.ref-genders-lookup-table th:hover{background:var(--bg-hover,#e2e8f0);color:var(--tx1,#0f172a)}.ref-genders-lookup-table td{padding:16px;font-size:14px;color:var(--tx2,#475569);border-bottom:1px solid var(--border,#e2e8f0);vertical-align:middle;background:var(--bg-card,#fff);transition:background-color .2s}.ref-genders-lookup-table tr:hover td{background:var(--bg-hover,#f1f5f9)}.ref-genders-lookup-table tr.ref-genders-dragging{opacity:.5}.ref-genders-lookup-table tr.ref-genders-dragging td{background:var(--primary-light,#dbeafe)}.ref-genders-sort-icon{margin-left:8px;color:var(--tx3,#94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.ref-genders-drag-handle{color:var(--tx3,#94a3b8);cursor:grab;transition:color .2s}.ref-genders-drag-handle:hover{color:var(--primary,#2563eb)}.ref-genders-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg,#f8fafc);border-radius:8px;color:var(--tx3,#64748b);font-size:12px;border:1px dashed var(--border,#e2e8f0);margin-bottom:16px}.ref-genders-drag-hint svg{color:var(--primary,#2563eb)}.ref-genders-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary,#2563eb);background:var(--primary-light,#dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border,#bfdbfe);display:inline-block;white-space:nowrap}.ref-genders-type-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.ref-genders-type-badge svg{width:12px;height:12px}.ref-genders-badge-blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.ref-genders-badge-green{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.ref-genders-badge-purple{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.ref-genders-badge-amber{background:#fef3c7;color:#b45309;border-color:#fde68a}.ref-genders-badge-teal{background:#ccfbf1;color:#0f766e;border-color:#99f6e4}.ref-genders-badge-red{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ref-genders-badge-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa}.ref-genders-badge-gray{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.ref-genders-badge-pink{background:#fce7f3;color:#be185d;border-color:#fbcfe8}.ref-genders-badge-gold,.ref-genders-badge-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a}.ref-genders-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg,#f8fafc);border:1px solid var(--border,#e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2,#475569);padding:0 8px}.ref-genders-label-cell{font-weight:500;color:var(--tx1,#0f172a)}.ref-genders-date-info{font-size:12px;color:var(--tx2,#475569);background:var(--bg,#f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.ref-genders-status-toggle{display:flex;align-items:center;gap:12px}.ref-genders-status-label{font-size:13px;font-weight:500}.ref-genders-status-label.ref-genders-active{color:var(--success,#16a34a)}.ref-genders-status-label.ref-genders-inactive{color:var(--danger,#dc2626)}.ref-genders-modern-switch{position:relative;display:inline-block;cursor:pointer}.ref-genders-modern-switch.ref-genders-small input+.ref-genders-switch-slider{width:40px;height:22px}.ref-genders-modern-switch.ref-genders-small input+.ref-genders-switch-slider .ref-genders-switch-handle{width:18px;height:18px}.ref-genders-modern-switch input{opacity:0;width:0;height:0;position:absolute}.ref-genders-modern-switch .ref-genders-switch-slider{position:relative;display:block;background:var(--bg-input,#e2e8f0);border:2px solid var(--border,#cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.ref-genders-modern-switch input:checked+.ref-genders-switch-slider{background:var(--primary,#2563eb);border-color:var(--primary,#2563eb)}.ref-genders-modern-switch .ref-genders-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.ref-genders-modern-switch input:checked+.ref-genders-switch-slider .ref-genders-switch-handle{transform:translate(18px)}.ref-genders-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.ref-genders-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-genders-action-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--primary,#2563eb);border-color:var(--primary,#2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.ref-genders-action-btn.ref-genders-danger:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626)}.ref-genders-action-btn:disabled{opacity:.5;cursor:not-allowed}.ref-genders-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.ref-genders-pagination-info{font-size:13px;color:var(--tx3,#64748b)}.ref-genders-pagination-buttons{display:flex;gap:6px}.ref-genders-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-genders-pagination-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);border-color:var(--primary,#2563eb);color:var(--primary,#2563eb);transform:translateY(-1px)}.ref-genders-pagination-btn.ref-genders-active{background:var(--primary,#2563eb);color:#fff;border-color:var(--primary,#2563eb)}.ref-genders-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.ref-genders-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card,#fff);border-radius:20px;border:2px dashed var(--border,#e2e8f0)}.ref-genders-empty-icon{color:var(--tx3,#94a3b8);margin-bottom:20px;width:64px;height:64px}.ref-genders-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1,#0f172a);margin-bottom:8px}.ref-genders-empty-state p{font-size:14px;color:var(--tx3,#64748b);margin-bottom:24px}.ref-genders-skeleton-table{background:var(--bg-card,#fff);border-radius:16px;padding:24px}.ref-genders-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border,#e2e8f0)}.ref-genders-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg,#f1f5f9) 25%,var(--bg-hover,#e2e8f0) 50%,var(--bg,#f1f5f9) 75%);background-size:200% 100%;animation:ref-genders-shimmer 1.5s infinite;border-radius:4px}@keyframes ref-genders-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ref-genders-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:ref-genders-modal-fade .2s ease}@keyframes ref-genders-modal-fade{0%{opacity:0}to{opacity:1}}.ref-genders-modal{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:ref-genders-modal-scale .3s ease}@keyframes ref-genders-modal-scale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ref-genders-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.ref-genders-modal-title{font-size:18px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:8px}.ref-genders-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border,#e2e8f0);background:var(--bg,#f8fafc);color:var(--tx2,#475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.ref-genders-modal-close-btn:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626);transform:rotate(90deg)}.ref-genders-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.ref-genders-modal-body{padding:20px 28px}.ref-genders-modal-foot{padding:20px 28px;border-top:1px solid var(--border,#e2e8f0);display:flex;justify-content:flex-end;gap:12px}.ref-genders-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.ref-genders-form-label{font-size:13px;font-weight:600;color:var(--tx2,#475569);display:flex;align-items:center;gap:8px}.ref-genders-required{color:var(--danger,#dc2626);margin-left:2px;font-size:14px}.ref-genders-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb);border-radius:12px;border:1px solid var(--primary-border,#bfdbfe);margin-left:8px}.ref-genders-form-hint{font-size:11px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-genders-input,.ref-genders-input:is(select,textarea){background:var(--bg-input,#fff);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.ref-genders-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 3px var(--primary-light,#dbeafe)}.ref-genders-input.ref-genders-error{border-color:var(--danger,#dc2626);background:var(--danger-light,#fee2e2)}textarea.ref-genders-input{resize:vertical;min-height:80px}.ref-genders-error-message{color:var(--danger,#dc2626);font-size:11px;margin-top:4px;display:block}.ref-genders-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ref-genders-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;font-family:inherit}.ref-genders-btn-sm{font-size:12px;padding:8px 14px}.ref-genders-btn-primary{background:var(--primary,#2563eb);color:#fff}.ref-genders-btn-primary:hover:not(:disabled){background:var(--primary-hover,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.ref-genders-btn-ghost{background:transparent;color:var(--tx2,#475569);border:1.5px solid var(--border,#e2e8f0)}.ref-genders-btn-ghost:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a);border-color:var(--tx2,#475569)}.ref-genders-btn-danger{background:var(--danger,#dc2626);color:#fff}.ref-genders-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.ref-genders-btn:disabled{opacity:.5;cursor:not-allowed}.ref-genders-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ref-genders-spin .6s linear infinite;margin-right:6px}@keyframes ref-genders-spin{to{transform:rotate(360deg)}}.ref-genders-spin{animation:ref-genders-spin 1s linear infinite}.ref-genders-confirm-icon{text-align:center;margin-bottom:16px}.ref-genders-confirm-message{font-size:14px;color:var(--tx2,#475569);text-align:center;line-height:1.6}.ref-genders-text-success{color:var(--success,#16a34a)}.ref-genders-text-danger{color:var(--danger,#dc2626)}.ref-genders-severity-red{background:#fee2e2;color:#dc2626;border-color:#fecaca;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-genders-severity-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-genders-severity-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-genders-bool-yes{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.ref-genders-bool-no{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}@media(max-width:1024px){.ref-genders-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.ref-genders-page-hdr{flex-direction:column}.ref-genders-page-actions{width:100%;justify-content:flex-start}.ref-genders-filters-bar{flex-direction:column;align-items:stretch}.ref-genders-search-wrapper,.ref-genders-filter-group,.ref-genders-filter-select{width:100%}.ref-genders-stats-grid{grid-template-columns:1fr;gap:16px}.ref-genders-grid-2{grid-template-columns:1fr}.ref-genders-pagination{flex-direction:column;align-items:stretch}.ref-genders-pagination-buttons{justify-content:center}.ref-genders-modal-hdr,.ref-genders-modal-body,.ref-genders-modal-foot{padding:16px 20px}}@media print{.ref-genders-page-actions,.ref-genders-filters-bar,.ref-genders-action-buttons,.ref-genders-status-toggle,.ref-genders-drag-handle,.ref-genders-drag-hint,.ref-genders-toast-container,.ref-genders-modal-bg{display:none!important}.ref-genders-card{box-shadow:none;border:1px solid #000}}.ref-handover-statuses-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.ref-handover-statuses-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card,#fff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:ref-handover-statuses-toast-in .3s ease;border-left:4px solid var(--primary,#2563eb)}.ref-handover-statuses-toast-success{border-left-color:var(--success,#16a34a)}.ref-handover-statuses-toast-error{border-left-color:var(--danger,#dc2626)}.ref-handover-statuses-toast-warning{border-left-color:var(--warning,#d97706)}.ref-handover-statuses-toast-info{border-left-color:var(--primary,#2563eb)}.ref-handover-statuses-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.ref-handover-statuses-toast-success .ref-handover-statuses-toast-icon{color:var(--success,#16a34a)}.ref-handover-statuses-toast-error .ref-handover-statuses-toast-icon{color:var(--danger,#dc2626)}.ref-handover-statuses-toast-warning .ref-handover-statuses-toast-icon{color:var(--warning,#d97706)}.ref-handover-statuses-toast-info .ref-handover-statuses-toast-icon{color:var(--primary,#2563eb)}.ref-handover-statuses-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1,#0f172a);line-height:1.5}.ref-handover-statuses-toast-close{background:none;border:none;color:var(--tx3,#94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s}.ref-handover-statuses-toast-close:hover{background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a)}@keyframes ref-handover-statuses-toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ref-handover-statuses-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.ref-handover-statuses-page-title{font-size:24px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:12px}.ref-handover-statuses-page-subtitle{font-size:14px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-handover-statuses-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-handover-statuses-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.ref-handover-statuses-stats-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.ref-handover-statuses-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.ref-handover-statuses-stats-primary{border-left:4px solid var(--primary,#2563eb)}.ref-handover-statuses-stats-success{border-left:4px solid var(--success,#16a34a)}.ref-handover-statuses-stats-warning{border-left:4px solid var(--warning,#d97706)}.ref-handover-statuses-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.ref-handover-statuses-stats-primary .ref-handover-statuses-stats-icon{background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb)}.ref-handover-statuses-stats-success .ref-handover-statuses-stats-icon{background:var(--success-light,#dcfce7);color:var(--success,#16a34a)}.ref-handover-statuses-stats-warning .ref-handover-statuses-stats-icon{background:var(--warning-light,#fef3c7);color:var(--warning,#d97706)}.ref-handover-statuses-stats-content{flex:1}.ref-handover-statuses-stats-title{font-size:13px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.ref-handover-statuses-stats-value{font-size:30px;font-weight:700;color:var(--tx1,#0f172a);line-height:1.2}.ref-handover-statuses-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card,#fff);padding:16px 20px;border-radius:12px;border:1px solid var(--border,#e2e8f0);box-shadow:0 2px 6px #00000005}.ref-handover-statuses-search-wrapper{position:relative;flex:1;min-width:280px}.ref-handover-statuses-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3,#94a3b8);pointer-events:none}.ref-handover-statuses-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;outline:none;transition:all .2s}.ref-handover-statuses-search-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-handover-statuses-search-input::placeholder{color:var(--tx3,#94a3b8)}.ref-handover-statuses-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-handover-statuses-filter-select{padding:10px 14px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.ref-handover-statuses-filter-select:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-handover-statuses-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.ref-handover-statuses-card:hover{box-shadow:0 8px 24px #00000014}.ref-handover-statuses-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.ref-handover-statuses-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.ref-handover-statuses-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg,#f8fafc);white-space:nowrap;border-bottom:2px solid var(--border,#e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.ref-handover-statuses-lookup-table th:hover{background:var(--bg-hover,#e2e8f0);color:var(--tx1,#0f172a)}.ref-handover-statuses-lookup-table td{padding:16px;font-size:14px;color:var(--tx2,#475569);border-bottom:1px solid var(--border,#e2e8f0);vertical-align:middle;background:var(--bg-card,#fff);transition:background-color .2s}.ref-handover-statuses-lookup-table tr:hover td{background:var(--bg-hover,#f1f5f9)}.ref-handover-statuses-lookup-table tr.ref-handover-statuses-dragging{opacity:.5}.ref-handover-statuses-lookup-table tr.ref-handover-statuses-dragging td{background:var(--primary-light,#dbeafe)}.ref-handover-statuses-sort-icon{margin-left:8px;color:var(--tx3,#94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.ref-handover-statuses-drag-handle{color:var(--tx3,#94a3b8);cursor:grab;transition:color .2s}.ref-handover-statuses-drag-handle:hover{color:var(--primary,#2563eb)}.ref-handover-statuses-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg,#f8fafc);border-radius:8px;color:var(--tx3,#64748b);font-size:12px;border:1px dashed var(--border,#e2e8f0);margin-bottom:16px}.ref-handover-statuses-drag-hint svg{color:var(--primary,#2563eb)}.ref-handover-statuses-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary,#2563eb);background:var(--primary-light,#dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border,#bfdbfe);display:inline-block;white-space:nowrap}.ref-handover-statuses-type-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.ref-handover-statuses-type-badge svg{width:12px;height:12px}.ref-handover-statuses-badge-blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.ref-handover-statuses-badge-green{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.ref-handover-statuses-badge-purple{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.ref-handover-statuses-badge-amber{background:#fef3c7;color:#b45309;border-color:#fde68a}.ref-handover-statuses-badge-teal{background:#ccfbf1;color:#0f766e;border-color:#99f6e4}.ref-handover-statuses-badge-red{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ref-handover-statuses-badge-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa}.ref-handover-statuses-badge-gray{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.ref-handover-statuses-badge-pink{background:#fce7f3;color:#be185d;border-color:#fbcfe8}.ref-handover-statuses-badge-gold,.ref-handover-statuses-badge-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a}.ref-handover-statuses-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg,#f8fafc);border:1px solid var(--border,#e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2,#475569);padding:0 8px}.ref-handover-statuses-label-cell{font-weight:500;color:var(--tx1,#0f172a)}.ref-handover-statuses-date-info{font-size:12px;color:var(--tx2,#475569);background:var(--bg,#f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.ref-handover-statuses-status-toggle{display:flex;align-items:center;gap:12px}.ref-handover-statuses-status-label{font-size:13px;font-weight:500}.ref-handover-statuses-status-label.ref-handover-statuses-active{color:var(--success,#16a34a)}.ref-handover-statuses-status-label.ref-handover-statuses-inactive{color:var(--danger,#dc2626)}.ref-handover-statuses-modern-switch{position:relative;display:inline-block;cursor:pointer}.ref-handover-statuses-modern-switch.ref-handover-statuses-small input+.ref-handover-statuses-switch-slider{width:40px;height:22px}.ref-handover-statuses-modern-switch.ref-handover-statuses-small input+.ref-handover-statuses-switch-slider .ref-handover-statuses-switch-handle{width:18px;height:18px}.ref-handover-statuses-modern-switch input{opacity:0;width:0;height:0;position:absolute}.ref-handover-statuses-modern-switch .ref-handover-statuses-switch-slider{position:relative;display:block;background:var(--bg-input,#e2e8f0);border:2px solid var(--border,#cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.ref-handover-statuses-modern-switch input:checked+.ref-handover-statuses-switch-slider{background:var(--primary,#2563eb);border-color:var(--primary,#2563eb)}.ref-handover-statuses-modern-switch .ref-handover-statuses-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.ref-handover-statuses-modern-switch input:checked+.ref-handover-statuses-switch-slider .ref-handover-statuses-switch-handle{transform:translate(18px)}.ref-handover-statuses-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.ref-handover-statuses-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-handover-statuses-action-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--primary,#2563eb);border-color:var(--primary,#2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.ref-handover-statuses-action-btn.ref-handover-statuses-danger:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626)}.ref-handover-statuses-action-btn:disabled{opacity:.5;cursor:not-allowed}.ref-handover-statuses-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.ref-handover-statuses-pagination-info{font-size:13px;color:var(--tx3,#64748b)}.ref-handover-statuses-pagination-buttons{display:flex;gap:6px}.ref-handover-statuses-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-handover-statuses-pagination-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);border-color:var(--primary,#2563eb);color:var(--primary,#2563eb);transform:translateY(-1px)}.ref-handover-statuses-pagination-btn.ref-handover-statuses-active{background:var(--primary,#2563eb);color:#fff;border-color:var(--primary,#2563eb)}.ref-handover-statuses-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.ref-handover-statuses-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card,#fff);border-radius:20px;border:2px dashed var(--border,#e2e8f0)}.ref-handover-statuses-empty-icon{color:var(--tx3,#94a3b8);margin-bottom:20px;width:64px;height:64px}.ref-handover-statuses-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1,#0f172a);margin-bottom:8px}.ref-handover-statuses-empty-state p{font-size:14px;color:var(--tx3,#64748b);margin-bottom:24px}.ref-handover-statuses-skeleton-table{background:var(--bg-card,#fff);border-radius:16px;padding:24px}.ref-handover-statuses-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border,#e2e8f0)}.ref-handover-statuses-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg,#f1f5f9) 25%,var(--bg-hover,#e2e8f0) 50%,var(--bg,#f1f5f9) 75%);background-size:200% 100%;animation:ref-handover-statuses-shimmer 1.5s infinite;border-radius:4px}@keyframes ref-handover-statuses-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ref-handover-statuses-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:ref-handover-statuses-modal-fade .2s ease}@keyframes ref-handover-statuses-modal-fade{0%{opacity:0}to{opacity:1}}.ref-handover-statuses-modal{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:ref-handover-statuses-modal-scale .3s ease}@keyframes ref-handover-statuses-modal-scale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ref-handover-statuses-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.ref-handover-statuses-modal-title{font-size:18px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:8px}.ref-handover-statuses-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border,#e2e8f0);background:var(--bg,#f8fafc);color:var(--tx2,#475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.ref-handover-statuses-modal-close-btn:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626);transform:rotate(90deg)}.ref-handover-statuses-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.ref-handover-statuses-modal-body{padding:20px 28px}.ref-handover-statuses-modal-foot{padding:20px 28px;border-top:1px solid var(--border,#e2e8f0);display:flex;justify-content:flex-end;gap:12px}.ref-handover-statuses-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.ref-handover-statuses-form-label{font-size:13px;font-weight:600;color:var(--tx2,#475569);display:flex;align-items:center;gap:8px}.ref-handover-statuses-required{color:var(--danger,#dc2626);margin-left:2px;font-size:14px}.ref-handover-statuses-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb);border-radius:12px;border:1px solid var(--primary-border,#bfdbfe);margin-left:8px}.ref-handover-statuses-form-hint{font-size:11px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-handover-statuses-input,.ref-handover-statuses-input:is(select,textarea){background:var(--bg-input,#fff);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.ref-handover-statuses-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 3px var(--primary-light,#dbeafe)}.ref-handover-statuses-input.ref-handover-statuses-error{border-color:var(--danger,#dc2626);background:var(--danger-light,#fee2e2)}textarea.ref-handover-statuses-input{resize:vertical;min-height:80px}.ref-handover-statuses-error-message{color:var(--danger,#dc2626);font-size:11px;margin-top:4px;display:block}.ref-handover-statuses-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ref-handover-statuses-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;font-family:inherit}.ref-handover-statuses-btn-sm{font-size:12px;padding:8px 14px}.ref-handover-statuses-btn-primary{background:var(--primary,#2563eb);color:#fff}.ref-handover-statuses-btn-primary:hover:not(:disabled){background:var(--primary-hover,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.ref-handover-statuses-btn-ghost{background:transparent;color:var(--tx2,#475569);border:1.5px solid var(--border,#e2e8f0)}.ref-handover-statuses-btn-ghost:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a);border-color:var(--tx2,#475569)}.ref-handover-statuses-btn-danger{background:var(--danger,#dc2626);color:#fff}.ref-handover-statuses-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.ref-handover-statuses-btn:disabled{opacity:.5;cursor:not-allowed}.ref-handover-statuses-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ref-handover-statuses-spin .6s linear infinite;margin-right:6px}@keyframes ref-handover-statuses-spin{to{transform:rotate(360deg)}}.ref-handover-statuses-spin{animation:ref-handover-statuses-spin 1s linear infinite}.ref-handover-statuses-confirm-icon{text-align:center;margin-bottom:16px}.ref-handover-statuses-confirm-message{font-size:14px;color:var(--tx2,#475569);text-align:center;line-height:1.6}.ref-handover-statuses-text-success{color:var(--success,#16a34a)}.ref-handover-statuses-text-danger{color:var(--danger,#dc2626)}.ref-handover-statuses-severity-red{background:#fee2e2;color:#dc2626;border-color:#fecaca;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-handover-statuses-severity-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-handover-statuses-severity-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-handover-statuses-bool-yes{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.ref-handover-statuses-bool-no{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}@media(max-width:1024px){.ref-handover-statuses-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.ref-handover-statuses-page-hdr{flex-direction:column}.ref-handover-statuses-page-actions{width:100%;justify-content:flex-start}.ref-handover-statuses-filters-bar{flex-direction:column;align-items:stretch}.ref-handover-statuses-search-wrapper,.ref-handover-statuses-filter-group,.ref-handover-statuses-filter-select{width:100%}.ref-handover-statuses-stats-grid{grid-template-columns:1fr;gap:16px}.ref-handover-statuses-grid-2{grid-template-columns:1fr}.ref-handover-statuses-pagination{flex-direction:column;align-items:stretch}.ref-handover-statuses-pagination-buttons{justify-content:center}.ref-handover-statuses-modal-hdr,.ref-handover-statuses-modal-body,.ref-handover-statuses-modal-foot{padding:16px 20px}}@media print{.ref-handover-statuses-page-actions,.ref-handover-statuses-filters-bar,.ref-handover-statuses-action-buttons,.ref-handover-statuses-status-toggle,.ref-handover-statuses-drag-handle,.ref-handover-statuses-drag-hint,.ref-handover-statuses-toast-container,.ref-handover-statuses-modal-bg{display:none!important}.ref-handover-statuses-card{box-shadow:none;border:1px solid #000}}.ref-notification-types-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.ref-notification-types-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #fff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:ref-notification-types-toast-in .3s ease;border-left:4px solid var(--primary, #2563eb)}.ref-notification-types-toast-success{border-left-color:var(--success, #16a34a)}.ref-notification-types-toast-error{border-left-color:var(--danger, #dc2626)}.ref-notification-types-toast-warning{border-left-color:var(--warning, #d97706)}.ref-notification-types-toast-info{border-left-color:var(--primary, #2563eb)}.ref-notification-types-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.ref-notification-types-toast-success .ref-notification-types-toast-icon{color:var(--success, #16a34a)}.ref-notification-types-toast-error .ref-notification-types-toast-icon{color:var(--danger, #dc2626)}.ref-notification-types-toast-warning .ref-notification-types-toast-icon{color:var(--warning, #d97706)}.ref-notification-types-toast-info .ref-notification-types-toast-icon{color:var(--primary, #2563eb)}.ref-notification-types-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.ref-notification-types-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s}.ref-notification-types-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes ref-notification-types-toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ref-notification-types-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.ref-notification-types-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.ref-notification-types-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.ref-notification-types-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-notification-types-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.ref-notification-types-stats-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.ref-notification-types-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.ref-notification-types-stats-primary{border-left:4px solid var(--primary, #2563eb)}.ref-notification-types-stats-success{border-left:4px solid var(--success, #16a34a)}.ref-notification-types-stats-warning{border-left:4px solid var(--warning, #d97706)}.ref-notification-types-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.ref-notification-types-stats-primary .ref-notification-types-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.ref-notification-types-stats-success .ref-notification-types-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.ref-notification-types-stats-warning .ref-notification-types-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.ref-notification-types-stats-content{flex:1}.ref-notification-types-stats-title{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.ref-notification-types-stats-value{font-size:30px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.ref-notification-types-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #fff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.ref-notification-types-search-wrapper{position:relative;flex:1;min-width:280px}.ref-notification-types-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.ref-notification-types-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.ref-notification-types-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.ref-notification-types-search-input::placeholder{color:var(--tx3, #94a3b8)}.ref-notification-types-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-notification-types-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.ref-notification-types-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.ref-notification-types-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.ref-notification-types-card:hover{box-shadow:0 8px 24px #00000014}.ref-notification-types-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.ref-notification-types-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.ref-notification-types-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.ref-notification-types-lookup-table th:hover{background:var(--bg-hover, #e2e8f0);color:var(--tx1, #0f172a)}.ref-notification-types-lookup-table td{padding:16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #fff);transition:background-color .2s}.ref-notification-types-lookup-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.ref-notification-types-lookup-table tr.ref-notification-types-dragging{opacity:.5}.ref-notification-types-lookup-table tr.ref-notification-types-dragging td{background:var(--primary-light, #dbeafe)}.ref-notification-types-sort-icon{margin-left:8px;color:var(--tx3, #94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.ref-notification-types-drag-handle{color:var(--tx3, #94a3b8);cursor:grab;transition:color .2s}.ref-notification-types-drag-handle:hover{color:var(--primary, #2563eb)}.ref-notification-types-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg, #f8fafc);border-radius:8px;color:var(--tx3, #64748b);font-size:12px;border:1px dashed var(--border, #e2e8f0);margin-bottom:16px}.ref-notification-types-drag-hint svg{color:var(--primary, #2563eb)}.ref-notification-types-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block;white-space:nowrap}.ref-notification-types-type-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.ref-notification-types-type-badge svg{width:12px;height:12px}.ref-notification-types-badge-blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.ref-notification-types-badge-green{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.ref-notification-types-badge-purple{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.ref-notification-types-badge-amber{background:#fef3c7;color:#b45309;border-color:#fde68a}.ref-notification-types-badge-teal{background:#ccfbf1;color:#0f766e;border-color:#99f6e4}.ref-notification-types-badge-red{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ref-notification-types-badge-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa}.ref-notification-types-badge-gray{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.ref-notification-types-badge-pink{background:#fce7f3;color:#be185d;border-color:#fbcfe8}.ref-notification-types-badge-gold,.ref-notification-types-badge-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a}.ref-notification-types-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2, #475569);padding:0 8px}.ref-notification-types-label-cell{font-weight:500;color:var(--tx1, #0f172a)}.ref-notification-types-date-info{font-size:12px;color:var(--tx2, #475569);background:var(--bg, #f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.ref-notification-types-status-toggle{display:flex;align-items:center;gap:12px}.ref-notification-types-status-label{font-size:13px;font-weight:500}.ref-notification-types-status-label.ref-notification-types-active{color:var(--success, #16a34a)}.ref-notification-types-status-label.ref-notification-types-inactive{color:var(--danger, #dc2626)}.ref-notification-types-modern-switch{position:relative;display:inline-block;cursor:pointer}.ref-notification-types-modern-switch.ref-notification-types-small input+.ref-notification-types-switch-slider{width:40px;height:22px}.ref-notification-types-modern-switch.ref-notification-types-small input+.ref-notification-types-switch-slider .ref-notification-types-switch-handle{width:18px;height:18px}.ref-notification-types-modern-switch input{opacity:0;width:0;height:0;position:absolute}.ref-notification-types-modern-switch .ref-notification-types-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.ref-notification-types-modern-switch input:checked+.ref-notification-types-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.ref-notification-types-modern-switch .ref-notification-types-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.ref-notification-types-modern-switch input:checked+.ref-notification-types-switch-slider .ref-notification-types-switch-handle{transform:translate(18px)}.ref-notification-types-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.ref-notification-types-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-notification-types-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.ref-notification-types-action-btn.ref-notification-types-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.ref-notification-types-action-btn:disabled{opacity:.5;cursor:not-allowed}.ref-notification-types-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.ref-notification-types-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.ref-notification-types-pagination-buttons{display:flex;gap:6px}.ref-notification-types-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-notification-types-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.ref-notification-types-pagination-btn.ref-notification-types-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.ref-notification-types-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.ref-notification-types-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #fff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.ref-notification-types-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.ref-notification-types-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.ref-notification-types-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.ref-notification-types-skeleton-table{background:var(--bg-card, #fff);border-radius:16px;padding:24px}.ref-notification-types-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.ref-notification-types-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:ref-notification-types-shimmer 1.5s infinite;border-radius:4px}@keyframes ref-notification-types-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ref-notification-types-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:ref-notification-types-modal-fade .2s ease}@keyframes ref-notification-types-modal-fade{0%{opacity:0}to{opacity:1}}.ref-notification-types-modal{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:ref-notification-types-modal-scale .3s ease}@keyframes ref-notification-types-modal-scale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ref-notification-types-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.ref-notification-types-modal-title{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.ref-notification-types-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.ref-notification-types-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.ref-notification-types-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.ref-notification-types-modal-body{padding:20px 28px}.ref-notification-types-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.ref-notification-types-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.ref-notification-types-form-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.ref-notification-types-required{color:var(--danger, #dc2626);margin-left:2px;font-size:14px}.ref-notification-types-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:12px;border:1px solid var(--primary-border, #bfdbfe);margin-left:8px}.ref-notification-types-form-hint{font-size:11px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.ref-notification-types-input,.ref-notification-types-input:is(select,textarea){background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.ref-notification-types-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.ref-notification-types-input.ref-notification-types-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}textarea.ref-notification-types-input{resize:vertical;min-height:80px}.ref-notification-types-error-message{color:var(--danger, #dc2626);font-size:11px;margin-top:4px;display:block}.ref-notification-types-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ref-notification-types-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;font-family:inherit}.ref-notification-types-btn-sm{font-size:12px;padding:8px 14px}.ref-notification-types-btn-primary{background:var(--primary, #2563eb);color:#fff}.ref-notification-types-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.ref-notification-types-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.ref-notification-types-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.ref-notification-types-btn-danger{background:var(--danger, #dc2626);color:#fff}.ref-notification-types-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.ref-notification-types-btn:disabled{opacity:.5;cursor:not-allowed}.ref-notification-types-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ref-notification-types-spin .6s linear infinite;margin-right:6px}@keyframes ref-notification-types-spin{to{transform:rotate(360deg)}}.ref-notification-types-spin{animation:ref-notification-types-spin 1s linear infinite}.ref-notification-types-confirm-icon{text-align:center;margin-bottom:16px}.ref-notification-types-confirm-message{font-size:14px;color:var(--tx2, #475569);text-align:center;line-height:1.6}.ref-notification-types-text-success{color:var(--success, #16a34a)}.ref-notification-types-text-danger{color:var(--danger, #dc2626)}.ref-notification-types-severity-red{background:#fee2e2;color:#dc2626;border-color:#fecaca;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-notification-types-severity-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-notification-types-severity-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-notification-types-bool-yes{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.ref-notification-types-bool-no{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}@media(max-width:1024px){.ref-notification-types-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.ref-notification-types-page-hdr{flex-direction:column}.ref-notification-types-page-actions{width:100%;justify-content:flex-start}.ref-notification-types-filters-bar{flex-direction:column;align-items:stretch}.ref-notification-types-search-wrapper,.ref-notification-types-filter-group,.ref-notification-types-filter-select{width:100%}.ref-notification-types-stats-grid{grid-template-columns:1fr;gap:16px}.ref-notification-types-grid-2{grid-template-columns:1fr}.ref-notification-types-pagination{flex-direction:column;align-items:stretch}.ref-notification-types-pagination-buttons{justify-content:center}.ref-notification-types-modal-hdr,.ref-notification-types-modal-body,.ref-notification-types-modal-foot{padding:16px 20px}}@media print{.ref-notification-types-page-actions,.ref-notification-types-filters-bar,.ref-notification-types-action-buttons,.ref-notification-types-status-toggle,.ref-notification-types-drag-handle,.ref-notification-types-drag-hint,.ref-notification-types-toast-container,.ref-notification-types-modal-bg{display:none!important}.ref-notification-types-card{box-shadow:none;border:1px solid #000}}.ref-presence-statuses-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.ref-presence-statuses-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card,#fff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:ref-presence-statuses-toast-in .3s ease;border-left:4px solid var(--primary,#2563eb)}.ref-presence-statuses-toast-success{border-left-color:var(--success,#16a34a)}.ref-presence-statuses-toast-error{border-left-color:var(--danger,#dc2626)}.ref-presence-statuses-toast-warning{border-left-color:var(--warning,#d97706)}.ref-presence-statuses-toast-info{border-left-color:var(--primary,#2563eb)}.ref-presence-statuses-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.ref-presence-statuses-toast-success .ref-presence-statuses-toast-icon{color:var(--success,#16a34a)}.ref-presence-statuses-toast-error .ref-presence-statuses-toast-icon{color:var(--danger,#dc2626)}.ref-presence-statuses-toast-warning .ref-presence-statuses-toast-icon{color:var(--warning,#d97706)}.ref-presence-statuses-toast-info .ref-presence-statuses-toast-icon{color:var(--primary,#2563eb)}.ref-presence-statuses-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1,#0f172a);line-height:1.5}.ref-presence-statuses-toast-close{background:none;border:none;color:var(--tx3,#94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s}.ref-presence-statuses-toast-close:hover{background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a)}@keyframes ref-presence-statuses-toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ref-presence-statuses-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.ref-presence-statuses-page-title{font-size:24px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:12px}.ref-presence-statuses-page-subtitle{font-size:14px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-presence-statuses-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-presence-statuses-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.ref-presence-statuses-stats-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.ref-presence-statuses-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.ref-presence-statuses-stats-primary{border-left:4px solid var(--primary,#2563eb)}.ref-presence-statuses-stats-success{border-left:4px solid var(--success,#16a34a)}.ref-presence-statuses-stats-warning{border-left:4px solid var(--warning,#d97706)}.ref-presence-statuses-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.ref-presence-statuses-stats-primary .ref-presence-statuses-stats-icon{background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb)}.ref-presence-statuses-stats-success .ref-presence-statuses-stats-icon{background:var(--success-light,#dcfce7);color:var(--success,#16a34a)}.ref-presence-statuses-stats-warning .ref-presence-statuses-stats-icon{background:var(--warning-light,#fef3c7);color:var(--warning,#d97706)}.ref-presence-statuses-stats-content{flex:1}.ref-presence-statuses-stats-title{font-size:13px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.ref-presence-statuses-stats-value{font-size:30px;font-weight:700;color:var(--tx1,#0f172a);line-height:1.2}.ref-presence-statuses-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card,#fff);padding:16px 20px;border-radius:12px;border:1px solid var(--border,#e2e8f0);box-shadow:0 2px 6px #00000005}.ref-presence-statuses-search-wrapper{position:relative;flex:1;min-width:280px}.ref-presence-statuses-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3,#94a3b8);pointer-events:none}.ref-presence-statuses-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;outline:none;transition:all .2s}.ref-presence-statuses-search-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-presence-statuses-search-input::placeholder{color:var(--tx3,#94a3b8)}.ref-presence-statuses-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-presence-statuses-filter-select{padding:10px 14px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.ref-presence-statuses-filter-select:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-presence-statuses-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.ref-presence-statuses-card:hover{box-shadow:0 8px 24px #00000014}.ref-presence-statuses-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.ref-presence-statuses-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.ref-presence-statuses-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg,#f8fafc);white-space:nowrap;border-bottom:2px solid var(--border,#e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.ref-presence-statuses-lookup-table th:hover{background:var(--bg-hover,#e2e8f0);color:var(--tx1,#0f172a)}.ref-presence-statuses-lookup-table td{padding:16px;font-size:14px;color:var(--tx2,#475569);border-bottom:1px solid var(--border,#e2e8f0);vertical-align:middle;background:var(--bg-card,#fff);transition:background-color .2s}.ref-presence-statuses-lookup-table tr:hover td{background:var(--bg-hover,#f1f5f9)}.ref-presence-statuses-lookup-table tr.ref-presence-statuses-dragging{opacity:.5}.ref-presence-statuses-lookup-table tr.ref-presence-statuses-dragging td{background:var(--primary-light,#dbeafe)}.ref-presence-statuses-sort-icon{margin-left:8px;color:var(--tx3,#94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.ref-presence-statuses-drag-handle{color:var(--tx3,#94a3b8);cursor:grab;transition:color .2s}.ref-presence-statuses-drag-handle:hover{color:var(--primary,#2563eb)}.ref-presence-statuses-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg,#f8fafc);border-radius:8px;color:var(--tx3,#64748b);font-size:12px;border:1px dashed var(--border,#e2e8f0);margin-bottom:16px}.ref-presence-statuses-drag-hint svg{color:var(--primary,#2563eb)}.ref-presence-statuses-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary,#2563eb);background:var(--primary-light,#dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border,#bfdbfe);display:inline-block;white-space:nowrap}.ref-presence-statuses-type-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.ref-presence-statuses-type-badge svg{width:12px;height:12px}.ref-presence-statuses-badge-blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.ref-presence-statuses-badge-green{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.ref-presence-statuses-badge-purple{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.ref-presence-statuses-badge-amber{background:#fef3c7;color:#b45309;border-color:#fde68a}.ref-presence-statuses-badge-teal{background:#ccfbf1;color:#0f766e;border-color:#99f6e4}.ref-presence-statuses-badge-red{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ref-presence-statuses-badge-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa}.ref-presence-statuses-badge-gray{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.ref-presence-statuses-badge-pink{background:#fce7f3;color:#be185d;border-color:#fbcfe8}.ref-presence-statuses-badge-gold,.ref-presence-statuses-badge-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a}.ref-presence-statuses-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg,#f8fafc);border:1px solid var(--border,#e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2,#475569);padding:0 8px}.ref-presence-statuses-label-cell{font-weight:500;color:var(--tx1,#0f172a)}.ref-presence-statuses-date-info{font-size:12px;color:var(--tx2,#475569);background:var(--bg,#f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.ref-presence-statuses-status-toggle{display:flex;align-items:center;gap:12px}.ref-presence-statuses-status-label{font-size:13px;font-weight:500}.ref-presence-statuses-status-label.ref-presence-statuses-active{color:var(--success,#16a34a)}.ref-presence-statuses-status-label.ref-presence-statuses-inactive{color:var(--danger,#dc2626)}.ref-presence-statuses-modern-switch{position:relative;display:inline-block;cursor:pointer}.ref-presence-statuses-modern-switch.ref-presence-statuses-small input+.ref-presence-statuses-switch-slider{width:40px;height:22px}.ref-presence-statuses-modern-switch.ref-presence-statuses-small input+.ref-presence-statuses-switch-slider .ref-presence-statuses-switch-handle{width:18px;height:18px}.ref-presence-statuses-modern-switch input{opacity:0;width:0;height:0;position:absolute}.ref-presence-statuses-modern-switch .ref-presence-statuses-switch-slider{position:relative;display:block;background:var(--bg-input,#e2e8f0);border:2px solid var(--border,#cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.ref-presence-statuses-modern-switch input:checked+.ref-presence-statuses-switch-slider{background:var(--primary,#2563eb);border-color:var(--primary,#2563eb)}.ref-presence-statuses-modern-switch .ref-presence-statuses-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.ref-presence-statuses-modern-switch input:checked+.ref-presence-statuses-switch-slider .ref-presence-statuses-switch-handle{transform:translate(18px)}.ref-presence-statuses-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.ref-presence-statuses-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-presence-statuses-action-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--primary,#2563eb);border-color:var(--primary,#2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.ref-presence-statuses-action-btn.ref-presence-statuses-danger:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626)}.ref-presence-statuses-action-btn:disabled{opacity:.5;cursor:not-allowed}.ref-presence-statuses-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.ref-presence-statuses-pagination-info{font-size:13px;color:var(--tx3,#64748b)}.ref-presence-statuses-pagination-buttons{display:flex;gap:6px}.ref-presence-statuses-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-presence-statuses-pagination-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);border-color:var(--primary,#2563eb);color:var(--primary,#2563eb);transform:translateY(-1px)}.ref-presence-statuses-pagination-btn.ref-presence-statuses-active{background:var(--primary,#2563eb);color:#fff;border-color:var(--primary,#2563eb)}.ref-presence-statuses-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.ref-presence-statuses-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card,#fff);border-radius:20px;border:2px dashed var(--border,#e2e8f0)}.ref-presence-statuses-empty-icon{color:var(--tx3,#94a3b8);margin-bottom:20px;width:64px;height:64px}.ref-presence-statuses-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1,#0f172a);margin-bottom:8px}.ref-presence-statuses-empty-state p{font-size:14px;color:var(--tx3,#64748b);margin-bottom:24px}.ref-presence-statuses-skeleton-table{background:var(--bg-card,#fff);border-radius:16px;padding:24px}.ref-presence-statuses-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border,#e2e8f0)}.ref-presence-statuses-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg,#f1f5f9) 25%,var(--bg-hover,#e2e8f0) 50%,var(--bg,#f1f5f9) 75%);background-size:200% 100%;animation:ref-presence-statuses-shimmer 1.5s infinite;border-radius:4px}@keyframes ref-presence-statuses-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ref-presence-statuses-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:ref-presence-statuses-modal-fade .2s ease}@keyframes ref-presence-statuses-modal-fade{0%{opacity:0}to{opacity:1}}.ref-presence-statuses-modal{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:ref-presence-statuses-modal-scale .3s ease}@keyframes ref-presence-statuses-modal-scale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ref-presence-statuses-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.ref-presence-statuses-modal-title{font-size:18px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:8px}.ref-presence-statuses-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border,#e2e8f0);background:var(--bg,#f8fafc);color:var(--tx2,#475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.ref-presence-statuses-modal-close-btn:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626);transform:rotate(90deg)}.ref-presence-statuses-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.ref-presence-statuses-modal-body{padding:20px 28px}.ref-presence-statuses-modal-foot{padding:20px 28px;border-top:1px solid var(--border,#e2e8f0);display:flex;justify-content:flex-end;gap:12px}.ref-presence-statuses-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.ref-presence-statuses-form-label{font-size:13px;font-weight:600;color:var(--tx2,#475569);display:flex;align-items:center;gap:8px}.ref-presence-statuses-required{color:var(--danger,#dc2626);margin-left:2px;font-size:14px}.ref-presence-statuses-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb);border-radius:12px;border:1px solid var(--primary-border,#bfdbfe);margin-left:8px}.ref-presence-statuses-form-hint{font-size:11px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-presence-statuses-input,.ref-presence-statuses-input:is(select,textarea){background:var(--bg-input,#fff);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.ref-presence-statuses-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 3px var(--primary-light,#dbeafe)}.ref-presence-statuses-input.ref-presence-statuses-error{border-color:var(--danger,#dc2626);background:var(--danger-light,#fee2e2)}textarea.ref-presence-statuses-input{resize:vertical;min-height:80px}.ref-presence-statuses-error-message{color:var(--danger,#dc2626);font-size:11px;margin-top:4px;display:block}.ref-presence-statuses-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ref-presence-statuses-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;font-family:inherit}.ref-presence-statuses-btn-sm{font-size:12px;padding:8px 14px}.ref-presence-statuses-btn-primary{background:var(--primary,#2563eb);color:#fff}.ref-presence-statuses-btn-primary:hover:not(:disabled){background:var(--primary-hover,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.ref-presence-statuses-btn-ghost{background:transparent;color:var(--tx2,#475569);border:1.5px solid var(--border,#e2e8f0)}.ref-presence-statuses-btn-ghost:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a);border-color:var(--tx2,#475569)}.ref-presence-statuses-btn-danger{background:var(--danger,#dc2626);color:#fff}.ref-presence-statuses-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.ref-presence-statuses-btn:disabled{opacity:.5;cursor:not-allowed}.ref-presence-statuses-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ref-presence-statuses-spin .6s linear infinite;margin-right:6px}@keyframes ref-presence-statuses-spin{to{transform:rotate(360deg)}}.ref-presence-statuses-spin{animation:ref-presence-statuses-spin 1s linear infinite}.ref-presence-statuses-confirm-icon{text-align:center;margin-bottom:16px}.ref-presence-statuses-confirm-message{font-size:14px;color:var(--tx2,#475569);text-align:center;line-height:1.6}.ref-presence-statuses-text-success{color:var(--success,#16a34a)}.ref-presence-statuses-text-danger{color:var(--danger,#dc2626)}.ref-presence-statuses-severity-red{background:#fee2e2;color:#dc2626;border-color:#fecaca;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-presence-statuses-severity-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-presence-statuses-severity-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-presence-statuses-bool-yes{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.ref-presence-statuses-bool-no{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}@media(max-width:1024px){.ref-presence-statuses-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.ref-presence-statuses-page-hdr{flex-direction:column}.ref-presence-statuses-page-actions{width:100%;justify-content:flex-start}.ref-presence-statuses-filters-bar{flex-direction:column;align-items:stretch}.ref-presence-statuses-search-wrapper,.ref-presence-statuses-filter-group,.ref-presence-statuses-filter-select{width:100%}.ref-presence-statuses-stats-grid{grid-template-columns:1fr;gap:16px}.ref-presence-statuses-grid-2{grid-template-columns:1fr}.ref-presence-statuses-pagination{flex-direction:column;align-items:stretch}.ref-presence-statuses-pagination-buttons{justify-content:center}.ref-presence-statuses-modal-hdr,.ref-presence-statuses-modal-body,.ref-presence-statuses-modal-foot{padding:16px 20px}}@media print{.ref-presence-statuses-page-actions,.ref-presence-statuses-filters-bar,.ref-presence-statuses-action-buttons,.ref-presence-statuses-status-toggle,.ref-presence-statuses-drag-handle,.ref-presence-statuses-drag-hint,.ref-presence-statuses-toast-container,.ref-presence-statuses-modal-bg{display:none!important}.ref-presence-statuses-card{box-shadow:none;border:1px solid #000}}.ref-visitor-id-types-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.ref-visitor-id-types-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card,#fff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:ref-visitor-id-types-toast-in .3s ease;border-left:4px solid var(--primary,#2563eb)}.ref-visitor-id-types-toast-success{border-left-color:var(--success,#16a34a)}.ref-visitor-id-types-toast-error{border-left-color:var(--danger,#dc2626)}.ref-visitor-id-types-toast-warning{border-left-color:var(--warning,#d97706)}.ref-visitor-id-types-toast-info{border-left-color:var(--primary,#2563eb)}.ref-visitor-id-types-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.ref-visitor-id-types-toast-success .ref-visitor-id-types-toast-icon{color:var(--success,#16a34a)}.ref-visitor-id-types-toast-error .ref-visitor-id-types-toast-icon{color:var(--danger,#dc2626)}.ref-visitor-id-types-toast-warning .ref-visitor-id-types-toast-icon{color:var(--warning,#d97706)}.ref-visitor-id-types-toast-info .ref-visitor-id-types-toast-icon{color:var(--primary,#2563eb)}.ref-visitor-id-types-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1,#0f172a);line-height:1.5}.ref-visitor-id-types-toast-close{background:none;border:none;color:var(--tx3,#94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s}.ref-visitor-id-types-toast-close:hover{background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a)}@keyframes ref-visitor-id-types-toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ref-visitor-id-types-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.ref-visitor-id-types-page-title{font-size:24px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:12px}.ref-visitor-id-types-page-subtitle{font-size:14px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-visitor-id-types-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-visitor-id-types-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.ref-visitor-id-types-stats-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.ref-visitor-id-types-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.ref-visitor-id-types-stats-primary{border-left:4px solid var(--primary,#2563eb)}.ref-visitor-id-types-stats-success{border-left:4px solid var(--success,#16a34a)}.ref-visitor-id-types-stats-warning{border-left:4px solid var(--warning,#d97706)}.ref-visitor-id-types-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.ref-visitor-id-types-stats-primary .ref-visitor-id-types-stats-icon{background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb)}.ref-visitor-id-types-stats-success .ref-visitor-id-types-stats-icon{background:var(--success-light,#dcfce7);color:var(--success,#16a34a)}.ref-visitor-id-types-stats-warning .ref-visitor-id-types-stats-icon{background:var(--warning-light,#fef3c7);color:var(--warning,#d97706)}.ref-visitor-id-types-stats-content{flex:1}.ref-visitor-id-types-stats-title{font-size:13px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.ref-visitor-id-types-stats-value{font-size:30px;font-weight:700;color:var(--tx1,#0f172a);line-height:1.2}.ref-visitor-id-types-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card,#fff);padding:16px 20px;border-radius:12px;border:1px solid var(--border,#e2e8f0);box-shadow:0 2px 6px #00000005}.ref-visitor-id-types-search-wrapper{position:relative;flex:1;min-width:280px}.ref-visitor-id-types-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3,#94a3b8);pointer-events:none}.ref-visitor-id-types-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;outline:none;transition:all .2s}.ref-visitor-id-types-search-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-visitor-id-types-search-input::placeholder{color:var(--tx3,#94a3b8)}.ref-visitor-id-types-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-visitor-id-types-filter-select{padding:10px 14px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.ref-visitor-id-types-filter-select:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-visitor-id-types-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.ref-visitor-id-types-card:hover{box-shadow:0 8px 24px #00000014}.ref-visitor-id-types-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.ref-visitor-id-types-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.ref-visitor-id-types-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg,#f8fafc);white-space:nowrap;border-bottom:2px solid var(--border,#e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.ref-visitor-id-types-lookup-table th:hover{background:var(--bg-hover,#e2e8f0);color:var(--tx1,#0f172a)}.ref-visitor-id-types-lookup-table td{padding:16px;font-size:14px;color:var(--tx2,#475569);border-bottom:1px solid var(--border,#e2e8f0);vertical-align:middle;background:var(--bg-card,#fff);transition:background-color .2s}.ref-visitor-id-types-lookup-table tr:hover td{background:var(--bg-hover,#f1f5f9)}.ref-visitor-id-types-lookup-table tr.ref-visitor-id-types-dragging{opacity:.5}.ref-visitor-id-types-lookup-table tr.ref-visitor-id-types-dragging td{background:var(--primary-light,#dbeafe)}.ref-visitor-id-types-sort-icon{margin-left:8px;color:var(--tx3,#94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.ref-visitor-id-types-drag-handle{color:var(--tx3,#94a3b8);cursor:grab;transition:color .2s}.ref-visitor-id-types-drag-handle:hover{color:var(--primary,#2563eb)}.ref-visitor-id-types-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg,#f8fafc);border-radius:8px;color:var(--tx3,#64748b);font-size:12px;border:1px dashed var(--border,#e2e8f0);margin-bottom:16px}.ref-visitor-id-types-drag-hint svg{color:var(--primary,#2563eb)}.ref-visitor-id-types-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary,#2563eb);background:var(--primary-light,#dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border,#bfdbfe);display:inline-block;white-space:nowrap}.ref-visitor-id-types-type-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.ref-visitor-id-types-type-badge svg{width:12px;height:12px}.ref-visitor-id-types-badge-blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.ref-visitor-id-types-badge-green{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.ref-visitor-id-types-badge-purple{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.ref-visitor-id-types-badge-amber{background:#fef3c7;color:#b45309;border-color:#fde68a}.ref-visitor-id-types-badge-teal{background:#ccfbf1;color:#0f766e;border-color:#99f6e4}.ref-visitor-id-types-badge-red{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ref-visitor-id-types-badge-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa}.ref-visitor-id-types-badge-gray{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.ref-visitor-id-types-badge-pink{background:#fce7f3;color:#be185d;border-color:#fbcfe8}.ref-visitor-id-types-badge-gold,.ref-visitor-id-types-badge-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a}.ref-visitor-id-types-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg,#f8fafc);border:1px solid var(--border,#e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2,#475569);padding:0 8px}.ref-visitor-id-types-label-cell{font-weight:500;color:var(--tx1,#0f172a)}.ref-visitor-id-types-date-info{font-size:12px;color:var(--tx2,#475569);background:var(--bg,#f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.ref-visitor-id-types-status-toggle{display:flex;align-items:center;gap:12px}.ref-visitor-id-types-status-label{font-size:13px;font-weight:500}.ref-visitor-id-types-status-label.ref-visitor-id-types-active{color:var(--success,#16a34a)}.ref-visitor-id-types-status-label.ref-visitor-id-types-inactive{color:var(--danger,#dc2626)}.ref-visitor-id-types-modern-switch{position:relative;display:inline-block;cursor:pointer}.ref-visitor-id-types-modern-switch.ref-visitor-id-types-small input+.ref-visitor-id-types-switch-slider{width:40px;height:22px}.ref-visitor-id-types-modern-switch.ref-visitor-id-types-small input+.ref-visitor-id-types-switch-slider .ref-visitor-id-types-switch-handle{width:18px;height:18px}.ref-visitor-id-types-modern-switch input{opacity:0;width:0;height:0;position:absolute}.ref-visitor-id-types-modern-switch .ref-visitor-id-types-switch-slider{position:relative;display:block;background:var(--bg-input,#e2e8f0);border:2px solid var(--border,#cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.ref-visitor-id-types-modern-switch input:checked+.ref-visitor-id-types-switch-slider{background:var(--primary,#2563eb);border-color:var(--primary,#2563eb)}.ref-visitor-id-types-modern-switch .ref-visitor-id-types-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.ref-visitor-id-types-modern-switch input:checked+.ref-visitor-id-types-switch-slider .ref-visitor-id-types-switch-handle{transform:translate(18px)}.ref-visitor-id-types-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.ref-visitor-id-types-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-visitor-id-types-action-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--primary,#2563eb);border-color:var(--primary,#2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.ref-visitor-id-types-action-btn.ref-visitor-id-types-danger:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626)}.ref-visitor-id-types-action-btn:disabled{opacity:.5;cursor:not-allowed}.ref-visitor-id-types-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.ref-visitor-id-types-pagination-info{font-size:13px;color:var(--tx3,#64748b)}.ref-visitor-id-types-pagination-buttons{display:flex;gap:6px}.ref-visitor-id-types-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-visitor-id-types-pagination-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);border-color:var(--primary,#2563eb);color:var(--primary,#2563eb);transform:translateY(-1px)}.ref-visitor-id-types-pagination-btn.ref-visitor-id-types-active{background:var(--primary,#2563eb);color:#fff;border-color:var(--primary,#2563eb)}.ref-visitor-id-types-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.ref-visitor-id-types-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card,#fff);border-radius:20px;border:2px dashed var(--border,#e2e8f0)}.ref-visitor-id-types-empty-icon{color:var(--tx3,#94a3b8);margin-bottom:20px;width:64px;height:64px}.ref-visitor-id-types-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1,#0f172a);margin-bottom:8px}.ref-visitor-id-types-empty-state p{font-size:14px;color:var(--tx3,#64748b);margin-bottom:24px}.ref-visitor-id-types-skeleton-table{background:var(--bg-card,#fff);border-radius:16px;padding:24px}.ref-visitor-id-types-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border,#e2e8f0)}.ref-visitor-id-types-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg,#f1f5f9) 25%,var(--bg-hover,#e2e8f0) 50%,var(--bg,#f1f5f9) 75%);background-size:200% 100%;animation:ref-visitor-id-types-shimmer 1.5s infinite;border-radius:4px}@keyframes ref-visitor-id-types-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ref-visitor-id-types-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:ref-visitor-id-types-modal-fade .2s ease}@keyframes ref-visitor-id-types-modal-fade{0%{opacity:0}to{opacity:1}}.ref-visitor-id-types-modal{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:ref-visitor-id-types-modal-scale .3s ease}@keyframes ref-visitor-id-types-modal-scale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ref-visitor-id-types-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.ref-visitor-id-types-modal-title{font-size:18px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:8px}.ref-visitor-id-types-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border,#e2e8f0);background:var(--bg,#f8fafc);color:var(--tx2,#475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.ref-visitor-id-types-modal-close-btn:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626);transform:rotate(90deg)}.ref-visitor-id-types-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.ref-visitor-id-types-modal-body{padding:20px 28px}.ref-visitor-id-types-modal-foot{padding:20px 28px;border-top:1px solid var(--border,#e2e8f0);display:flex;justify-content:flex-end;gap:12px}.ref-visitor-id-types-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.ref-visitor-id-types-form-label{font-size:13px;font-weight:600;color:var(--tx2,#475569);display:flex;align-items:center;gap:8px}.ref-visitor-id-types-required{color:var(--danger,#dc2626);margin-left:2px;font-size:14px}.ref-visitor-id-types-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb);border-radius:12px;border:1px solid var(--primary-border,#bfdbfe);margin-left:8px}.ref-visitor-id-types-form-hint{font-size:11px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-visitor-id-types-input,.ref-visitor-id-types-input:is(select,textarea){background:var(--bg-input,#fff);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.ref-visitor-id-types-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 3px var(--primary-light,#dbeafe)}.ref-visitor-id-types-input.ref-visitor-id-types-error{border-color:var(--danger,#dc2626);background:var(--danger-light,#fee2e2)}textarea.ref-visitor-id-types-input{resize:vertical;min-height:80px}.ref-visitor-id-types-error-message{color:var(--danger,#dc2626);font-size:11px;margin-top:4px;display:block}.ref-visitor-id-types-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ref-visitor-id-types-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;font-family:inherit}.ref-visitor-id-types-btn-sm{font-size:12px;padding:8px 14px}.ref-visitor-id-types-btn-primary{background:var(--primary,#2563eb);color:#fff}.ref-visitor-id-types-btn-primary:hover:not(:disabled){background:var(--primary-hover,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.ref-visitor-id-types-btn-ghost{background:transparent;color:var(--tx2,#475569);border:1.5px solid var(--border,#e2e8f0)}.ref-visitor-id-types-btn-ghost:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a);border-color:var(--tx2,#475569)}.ref-visitor-id-types-btn-danger{background:var(--danger,#dc2626);color:#fff}.ref-visitor-id-types-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.ref-visitor-id-types-btn:disabled{opacity:.5;cursor:not-allowed}.ref-visitor-id-types-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ref-visitor-id-types-spin .6s linear infinite;margin-right:6px}@keyframes ref-visitor-id-types-spin{to{transform:rotate(360deg)}}.ref-visitor-id-types-spin{animation:ref-visitor-id-types-spin 1s linear infinite}.ref-visitor-id-types-confirm-icon{text-align:center;margin-bottom:16px}.ref-visitor-id-types-confirm-message{font-size:14px;color:var(--tx2,#475569);text-align:center;line-height:1.6}.ref-visitor-id-types-text-success{color:var(--success,#16a34a)}.ref-visitor-id-types-text-danger{color:var(--danger,#dc2626)}.ref-visitor-id-types-severity-red{background:#fee2e2;color:#dc2626;border-color:#fecaca;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-visitor-id-types-severity-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-visitor-id-types-severity-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-visitor-id-types-bool-yes{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.ref-visitor-id-types-bool-no{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}@media(max-width:1024px){.ref-visitor-id-types-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.ref-visitor-id-types-page-hdr{flex-direction:column}.ref-visitor-id-types-page-actions{width:100%;justify-content:flex-start}.ref-visitor-id-types-filters-bar{flex-direction:column;align-items:stretch}.ref-visitor-id-types-search-wrapper,.ref-visitor-id-types-filter-group,.ref-visitor-id-types-filter-select{width:100%}.ref-visitor-id-types-stats-grid{grid-template-columns:1fr;gap:16px}.ref-visitor-id-types-grid-2{grid-template-columns:1fr}.ref-visitor-id-types-pagination{flex-direction:column;align-items:stretch}.ref-visitor-id-types-pagination-buttons{justify-content:center}.ref-visitor-id-types-modal-hdr,.ref-visitor-id-types-modal-body,.ref-visitor-id-types-modal-foot{padding:16px 20px}}@media print{.ref-visitor-id-types-page-actions,.ref-visitor-id-types-filters-bar,.ref-visitor-id-types-action-buttons,.ref-visitor-id-types-status-toggle,.ref-visitor-id-types-drag-handle,.ref-visitor-id-types-drag-hint,.ref-visitor-id-types-toast-container,.ref-visitor-id-types-modal-bg{display:none!important}.ref-visitor-id-types-card{box-shadow:none;border:1px solid #000}}.ref-visit-types-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.ref-visit-types-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card,#fff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:ref-visit-types-toast-in .3s ease;border-left:4px solid var(--primary,#2563eb)}.ref-visit-types-toast-success{border-left-color:var(--success,#16a34a)}.ref-visit-types-toast-error{border-left-color:var(--danger,#dc2626)}.ref-visit-types-toast-warning{border-left-color:var(--warning,#d97706)}.ref-visit-types-toast-info{border-left-color:var(--primary,#2563eb)}.ref-visit-types-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.ref-visit-types-toast-success .ref-visit-types-toast-icon{color:var(--success,#16a34a)}.ref-visit-types-toast-error .ref-visit-types-toast-icon{color:var(--danger,#dc2626)}.ref-visit-types-toast-warning .ref-visit-types-toast-icon{color:var(--warning,#d97706)}.ref-visit-types-toast-info .ref-visit-types-toast-icon{color:var(--primary,#2563eb)}.ref-visit-types-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1,#0f172a);line-height:1.5}.ref-visit-types-toast-close{background:none;border:none;color:var(--tx3,#94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s}.ref-visit-types-toast-close:hover{background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a)}@keyframes ref-visit-types-toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ref-visit-types-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.ref-visit-types-page-title{font-size:24px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:12px}.ref-visit-types-page-subtitle{font-size:14px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-visit-types-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-visit-types-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.ref-visit-types-stats-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px 20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.ref-visit-types-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.ref-visit-types-stats-primary{border-left:4px solid var(--primary,#2563eb)}.ref-visit-types-stats-success{border-left:4px solid var(--success,#16a34a)}.ref-visit-types-stats-warning{border-left:4px solid var(--warning,#d97706)}.ref-visit-types-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.ref-visit-types-stats-primary .ref-visit-types-stats-icon{background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb)}.ref-visit-types-stats-success .ref-visit-types-stats-icon{background:var(--success-light,#dcfce7);color:var(--success,#16a34a)}.ref-visit-types-stats-warning .ref-visit-types-stats-icon{background:var(--warning-light,#fef3c7);color:var(--warning,#d97706)}.ref-visit-types-stats-content{flex:1}.ref-visit-types-stats-title{font-size:13px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.ref-visit-types-stats-value{font-size:30px;font-weight:700;color:var(--tx1,#0f172a);line-height:1.2}.ref-visit-types-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card,#fff);padding:16px 20px;border-radius:12px;border:1px solid var(--border,#e2e8f0);box-shadow:0 2px 6px #00000005}.ref-visit-types-search-wrapper{position:relative;flex:1;min-width:280px}.ref-visit-types-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3,#94a3b8);pointer-events:none}.ref-visit-types-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;outline:none;transition:all .2s}.ref-visit-types-search-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-visit-types-search-input::placeholder{color:var(--tx3,#94a3b8)}.ref-visit-types-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ref-visit-types-filter-select{padding:10px 14px;background:var(--bg-input,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.ref-visit-types-filter-select:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 4px var(--primary-light,#dbeafe)}.ref-visit-types-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.ref-visit-types-card:hover{box-shadow:0 8px 24px #00000014}.ref-visit-types-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.ref-visit-types-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.ref-visit-types-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3,#64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg,#f8fafc);white-space:nowrap;border-bottom:2px solid var(--border,#e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.ref-visit-types-lookup-table th:hover{background:var(--bg-hover,#e2e8f0);color:var(--tx1,#0f172a)}.ref-visit-types-lookup-table td{padding:16px;font-size:14px;color:var(--tx2,#475569);border-bottom:1px solid var(--border,#e2e8f0);vertical-align:middle;background:var(--bg-card,#fff);transition:background-color .2s}.ref-visit-types-lookup-table tr:hover td{background:var(--bg-hover,#f1f5f9)}.ref-visit-types-lookup-table tr.ref-visit-types-dragging{opacity:.5}.ref-visit-types-lookup-table tr.ref-visit-types-dragging td{background:var(--primary-light,#dbeafe)}.ref-visit-types-sort-icon{margin-left:8px;color:var(--tx3,#94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.ref-visit-types-drag-handle{color:var(--tx3,#94a3b8);cursor:grab;transition:color .2s}.ref-visit-types-drag-handle:hover{color:var(--primary,#2563eb)}.ref-visit-types-drag-hint{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg,#f8fafc);border-radius:8px;color:var(--tx3,#64748b);font-size:12px;border:1px dashed var(--border,#e2e8f0);margin-bottom:16px}.ref-visit-types-drag-hint svg{color:var(--primary,#2563eb)}.ref-visit-types-code-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:var(--primary,#2563eb);background:var(--primary-light,#dbeafe);padding:4px 8px;border-radius:6px;border:1px solid var(--primary-border,#bfdbfe);display:inline-block;white-space:nowrap}.ref-visit-types-type-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.ref-visit-types-type-badge svg{width:12px;height:12px}.ref-visit-types-badge-blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.ref-visit-types-badge-green{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.ref-visit-types-badge-purple{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.ref-visit-types-badge-amber{background:#fef3c7;color:#b45309;border-color:#fde68a}.ref-visit-types-badge-teal{background:#ccfbf1;color:#0f766e;border-color:#99f6e4}.ref-visit-types-badge-red{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ref-visit-types-badge-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa}.ref-visit-types-badge-gray{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.ref-visit-types-badge-pink{background:#fce7f3;color:#be185d;border-color:#fbcfe8}.ref-visit-types-badge-gold,.ref-visit-types-badge-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a}.ref-visit-types-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg,#f8fafc);border:1px solid var(--border,#e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2,#475569);padding:0 8px}.ref-visit-types-label-cell{font-weight:500;color:var(--tx1,#0f172a)}.ref-visit-types-date-info{font-size:12px;color:var(--tx2,#475569);background:var(--bg,#f8fafc);padding:4px 8px;border-radius:6px;display:inline-block;white-space:nowrap}.ref-visit-types-status-toggle{display:flex;align-items:center;gap:12px}.ref-visit-types-status-label{font-size:13px;font-weight:500}.ref-visit-types-status-label.ref-visit-types-active{color:var(--success,#16a34a)}.ref-visit-types-status-label.ref-visit-types-inactive{color:var(--danger,#dc2626)}.ref-visit-types-modern-switch{position:relative;display:inline-block;cursor:pointer}.ref-visit-types-modern-switch.ref-visit-types-small input+.ref-visit-types-switch-slider{width:40px;height:22px}.ref-visit-types-modern-switch.ref-visit-types-small input+.ref-visit-types-switch-slider .ref-visit-types-switch-handle{width:18px;height:18px}.ref-visit-types-modern-switch input{opacity:0;width:0;height:0;position:absolute}.ref-visit-types-modern-switch .ref-visit-types-switch-slider{position:relative;display:block;background:var(--bg-input,#e2e8f0);border:2px solid var(--border,#cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.ref-visit-types-modern-switch input:checked+.ref-visit-types-switch-slider{background:var(--primary,#2563eb);border-color:var(--primary,#2563eb)}.ref-visit-types-modern-switch .ref-visit-types-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.ref-visit-types-modern-switch input:checked+.ref-visit-types-switch-slider .ref-visit-types-switch-handle{transform:translate(18px)}.ref-visit-types-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.ref-visit-types-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-visit-types-action-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--primary,#2563eb);border-color:var(--primary,#2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.ref-visit-types-action-btn.ref-visit-types-danger:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626)}.ref-visit-types-action-btn:disabled{opacity:.5;cursor:not-allowed}.ref-visit-types-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.ref-visit-types-pagination-info{font-size:13px;color:var(--tx3,#64748b)}.ref-visit-types-pagination-buttons{display:flex;gap:6px}.ref-visit-types-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--tx2,#475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ref-visit-types-pagination-btn:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);border-color:var(--primary,#2563eb);color:var(--primary,#2563eb);transform:translateY(-1px)}.ref-visit-types-pagination-btn.ref-visit-types-active{background:var(--primary,#2563eb);color:#fff;border-color:var(--primary,#2563eb)}.ref-visit-types-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.ref-visit-types-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card,#fff);border-radius:20px;border:2px dashed var(--border,#e2e8f0)}.ref-visit-types-empty-icon{color:var(--tx3,#94a3b8);margin-bottom:20px;width:64px;height:64px}.ref-visit-types-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1,#0f172a);margin-bottom:8px}.ref-visit-types-empty-state p{font-size:14px;color:var(--tx3,#64748b);margin-bottom:24px}.ref-visit-types-skeleton-table{background:var(--bg-card,#fff);border-radius:16px;padding:24px}.ref-visit-types-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border,#e2e8f0)}.ref-visit-types-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg,#f1f5f9) 25%,var(--bg-hover,#e2e8f0) 50%,var(--bg,#f1f5f9) 75%);background-size:200% 100%;animation:ref-visit-types-shimmer 1.5s infinite;border-radius:4px}@keyframes ref-visit-types-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ref-visit-types-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:ref-visit-types-modal-fade .2s ease}@keyframes ref-visit-types-modal-fade{0%{opacity:0}to{opacity:1}}.ref-visit-types-modal{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:ref-visit-types-modal-scale .3s ease}@keyframes ref-visit-types-modal-scale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ref-visit-types-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.ref-visit-types-modal-title{font-size:18px;font-weight:700;color:var(--tx1,#0f172a);display:flex;align-items:center;gap:8px}.ref-visit-types-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border,#e2e8f0);background:var(--bg,#f8fafc);color:var(--tx2,#475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.ref-visit-types-modal-close-btn:hover:not(:disabled){background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626);transform:rotate(90deg)}.ref-visit-types-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.ref-visit-types-modal-body{padding:20px 28px}.ref-visit-types-modal-foot{padding:20px 28px;border-top:1px solid var(--border,#e2e8f0);display:flex;justify-content:flex-end;gap:12px}.ref-visit-types-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.ref-visit-types-form-label{font-size:13px;font-weight:600;color:var(--tx2,#475569);display:flex;align-items:center;gap:8px}.ref-visit-types-required{color:var(--danger,#dc2626);margin-left:2px;font-size:14px}.ref-visit-types-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light,#dbeafe);color:var(--primary,#2563eb);border-radius:12px;border:1px solid var(--primary-border,#bfdbfe);margin-left:8px}.ref-visit-types-form-hint{font-size:11px;color:var(--tx3,#64748b);margin-top:4px;line-height:1.5}.ref-visit-types-input,.ref-visit-types-input:is(select,textarea){background:var(--bg-input,#fff);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;color:var(--tx1,#0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.ref-visit-types-input:focus{border-color:var(--primary,#2563eb);box-shadow:0 0 0 3px var(--primary-light,#dbeafe)}.ref-visit-types-input.ref-visit-types-error{border-color:var(--danger,#dc2626);background:var(--danger-light,#fee2e2)}textarea.ref-visit-types-input{resize:vertical;min-height:80px}.ref-visit-types-error-message{color:var(--danger,#dc2626);font-size:11px;margin-top:4px;display:block}.ref-visit-types-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ref-visit-types-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;font-family:inherit}.ref-visit-types-btn-sm{font-size:12px;padding:8px 14px}.ref-visit-types-btn-primary{background:var(--primary,#2563eb);color:#fff}.ref-visit-types-btn-primary:hover:not(:disabled){background:var(--primary-hover,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.ref-visit-types-btn-ghost{background:transparent;color:var(--tx2,#475569);border:1.5px solid var(--border,#e2e8f0)}.ref-visit-types-btn-ghost:hover:not(:disabled){background:var(--bg-hover,#f1f5f9);color:var(--tx1,#0f172a);border-color:var(--tx2,#475569)}.ref-visit-types-btn-danger{background:var(--danger,#dc2626);color:#fff}.ref-visit-types-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.ref-visit-types-btn:disabled{opacity:.5;cursor:not-allowed}.ref-visit-types-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ref-visit-types-spin .6s linear infinite;margin-right:6px}@keyframes ref-visit-types-spin{to{transform:rotate(360deg)}}.ref-visit-types-spin{animation:ref-visit-types-spin 1s linear infinite}.ref-visit-types-confirm-icon{text-align:center;margin-bottom:16px}.ref-visit-types-confirm-message{font-size:14px;color:var(--tx2,#475569);text-align:center;line-height:1.6}.ref-visit-types-text-success{color:var(--success,#16a34a)}.ref-visit-types-text-danger{color:var(--danger,#dc2626)}.ref-visit-types-severity-red{background:#fee2e2;color:#dc2626;border-color:#fecaca;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-visit-types-severity-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-visit-types-severity-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;display:inline-flex;align-items:center;gap:4px}.ref-visit-types-bool-yes{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.ref-visit-types-bool-no{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}@media(max-width:1024px){.ref-visit-types-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.ref-visit-types-page-hdr{flex-direction:column}.ref-visit-types-page-actions{width:100%;justify-content:flex-start}.ref-visit-types-filters-bar{flex-direction:column;align-items:stretch}.ref-visit-types-search-wrapper,.ref-visit-types-filter-group,.ref-visit-types-filter-select{width:100%}.ref-visit-types-stats-grid{grid-template-columns:1fr;gap:16px}.ref-visit-types-grid-2{grid-template-columns:1fr}.ref-visit-types-pagination{flex-direction:column;align-items:stretch}.ref-visit-types-pagination-buttons{justify-content:center}.ref-visit-types-modal-hdr,.ref-visit-types-modal-body,.ref-visit-types-modal-foot{padding:16px 20px}}@media print{.ref-visit-types-page-actions,.ref-visit-types-filters-bar,.ref-visit-types-action-buttons,.ref-visit-types-status-toggle,.ref-visit-types-drag-handle,.ref-visit-types-drag-hint,.ref-visit-types-toast-container,.ref-visit-types-modal-bg{display:none!important}.ref-visit-types-card{box-shadow:none;border:1px solid #000}}.sg-toast-wrap{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.sg-toast{display:flex;align-items:center;gap:11px;padding:13px 16px;background:#fff;border-radius:12px;box-shadow:0 8px 30px #0f172a24,0 1px 4px #0f172a0f;min-width:300px;max-width:400px;border-left:3.5px solid #2563eb;animation:sg-toast-slide .28s cubic-bezier(.4,0,.2,1);font-family:Plus Jakarta Sans,system-ui,sans-serif}.sg-toast--success{border-left-color:#16a34a}.sg-toast--error{border-left-color:#dc2626}.sg-toast--warning{border-left-color:#d97706}.sg-toast__icon{flex-shrink:0;display:flex}.sg-toast--success .sg-toast__icon{color:#16a34a}.sg-toast--error .sg-toast__icon{color:#dc2626}.sg-toast--warning .sg-toast__icon{color:#d97706}.sg-toast--info .sg-toast__icon{color:#2563eb}.sg-toast__msg{flex:1;font-size:13px;font-weight:500;color:#0f172a;line-height:1.45}.sg-toast__x{background:none;border:none;color:#94a3b8;cursor:pointer;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s}.sg-toast__x:hover{background:#f1f5f9;color:#0f172a}@keyframes sg-toast-slide{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.sg-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap;font-family:Plus Jakarta Sans,system-ui,sans-serif}.sg-page-hdr__left{flex:1}.sg-page-hdr__right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.sg-page-title{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:800;color:#0f172a;letter-spacing:-.5px}.sg-title-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #2563eb4d;flex-shrink:0}.sg-page-sub{font-size:13px;color:#64748b;margin-top:4px;margin-left:48px}.sg-kpi-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:24px}.sg-kpi{position:relative;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:16px 16px 14px 18px;display:flex;align-items:center;gap:13px;overflow:hidden;transition:transform .2s,box-shadow .2s;animation:sg-kpi-in .4s cubic-bezier(.4,0,.2,1) var(--delay, 0ms) both;font-family:Plus Jakarta Sans,system-ui,sans-serif}.sg-kpi:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.sg-kpi__bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent, #2563eb);border-radius:14px 0 0 14px}.sg-kpi__icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sg-kpi__val{font-size:26px;font-weight:800;letter-spacing:-1px;line-height:1;font-family:DM Mono,monospace}.sg-kpi__lbl{font-size:10px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-top:3px}.sg-kpi__sub{font-size:10px;color:#94a3b8;margin-top:2px}@keyframes sg-kpi-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.sg-tab-bar{display:flex;gap:2px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:4px;margin-bottom:22px;overflow-x:auto;scrollbar-width:none}.sg-tab-bar::-webkit-scrollbar{display:none}.sg-tab{position:relative;display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;border:none;background:transparent;color:#64748b;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;font-family:Plus Jakarta Sans,system-ui,sans-serif;flex-shrink:0}.sg-tab:hover:not(.sg-tab--active){background:#fff;color:#0f172a;box-shadow:0 1px 4px #0000000d}.sg-tab--active{background:#fff;color:var(--tc, #2563eb);box-shadow:0 2px 8px #00000014,0 0 0 1px #0000000a}.sg-tab__ind{position:absolute;bottom:0;left:12px;right:12px;height:2px;border-radius:2px;animation:sg-ind-in .2s ease}@keyframes sg-ind-in{0%{transform:scaleX(0);opacity:0}to{transform:scaleX(1);opacity:1}}.sg-tab-body{animation:sg-fade-in .18s ease both;font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes sg-fade-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.sg-fbar{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px 16px;margin-bottom:16px;flex-wrap:wrap}.sg-fbar__search{position:relative;flex:1;min-width:220px;max-width:360px}.sg-fbar__search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.sg-fbar__search-input{width:100%;padding:9px 36px 9px 38px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;color:#0f172a;font-size:13px;outline:none;transition:all .2s;font-family:inherit}.sg-fbar__search-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;background:#fff}.sg-fbar__search-input::placeholder{color:#94a3b8}.sg-fbar__clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:2px;border-radius:4px;transition:all .15s}.sg-fbar__clear:hover{color:#dc2626;background:#fee2e2}.sg-fbar__filters{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.sg-fbar__end{display:flex;gap:8px;align-items:center;margin-left:auto}.sg-sel{padding:7px 11px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;color:#0f172a;font-size:12px;outline:none;cursor:pointer;font-family:inherit;transition:all .2s}.sg-sel:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.sg-chips{display:flex;gap:5px;flex-wrap:wrap}.sg-chip{display:inline-flex;align-items:center;padding:6px 13px;border-radius:20px;border:1.5px solid #e2e8f0;background:#fff;color:#475569;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.sg-chip:hover{border-color:#2563eb;color:#2563eb}.sg-chip--active{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 2px 8px #2563eb40}.sg-count{font-size:12px;color:#94a3b8;font-weight:500}.sg-table-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden;box-shadow:0 2px 12px #0000000a}.sg-table-wrap{overflow-x:auto}.sg-table{width:100%;border-collapse:separate;border-spacing:0}.sg-table thead tr{background:linear-gradient(to bottom,#f8fafc,#f1f5f9)}.sg-table th{padding:12px 14px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:2px solid #e2e8f0;white-space:nowrap;-webkit-user-select:none;user-select:none}.sg-th--sort{cursor:pointer;transition:color .15s}.sg-th--sort:hover{color:#0f172a}.sg-th--sorted{color:#2563eb}.sg-th__inner{display:inline-flex;align-items:center;gap:4px}.sg-th__icon{display:flex;align-items:center;opacity:.6}.sg-th--sorted .sg-th__icon{opacity:1;color:#2563eb}.sg-table td{padding:12px 14px;font-size:13px;color:#475569;border-bottom:1px solid #f1f5f9;vertical-align:middle}.sg-table tr:last-child td{border-bottom:none}.sg-tr{transition:background .12s;animation:sg-row-in .22s ease both}.sg-tr:hover td{background:#f8fafc}@keyframes sg-row-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.sg-table--sm th,.sg-table--sm td{padding:10px 12px}.sg-table-foot{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-top:1px solid #f1f5f9}.sg-person{display:flex;align-items:center;gap:10px}.sg-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;position:relative}.sg-avatar--sm{width:28px;height:28px;font-size:10px}.sg-avatar--lg{width:44px;height:44px;font-size:16px}.sg-avatar__dot{position:absolute;bottom:1px;right:1px;width:9px;height:9px;border-radius:50%;background:#16a34a;border:2px solid #fff}.sg-person__name{font-size:13px;font-weight:700;color:#0f172a;line-height:1.3}.sg-person__sub{font-size:11px;color:#64748b;font-family:DM Mono,monospace;margin-top:1px}.sg-person__email{font-size:11px;color:#94a3b8;margin-top:1px}.sg-cell-text{font-size:13px;color:#0f172a;display:block}.sg-cell-sub{font-size:11px;color:#64748b;font-family:DM Mono,monospace}.sg-role-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.sg-role-badge--admin{background:#ede9fe;color:#5b21b6;border-color:#ddd6fe}.sg-role-badge--supervisor{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.sg-role-badge--receptionist{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.sg-role-badge--other{background:#f1f5f9;color:#475569;border-color:#e2e8f0}.sg-status{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid transparent;white-space:nowrap}.sg-status--active{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.sg-status--inactive{background:#fee2e2;color:#dc2626;border-color:#fecaca}.sg-status--locked{background:#fef3c7;color:#b45309;border-color:#fde68a}.sg-status--online{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.sg-pulse{display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor;animation:sg-pulse-anim 1.6s ease-in-out infinite}@keyframes sg-pulse-anim{0%,to{opacity:1}50%{opacity:.35}}.sg-evt{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:8px;font-size:11px;font-weight:600;white-space:nowrap}.sg-evt--success{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}.sg-evt--danger{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.sg-evt--neutral{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0}.sg-evt--warning{background:#fef3c7;color:#b45309;border:1px solid #fde68a}.sg-evt--purple{background:#ede9fe;color:#7c3aed;border:1px solid #ddd6fe}.sg-loc-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:12px;color:#475569;white-space:nowrap}.sg-loc-chip svg{color:#2563eb}.sg-perm-row{display:flex;flex-wrap:wrap;gap:5px}.sg-perm-pip{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:6px;font-size:10px;font-weight:600;white-space:nowrap}.sg-perm-pip--on{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}.sg-perm-pip--off{background:#f3f4f6;color:#9ca3af;border:1px solid #e5e7eb}.sg-code{font-family:DM Mono,monospace;font-size:11px;font-weight:500;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 8px;border-radius:6px;color:#0f172a}.sg-ip{font-family:DM Mono,monospace;font-size:11px;background:#f8fafc;border:1px solid #e2e8f0;padding:2px 7px;border-radius:5px;color:#475569}.sg-mono{font-size:12px;font-family:DM Mono,monospace;color:#475569;white-space:nowrap}.sg-muted{color:#94a3b8}.sg-acts{display:flex;align-items:center;gap:5px;justify-content:flex-end}.sg-act{width:32px;height:32px;border-radius:8px;border:1.5px solid #e2e8f0;background:#fff;color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .16s;flex-shrink:0}.sg-act:hover:not(:disabled){background:#eff6ff;color:#2563eb;border-color:#2563eb;transform:translateY(-1px);box-shadow:0 3px 8px #2563eb2e}.sg-act--red:hover:not(:disabled){background:#fee2e2;color:#dc2626;border-color:#dc2626;box-shadow:0 3px 8px #dc26262e}.sg-act--warn:hover:not(:disabled){background:#fef3c7;color:#b45309;border-color:#fde68a;box-shadow:none}.sg-act--ok:hover:not(:disabled){background:#dcfce7;color:#16a34a;border-color:#bbf7d0;box-shadow:none}.sg-act:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.sg-pager{display:flex;gap:4px}.sg-pager__btn{width:32px;height:32px;border-radius:8px;border:1.5px solid #e2e8f0;background:#fff;color:#475569;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit}.sg-pager__btn:hover:not(:disabled){background:#f1f5f9;border-color:#2563eb;color:#2563eb}.sg-pager__btn--active{background:#2563eb!important;color:#fff!important;border-color:#2563eb!important;box-shadow:0 2px 8px #2563eb4d}.sg-pager__btn--dots{cursor:default;border-color:transparent;background:none}.sg-pager__btn:disabled{opacity:.4;cursor:not-allowed}.sg-skel{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:16px 20px}.sg-skel__row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid #f1f5f9;animation:sg-row-in .25s ease both}.sg-skel__row:last-child{border-bottom:none}.sg-skel__circle{width:36px;height:36px;border-radius:50%;flex-shrink:0;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:sg-shimmer 1.4s linear infinite}.sg-skel__bar{height:11px;border-radius:5px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:sg-shimmer 1.4s linear infinite}.sg-skel__bar--lg{flex:1;max-width:200px}.sg-skel__bar--md{width:100px}.sg-skel__bar--sm{width:70px}@keyframes sg-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sg-empty{text-align:center;padding:64px 24px;background:#fff;border:2px dashed #e2e8f0;border-radius:16px}.sg-empty__ring{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);display:flex;align-items:center;justify-content:center;color:#94a3b8;margin:0 auto 20px}.sg-empty__title{font-size:16px;font-weight:700;color:#0f172a;margin-bottom:6px}.sg-empty__body{font-size:13px;color:#64748b;margin-bottom:20px;line-height:1.6;max-width:360px;margin-left:auto;margin-right:auto}.sg-overlay{position:fixed;inset:0;background:#00000085;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:sg-ovl-in .2s ease;font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes sg-ovl-in{0%{opacity:0}to{opacity:1}}.sg-modal{background:#fff;border-radius:20px;box-shadow:0 32px 64px -20px #00000061,0 0 0 1px #0000000a;width:100%;max-height:92vh;overflow-y:auto;animation:sg-modal-in .22s cubic-bezier(.4,0,.2,1)}.sg-modal--lg{max-width:660px}.sg-modal--md{max-width:540px}.sg-modal--sm{max-width:420px}.sg-modal--center{padding:32px;display:flex;flex-direction:column;align-items:center}@keyframes sg-modal-in{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:none}}.sg-modal__hdr{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 16px;border-bottom:1px solid #f1f5f9;gap:12px}.sg-modal__hdr-left{display:flex;align-items:center;gap:12px}.sg-modal__hdr-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 3px 10px #2563eb40;flex-shrink:0}.sg-modal__title{font-size:16px;font-weight:800;color:#0f172a;letter-spacing:-.2px}.sg-modal__sub{font-size:12px;color:#64748b;margin-top:1px}.sg-modal__close{width:32px;height:32px;border-radius:50%;border:1.5px solid #e2e8f0;background:#f8fafc;color:#475569;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.sg-modal__close:hover:not(:disabled){background:#fee2e2;color:#dc2626;border-color:#dc2626;transform:rotate(90deg)}.sg-modal__close:disabled{opacity:.5;cursor:not-allowed}.sg-modal__body{padding:20px 24px}.sg-modal__foot{padding:14px 24px;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.sg-modal__foot--center{justify-content:center}.sg-steps{display:flex;align-items:center;padding:14px 24px 0;border-bottom:1px solid #f1f5f9}.sg-step{display:flex;align-items:center;gap:8px;flex:1}.sg-step:last-child{flex:0}.sg-step__dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;background:#f1f5f9;color:#94a3b8;border:2px solid #e2e8f0;transition:all .25s}.sg-step--active .sg-step__dot{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 2px 8px #2563eb4d}.sg-step--done .sg-step__dot{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.sg-step__lbl{font-size:11px;font-weight:600;color:#94a3b8;white-space:nowrap;transition:color .2s}.sg-step--active .sg-step__lbl{color:#2563eb}.sg-step--done .sg-step__lbl{color:#16a34a}.sg-step__line{flex:1;height:1px;background:#e2e8f0;margin:0 8px}.sg-step--done~.sg-step .sg-step__line{background:#bbf7d0}.sg-form-step{min-height:260px}.sg-form-grid{display:grid;gap:14px;margin-bottom:4px}.sg-form-grid--2{grid-template-columns:1fr 1fr}.sg-form-grid--3{grid-template-columns:1fr 1fr 1fr}.sg-fg{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.sg-fg>label{font-size:12px;font-weight:700;color:#475569;display:flex;align-items:center;gap:5px}.sg-req{color:#dc2626}.sg-opt{font-size:10px;font-weight:500;color:#94a3b8;background:#f1f5f9;padding:1px 6px;border-radius:6px;border:1px solid #e2e8f0;margin-left:4px}.sg-hint{font-size:11px;color:#64748b;line-height:1.5}.sg-err{font-size:11px;color:#dc2626;font-weight:600}.sg-input{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;color:#0f172a;font-size:13px;padding:10px 13px;outline:none;width:100%;transition:all .2s;font-family:inherit}.sg-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.sg-input--err{border-color:#dc2626;background:#fff5f5}.sg-input:disabled{opacity:.6;cursor:not-allowed;background:#f8fafc}select.sg-input{cursor:pointer}.sg-input--mono{font-family:DM Mono,monospace;letter-spacing:.03em}.sg-input-wrap,.sg-input-wrap--right{position:relative}.sg-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.sg-input--icon{padding-left:38px}.sg-input--pr{padding-right:42px}.sg-pw-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;transition:color .15s}.sg-pw-eye:hover{color:#2563eb}.sg-pw-strength{display:flex;align-items:center;gap:4px;margin-top:6px}.sg-pw-bar{flex:1;height:3px;border-radius:2px;transition:background .3s}.sg-pw-match{display:flex;align-items:center;gap:4px;font-size:11px;color:#16a34a;font-weight:600;margin-top:4px}.sg-info-strip{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:9px;color:#1d4ed8;font-size:12px;margin-bottom:16px}.sg-role-preview{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px;margin-bottom:14px}.sg-role-preview__hdr{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px}.sg-role-preview__hdr svg{color:#2563eb}.sg-role-preview__perms{display:flex;flex-wrap:wrap;gap:6px}.sg-switch-row{display:flex;align-items:center;gap:10px}.sg-switch-lbl--on{font-size:13px;font-weight:600;color:#16a34a}.sg-switch-lbl--off{font-size:13px;font-weight:600;color:#dc2626}.sg-switch{position:relative;cursor:pointer;display:inline-block}.sg-switch input{opacity:0;width:0;height:0;position:absolute}.sg-switch__track{display:block;width:44px;height:24px;background:#e2e8f0;border:2px solid #cbd5e1;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.sg-switch input:checked~.sg-switch__track{background:#2563eb;border-color:#2563eb}.sg-switch__knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 4px #0003}.sg-switch input:checked~.sg-switch__track .sg-switch__knob{transform:translate(20px)}.sg-section-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.5px;padding:10px 0;border-bottom:1px solid #e2e8f0;margin-bottom:14px}.sg-section-title svg{color:#2563eb}.sg-perms-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}.sg-perm-card{display:flex;align-items:center;gap:10px;padding:10px 13px;border:1.5px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .2s;background:#fff}.sg-perm-card:hover{border-color:#2563eb;background:#eff6ff}.sg-perm-card--on{border-color:#bbf7d0;background:#f0fdf4}.sg-perm-card input{display:none}.sg-perm-card__check{flex-shrink:0;display:flex}.sg-perm-card__empty{width:14px;height:14px;border-radius:50%;border:1.5px solid #cbd5e1}.sg-perm-card__lbl{font-size:12px;font-weight:600;color:#0f172a}.sg-perm-card__desc{font-size:10px;color:#64748b}.sg-confirm-orb{width:76px;height:76px;border-radius:50%;margin:0 auto 18px;display:flex;align-items:center;justify-content:center}.sg-confirm-orb--red{background:#fee2e2;color:#dc2626;box-shadow:0 0 0 12px #fff5f5}.sg-confirm-orb--green{background:#dcfce7;color:#16a34a;box-shadow:0 0 0 12px #f0fdf4}.sg-confirm-title{font-size:17px;font-weight:800;color:#0f172a;margin-bottom:8px;text-align:center}.sg-confirm-msg{font-size:13px;color:#64748b;text-align:center;line-height:1.65;max-width:320px;margin:0 auto 4px}.sg-detail-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.sg-detail-row{display:flex;flex-direction:column;gap:3px;padding:10px 14px;border-bottom:1px solid #f1f5f9}.sg-detail-row:nth-child(odd){background:#f8fafc}.sg-detail-row:nth-last-child(-n+2){border-bottom:none}.sg-detail-k{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px}.sg-detail-v{font-size:13px;font-weight:600;color:#0f172a}.sg-detail-v--link{color:#2563eb;text-decoration:none}.sg-detail-v--link:hover{text-decoration:underline}.sg-locked-banner{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fef3c7;border:1px solid #fde68a;border-radius:9px;color:#92400e;font-size:12px;font-weight:600;margin-bottom:14px}.sg-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:700;padding:9px 18px;border-radius:9px;border:1.5px solid transparent;cursor:pointer;transition:all .17s;font-family:inherit;white-space:nowrap}.sg-btn--sm{font-size:12px;padding:7px 13px}.sg-btn--primary{background:#2563eb;color:#fff;border-color:#2563eb}.sg-btn--primary:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.sg-btn--ghost{background:#fff;color:#475569;border-color:#e2e8f0}.sg-btn--ghost:hover:not(:disabled){background:#f8fafc;color:#0f172a;border-color:#cbd5e1}.sg-btn--danger{background:#dc2626;color:#fff;border-color:#dc2626}.sg-btn--danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.sg-btn--success{background:#16a34a;color:#fff;border-color:#16a34a}.sg-btn--success:hover:not(:disabled){background:#15803d;transform:translateY(-1px)}.sg-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.sg-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:sg-spin .55s linear infinite}@keyframes sg-spin{to{transform:rotate(360deg)}}.sg-spin{animation:sg-spin 1s linear infinite}@media(max-width:1280px){.sg-kpi-strip{grid-template-columns:repeat(3,1fr)}}@media(max-width:1024px){.sg-kpi-strip{grid-template-columns:repeat(3,1fr)}.sg-form-grid--3{grid-template-columns:1fr 1fr}.sg-perms-grid{grid-template-columns:1fr}}@media(max-width:768px){.sg-kpi-strip{grid-template-columns:repeat(2,1fr)}.sg-page-hdr{flex-direction:column}.sg-form-grid--2,.sg-form-grid--3,.sg-detail-grid{grid-template-columns:1fr}.sg-fbar{flex-direction:column;align-items:stretch}.sg-fbar__search{max-width:none}.sg-modal--lg,.sg-modal--md{max-width:98%}.sg-modal__hdr,.sg-modal__body,.sg-modal__foot{padding:14px 16px}.sg-steps{padding:10px 16px 0}}@media(max-width:480px){.sg-kpi-strip{grid-template-columns:1fr 1fr}.sg-toast-wrap .sg-toast{min-width:auto;width:calc(100vw - 40px)}}@media print{.sg-toast-wrap,.sg-page-hdr__right,.sg-fbar,.sg-acts,.sg-tab-bar,.sg-overlay{display:none!important}.sg-table-card,.sg-kpi{box-shadow:none;border-color:#e2e8f0}}.sg-desk-selected-info{display:flex;align-items:center;gap:8px;padding:9px 13px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:9px;color:#15803d;font-size:12px;font-weight:500;margin-top:8px;margin-bottom:4px}.sg-desk-selected-info svg{color:#15803d;flex-shrink:0}.dp-wrap{position:relative;font-family:Plus Jakarta Sans,system-ui,sans-serif}.dp-wrap--disabled{opacity:.6;pointer-events:none}.dp-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:10px 13px;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;color:#475569;font-size:13px;font-family:inherit;cursor:pointer;transition:all .2s;text-align:left}.dp-trigger:hover:not(:disabled){border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.dp-trigger--selected{border-color:#bbf7d0;background:#f0fdf4;color:#15803d}.dp-trigger__icon{color:#94a3b8;flex-shrink:0}.dp-trigger__label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dp-trigger__arrow{color:#94a3b8;flex-shrink:0}.dp-trigger__clear{background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;padding:2px;border-radius:4px;flex-shrink:0;transition:color .15s}.dp-trigger__clear:hover{color:#dc2626}.dp-panel{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:500;display:flex;gap:0;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;box-shadow:0 16px 40px -8px #0000002e,0 4px 12px #0000000f;overflow:hidden;max-height:320px}.dp-col{flex:1;min-width:0;border-right:1px solid #f1f5f9;display:flex;flex-direction:column;overflow:hidden}.dp-col:last-child{border-right:none}.dp-col__hdr{display:flex;align-items:center;gap:5px;padding:9px 12px;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:10px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.4px;flex-shrink:0}.dp-col__badge{margin-left:auto;background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;border-radius:4px;padding:1px 5px;font-size:9px;font-weight:700}.dp-col{overflow-y:auto;scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent}.dp-col::-webkit-scrollbar{width:4px}.dp-col::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:2px}.dp-item{display:flex;align-items:center;gap:7px;padding:9px 12px;border:none;background:transparent;color:#475569;font-size:12px;font-family:inherit;text-align:left;cursor:pointer;transition:background .12s;border-bottom:1px solid #f8fafc;width:100%}.dp-item:hover{background:#f1f5f9;color:#0f172a}.dp-item--active{background:#eff6ff;color:#2563eb;font-weight:600}.dp-item__icon{color:inherit;flex-shrink:0}.dp-item__label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dp-item__code{font-family:DM Mono,monospace;font-size:10px;color:#94a3b8;flex-shrink:0}.dp-item__chevron{color:#2563eb;flex-shrink:0}.dp-desk{display:flex;flex-direction:column;gap:2px;padding:9px 12px;border:none;background:transparent;text-align:left;cursor:pointer;transition:background .12s;border-bottom:1px solid #f8fafc;width:100%}.dp-desk:hover:not(:disabled){background:#f0fdf4}.dp-desk--selected{background:#dcfce7}.dp-desk--occupied{opacity:.55;cursor:not-allowed}.dp-desk:disabled{cursor:not-allowed}.dp-desk__top{display:flex;align-items:center;justify-content:space-between}.dp-desk__number{font-family:DM Mono,monospace;font-size:11.5px;font-weight:600;color:#0f172a}.dp-desk__check{color:#16a34a}.dp-desk__occupied-icon{color:#94a3b8}.dp-desk__label{font-size:10.5px;color:#64748b}.dp-desk__occupant,.dp-desk__phone{display:flex;align-items:center;gap:3px;font-size:10px;color:#94a3b8}.dp-empty{padding:16px 12px;font-size:11px;color:#cbd5e1;font-style:italic;text-align:center}.dp-compact{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;font-size:12px;color:#15803d}.dp-compact svg{color:#15803d;flex-shrink:0}.dp-compact__x{background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;transition:color .15s}.dp-compact__x:hover{color:#dc2626}.av2-page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.av2-page-header__left{flex:1}.av2-page-title{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:800;color:var(--tx1, #0f172a);letter-spacing:-.5px}.av2-title-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #2563eb4d;flex-shrink:0}.av2-page-sub{font-size:13px;color:var(--tx3, #64748b);margin-top:4px;margin-left:48px}.av2-page-header__right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.av2-header-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s;white-space:nowrap;font-family:inherit;text-decoration:none}.av2-header-btn:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff;transform:translateY(-1px)}.av2-header-btn--primary{background:#2563eb;color:#fff;border-color:#2563eb}.av2-header-btn--primary:hover{background:#1d4ed8;border-color:#1d4ed8;color:#fff;box-shadow:0 4px 14px #2563eb4d}.av2-stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:24px}.av2-stat-card{position:relative;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:16px 16px 16px 14px;display:flex;align-items:center;gap:14px;overflow:hidden;transition:transform .2s,box-shadow .2s;cursor:default}.av2-stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px #00000017}.av2-stat-card__bar{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:14px 0 0 14px}.av2-stat-card__icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.av2-stat-card__val{font-size:28px;font-weight:800;line-height:1;letter-spacing:-1px}.av2-stat-card__lbl{font-size:11px;font-weight:700;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}.av2-stat-card__trend{font-size:10px;color:var(--tx3, #94a3b8);margin-top:2px}.av2-tab-bar{display:flex;gap:2px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:4px;margin-bottom:22px;overflow-x:auto;scrollbar-width:none}.av2-tab-bar::-webkit-scrollbar{display:none}.av2-tab{position:relative;display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;border:none;background:transparent;color:var(--tx3, #64748b);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;font-family:inherit;flex-shrink:0;overflow:hidden}.av2-tab:hover:not(.av2-tab--active){background:var(--bg-card, #fff);color:var(--tx1, #0f172a);box-shadow:0 1px 4px #0000000f}.av2-tab--active{background:var(--bg-card, #fff);color:var(--tab-color, #2563eb);box-shadow:0 2px 8px #00000014,0 0 0 1px #0000000a}.av2-tab__icon{display:flex;align-items:center;justify-content:center;transition:transform .2s}.av2-tab--active .av2-tab__icon{transform:scale(1.15)}.av2-tab__badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:10px;font-size:10px;font-weight:700;padding:0 6px;background:#dbeafe;color:#2563eb;transition:all .2s}.av2-tab--active .av2-tab__badge{background:var(--tab-color, #2563eb);color:#fff}.av2-tab__badge--red{background:#fee2e2;color:#dc2626}.av2-tab--active .av2-tab__badge--red{background:#dc2626;color:#fff}.av2-tab__indicator{position:absolute;bottom:0;left:12px;right:12px;height:2px;border-radius:2px;animation:av2-indicator-in .2s ease}@keyframes av2-indicator-in{0%{transform:scaleX(0);opacity:0}to{transform:scaleX(1);opacity:1}}.av2-tab-content{animation-duration:.18s;animation-fill-mode:both;animation-timing-function:ease}.av2-tab-content--enter{animation-name:av2-fade-in}.av2-tab-content--exit{animation-name:av2-fade-out}@keyframes av2-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@keyframes av2-fade-out{0%{opacity:1;transform:none}to{opacity:0;transform:translateY(-4px)}}.av2-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}.av2-section-title{display:flex;align-items:center;gap:9px;font-size:16px;font-weight:700;color:var(--tx1, #0f172a)}.av2-section-desc{font-size:13px;color:var(--tx3, #64748b);margin-top:4px}.av2-section-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:11px;font-size:11px;font-weight:700;padding:0 6px;background:#dbeafe;color:#2563eb}.av2-section-badge--red{background:#fee2e2;color:#dc2626}.av2-filter-row{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.av2-search-box{position:relative;flex:1;min-width:220px;max-width:380px}.av2-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.av2-search-input{width:100%;padding:10px 36px 10px 38px;background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;transition:all .2s;font-family:inherit}.av2-search-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.av2-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--tx3);cursor:pointer;display:flex;padding:2px;transition:color .15s}.av2-search-clear:hover{color:#dc2626}.av2-chips{display:flex;gap:6px;flex-wrap:wrap}.av2-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:20px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.av2-chip:hover{border-color:#2563eb;color:#2563eb}.av2-chip--active{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 2px 8px #2563eb40}.av2-chip__count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;font-size:10px;font-weight:700;background:#ffffff40;padding:0 4px}.av2-chip:not(.av2-chip--active) .av2-chip__count{background:var(--bg, #f1f5f9);color:var(--tx3)}.av2-table-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;overflow:hidden;box-shadow:0 2px 12px #0000000a}.av2-table{width:100%;border-collapse:separate;border-spacing:0}.av2-table thead tr{background:linear-gradient(to bottom,#f8fafc,#f1f5f9)}.av2-table th{font-size:11px;font-weight:700;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:13px 14px;text-align:left;border-bottom:2px solid var(--border, #e2e8f0);white-space:nowrap;-webkit-user-select:none;user-select:none}.av2-th--sortable{cursor:pointer;display:table-cell}.av2-th--sortable:hover{color:var(--tx1, #0f172a)}.av2-table td{padding:12px 14px;font-size:13px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle}.av2-table tr:last-child td{border-bottom:none}.av2-tr{transition:background .12s;animation:av2-row-in .2s ease both}.av2-tr:hover td{background:#f8fafc}.av2-tr--overstay td{background:#fff8f8!important}.av2-tr--overstay:hover td{background:#fee2e2!important}@keyframes av2-row-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.av2-visitor-cell{display:flex;align-items:center;gap:10px}.av2-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.av2-avatar--sm{width:32px;height:32px;font-size:11px}.av2-visitor-name{font-weight:700;color:var(--tx1, #0f172a);font-size:13px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}.av2-visitor-org{font-size:11px;color:var(--tx3, #64748b);margin-top:1px}.av2-mini-badge{display:inline-flex;align-items:center;gap:3px;font-size:9px;font-weight:700;padding:2px 6px;border-radius:6px}.av2-mini-badge--purple{background:#ede9fe;color:#7c3aed}.av2-mini-badge--red{background:#fee2e2;color:#dc2626}.av2-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid transparent;white-space:nowrap;letter-spacing:.2px}.av2-badge--waiting{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.av2-badge--attended{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.av2-badge--overstay{background:#fee2e2;color:#dc2626;border-color:#fecaca}.av2-badge--registered{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}.av2-badge--completed{background:#f1f5f9;color:#94a3b8;border-color:#e2e8f0}.av2-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor;animation:av2-pulse 1.6s ease-in-out infinite}@keyframes av2-pulse{0%,to{opacity:1}50%{opacity:.35}}.av2-time-val{font-size:14px;font-weight:800;color:var(--tx1, #0f172a);letter-spacing:-.3px}.av2-time-val--alert{color:#dc2626}.av2-time-sub{font-size:10px;color:var(--tx3, #94a3b8);margin-top:1px;font-weight:500}.av2-cell-code{font-family:SF Mono,Fira Code,monospace;font-size:13px;font-weight:700;color:#0f172a;background:#f1f5f9;padding:3px 8px;border-radius:7px;white-space:nowrap;border:1px solid #e2e8f0}.av2-no-cell-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:3px 8px;border-radius:8px;background:#f8fafc;color:#94a3b8;border:1px solid #e2e8f0;white-space:nowrap}.av2-host-name{font-size:13px;font-weight:600;color:var(--tx1, #0f172a)}.av2-host-dept{font-size:11px;color:var(--tx3, #64748b);margin-top:1px}.av2-purpose-chip{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:3px 9px;border-radius:8px;background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe;white-space:nowrap}.av2-action-group{display:flex;align-items:center;gap:5px}.av2-action-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:7px;border:none;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.av2-action-btn:disabled{opacity:.45;cursor:not-allowed}.av2-action-btn--attend{background:#dcfce7;color:#15803d}.av2-action-btn--attend:hover:not(:disabled){background:#16a34a;color:#fff;transform:translateY(-1px)}.av2-action-btn--notify{background:#dbeafe;color:#1d4ed8;padding:5px 8px}.av2-action-btn--notify:hover:not(:disabled){background:#2563eb;color:#fff;transform:translateY(-1px)}.av2-action-btn--detail{background:#f1f5f9;color:#475569;padding:5px 8px}.av2-action-btn--detail:hover{background:#e2e8f0;color:#0f172a}.av2-action-btn--danger{background:#fee2e2;color:#dc2626}.av2-action-btn--danger:hover:not(:disabled){background:#dc2626;color:#fff;transform:translateY(-1px)}.av2-action-btn--remove{background:#fee2e2;color:#dc2626}.av2-action-btn--remove:hover{background:#dc2626;color:#fff}.av2-table-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px;font-size:12px;color:var(--tx3, #94a3b8);padding:0 2px}.av2-refresh-hint{display:flex;align-items:center;gap:5px}.av2-td--sm{font-size:12px}.av2-td--bold{font-weight:600;color:var(--tx1)}.av2-td--muted{font-size:12px;color:var(--tx3, #94a3b8)}.av2-td--mono{font-family:SF Mono,monospace;font-size:12px;white-space:nowrap}.av2-td--truncate{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.av2-id-code{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:600;background:#f1f5f9;padding:2px 7px;border-radius:5px;border:1px solid #e2e8f0;color:#0f172a}.av2-sticker-released{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.av2-perm-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.av2-reason-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 9px;border-radius:8px;white-space:nowrap;font-family:SF Mono,monospace}.av2-reason-badge--red{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.av2-reason-badge--amber{background:#fef3c7;color:#b45309;border:1px solid #fde68a}.av2-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13px;font-weight:700;padding:9px 18px;border-radius:9px;border:1.5px solid transparent;cursor:pointer;transition:all .17s;font-family:inherit;white-space:nowrap;text-decoration:none}.av2-btn--primary{background:#2563eb;color:#fff;border-color:#2563eb}.av2-btn--primary:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.av2-btn--success{background:#16a34a;color:#fff;border-color:#16a34a}.av2-btn--success:hover:not(:disabled){background:#15803d;transform:translateY(-1px)}.av2-btn--danger{background:#dc2626;color:#fff;border-color:#dc2626}.av2-btn--danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.av2-btn--ghost{background:var(--bg-card, #fff);color:var(--tx2, #475569);border-color:var(--border, #e2e8f0)}.av2-btn--ghost:hover:not(:disabled){background:var(--bg, #f8fafc)}.av2-btn:disabled{opacity:.5;cursor:not-allowed}.av2-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:av2-spin .55s linear infinite}@keyframes av2-spin{to{transform:rotate(360deg)}}.av2-skeleton-rows{display:flex;flex-direction:column;gap:1px}.av2-skeleton-row{display:flex;align-items:center;gap:14px;padding:14px 16px;border-bottom:1px solid var(--border, #e2e8f0);animation:av2-skeleton-pulse 1.5s ease infinite}.av2-skeleton-row:last-child{border-bottom:none}.av2-skeleton{height:12px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:av2-shimmer 1.4s linear infinite;border-radius:6px}.av2-skeleton--circle{width:36px;height:36px;border-radius:50%;flex-shrink:0}.av2-skeleton--wide{flex:1;max-width:220px}.av2-skeleton--mid{width:100px}.av2-skeleton--short{width:60px}@keyframes av2-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.av2-empty-state{text-align:center;padding:64px 24px;color:var(--tx3, #94a3b8)}.av2-empty-state__icon{width:72px;height:72px;border-radius:18px;background:var(--bg, #f1f5f9);color:var(--tx3, #94a3b8);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}.av2-empty-state h3{font-size:16px;font-weight:700;color:var(--tx2, #475569);margin:0 0 8px}.av2-empty-state p{font-size:13px;line-height:1.6;max-width:360px;margin:0 auto 18px}.av2-block-form{background:var(--bg-card, #fff);border:1.5px solid #fecaca;border-radius:14px;padding:22px;margin-bottom:22px;box-shadow:0 4px 18px #dc262612;animation:av2-fade-in .2s ease}.av2-block-form__header{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:700;color:var(--tx1, #0f172a);margin-bottom:8px}.av2-block-form__desc{font-size:13px;color:var(--tx3, #64748b);line-height:1.6;margin-bottom:18px}.av2-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}.av2-form-group{display:flex;flex-direction:column;gap:5px}.av2-form-group--full{grid-column:1 / -1}.av2-form-group label{font-size:12px;font-weight:700;color:var(--tx2, #475569);display:flex;align-items:center;gap:5px}.av2-form-group input,.av2-form-group select{background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13px;padding:9px 12px;outline:none;width:100%;transition:all .2s;font-family:inherit}.av2-form-group input:focus,.av2-form-group select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.av2-input--error{border-color:#dc2626!important;background:#fef2f2!important}.av2-error-msg{font-size:11px;color:#dc2626;font-weight:600}.av2-required{color:#dc2626;font-weight:700}.av2-optional{font-size:10px;font-weight:500;color:var(--tx3);background:var(--bg, #f1f5f9);padding:1px 6px;border-radius:6px;border:1px solid var(--border, #e2e8f0)}.av2-block-form__actions{display:flex;gap:10px;margin-top:4px}.av2-modal-overlay{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:av2-fade-in .2s ease}.av2-modal{background:var(--bg-card, #fff);border-radius:20px;box-shadow:0 32px 64px -20px #0006;width:100%;max-width:580px;max-height:92vh;overflow-y:auto;animation:av2-modal-in .22s ease}@keyframes av2-modal-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.av2-modal-header{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 14px;border-bottom:1px solid var(--border, #e2e8f0)}.av2-modal-identity{display:flex;align-items:center;gap:12px}.av2-modal-avatar{width:44px;height:44px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;flex-shrink:0}.av2-modal-name{font-size:18px;font-weight:800;color:var(--tx1, #0f172a);letter-spacing:-.3px}.av2-modal-org{font-size:13px;color:var(--tx3, #64748b);margin-top:2px}.av2-modal-close{background:none;border:none;cursor:pointer;color:var(--tx3, #94a3b8);transition:color .15s;padding:4px;border-radius:8px;display:flex}.av2-modal-close:hover{color:#dc2626;background:#fee2e2}.av2-modal-overstay-banner{display:flex;align-items:center;gap:8px;padding:10px 24px;background:#fee2e2;color:#dc2626;font-size:12px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;border-bottom:1px solid #fecaca}.av2-modal-body{padding:18px 24px}.av2-detail-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--border, #e2e8f0);border-radius:12px;overflow:hidden}.av2-detail-cell{padding:10px 14px;border-bottom:1px solid var(--border, #e2e8f0)}.av2-detail-cell:nth-last-child(-n+2){border-bottom:none}.av2-detail-cell--alt{background:var(--bg, #f8fafc)}.av2-detail-key{font-size:10px;font-weight:700;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.av2-detail-val{font-size:13px;font-weight:600;color:var(--tx1, #0f172a)}.av2-modal-footer{padding:14px 24px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}@media(max-width:1280px){.av2-stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:1024px){.av2-stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.av2-stats-grid{grid-template-columns:1fr 1fr}.av2-page-header{flex-direction:column;gap:12px}.av2-page-sub{margin-left:0}.av2-tab-bar{overflow-x:auto}.av2-tab{padding:9px 14px}.av2-tab__label{display:none}.av2-filter-row{flex-direction:column;align-items:stretch}.av2-search-box{max-width:none}.av2-form-grid,.av2-detail-grid{grid-template-columns:1fr}.av2-detail-cell:nth-last-child(-n+2){border-bottom:1px solid var(--border)}.av2-detail-cell:last-child{border-bottom:none}.av2-modal{max-width:100%;border-radius:16px}.av2-modal-header,.av2-modal-body,.av2-modal-footer{padding:16px 18px}.av2-table-card{overflow-x:auto}.av2-table{min-width:680px}}@media(max-width:480px){.av2-stats-grid{grid-template-columns:1fr}.av2-tab__label{display:inline}}@media print{.av2-page-header__right,.av2-filter-row,.av2-action-group,.av2-block-form{display:none!important}}.vcd-display{position:relative;width:100vw;min-height:100dvh;background:#050d1a;color:#e2eaf4;font-family:DM Sans,system-ui,sans-serif;display:flex;flex-direction:column;overflow:hidden;transition:background .3s}.vcd-display--flash{animation:vcd-flash-anim .5s ease-out}@keyframes vcd-flash-anim{0%{background:#0f2a6e}30%{background:#0e1e4a}to{background:#050d1a}}.vcd-display__grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(59,130,246,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.04) 1px,transparent 1px);background-size:48px 48px;pointer-events:none}.vcd-display__glow-top{position:absolute;top:-120px;left:50%;transform:translate(-50%);width:900px;height:340px;background:radial-gradient(ellipse at center,rgba(37,99,235,.18) 0%,transparent 70%);pointer-events:none}.vcd-display__glow-btm{position:absolute;bottom:-80px;left:30%;width:600px;height:260px;background:radial-gradient(ellipse at center,rgba(6,182,212,.1) 0%,transparent 70%);pointer-events:none}.vcd-header{position:relative;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:18px 40px 16px;border-bottom:1px solid rgba(59,130,246,.15);background:#050d1ab3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.vcd-header__brand{display:flex;align-items:center;gap:12px}.vcd-header__logo{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:#3b82f61f;border:1px solid rgba(59,130,246,.25)}.vcd-header__name{font-family:Bebas Neue,sans-serif;font-size:28px;letter-spacing:1px;color:#fff}.vcd-header__sep{color:#fff3;font-size:20px}.vcd-header__sub{font-size:13px;font-weight:500;color:#e2eaf473;letter-spacing:.3px}.vcd-header__sse-status{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;letter-spacing:.3px;opacity:.85}.vcd-sse-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}@keyframes vcd-sse-pulse{0%,to{box-shadow:0 0 #16a34a80}50%{box-shadow:0 0 0 5px #16a34a00}}.vcd-header__clock{text-align:right;line-height:1}.vcd-clock__time{font-family:JetBrains Mono,monospace;font-size:36px;font-weight:700;color:#fff;letter-spacing:2px}.vcd-clock__sec{font-family:JetBrains Mono,monospace;font-size:22px;font-weight:400;color:#ffffff59}.vcd-clock__date{display:block;font-size:12px;font-weight:500;color:#e2eaf466;letter-spacing:.5px;text-transform:uppercase;margin-top:5px}.vcd-stage{position:relative;z-index:5;flex:1;display:flex;align-items:center;justify-content:center;padding:32px 48px}.vcd-idle{text-align:center;-webkit-user-select:none;user-select:none}.vcd-idle__icon-wrap{position:relative;width:140px;height:140px;margin:0 auto 28px;display:flex;align-items:center;justify-content:center}.vcd-idle__ring{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(59,130,246,.2);animation:vcd-idle-ring 3s ease-in-out infinite}.vcd-idle__ring--1{animation-delay:0s}.vcd-idle__ring--2{animation-delay:.8s;inset:-16px;border-color:#3b82f61f}.vcd-idle__ring--3{animation-delay:1.6s;inset:-32px;border-color:#3b82f60f}@keyframes vcd-idle-ring{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.06);opacity:1}}.vcd-idle__icon{color:#3b82f699;position:relative;z-index:1}.vcd-idle__label{font-size:22px;font-weight:300;color:#e2eaf466;letter-spacing:.5px;margin-bottom:8px}.vcd-idle__hint{font-size:12px;color:#e2eaf433;letter-spacing:1px;text-transform:uppercase}.vcd-call{width:100%;max-width:900px;display:flex;flex-direction:column;align-items:center;gap:0;animation:vcd-call-enter .5s cubic-bezier(.22,.68,0,1.2)}@keyframes vcd-call-enter{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:none}}.vcd-call__attention{display:flex;align-items:center;gap:12px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700;letter-spacing:4px;color:#3b82f6;margin-bottom:20px;animation:vcd-att-blink 1.2s ease-in-out infinite alternate}@keyframes vcd-att-blink{0%{opacity:.7}to{opacity:1}}.vcd-call__att-dot{width:6px;height:6px;border-radius:50%;background:#3b82f6;animation:vcd-att-blink 1.2s ease-in-out infinite alternate}.vcd-call__group-badge{font-size:10px;font-weight:700;letter-spacing:2px;color:#06b6d4;background:#06b6d41f;border:1px solid rgba(6,182,212,.3);border-radius:20px;padding:3px 10px}.vcd-call__pass-wrap{text-align:center;margin-bottom:24px}.vcd-call__pass-label{font-size:11px;font-weight:700;letter-spacing:5px;color:#3b82f699;text-transform:uppercase;margin-bottom:8px}.vcd-call__pass-number{display:flex;gap:10px;justify-content:center;align-items:center}.vcd-call__pass-digit{display:inline-flex;align-items:center;justify-content:center;width:100px;height:120px;background:linear-gradient(135deg,#2563eb2e,#06b6d41a);border:1px solid rgba(59,130,246,.3);border-radius:16px;font-family:Bebas Neue,sans-serif;font-size:96px;color:#fff;letter-spacing:-2px;box-shadow:0 0 0 1px #3b82f61a,0 8px 32px #2563eb33,inset 0 1px #ffffff0f;animation:vcd-digit-drop .4s cubic-bezier(.34,1.56,.64,1) both}@keyframes vcd-digit-drop{0%{opacity:0;transform:translateY(-20px) scale(.8)}to{opacity:1;transform:none}}.vcd-call__identity{display:flex;align-items:center;gap:18px;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:16px;padding:14px 24px;margin-bottom:24px;width:100%;max-width:600px;animation:vcd-call-enter .5s .15s both}.vcd-call__avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#0891b2);display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;font-size:20px;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:-1px}.vcd-call__visitor-info{flex:1;min-width:0}.vcd-call__visitor-name{font-size:26px;font-weight:600;color:#fff;letter-spacing:-.3px}.vcd-call__visitor-org{font-size:14px;color:#e2eaf480;margin-top:2px}.vcd-call__visitor-desc{font-size:12px;font-style:italic;color:#e2eaf459;margin-top:4px;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vcd-call__visitor-purpose{display:inline-block;margin-top:6px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#06b6d4;background:#06b6d41a;border:1px solid rgba(6,182,212,.25);border-radius:20px;padding:2px 10px}.vcd-call__direction{width:100%;max-width:700px;background:linear-gradient(135deg,#2563eb24,#06b6d414);border:1px solid rgba(59,130,246,.3);border-radius:20px;padding:24px 32px;text-align:center;position:relative;overflow:hidden;margin-bottom:14px;animation:vcd-call-enter .5s .25s both}.vcd-call__direction:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(6,182,212,.04));pointer-events:none}.vcd-call__dir-label{font-size:11px;font-weight:700;letter-spacing:5px;color:#3b82f6b3;text-transform:uppercase;margin-bottom:12px}.vcd-call__dir-arrow{color:#3b82f680;margin-bottom:10px;animation:vcd-arrow-bounce .8s ease-in-out infinite alternate}@keyframes vcd-arrow-bounce{0%{transform:translate(-4px)}to{transform:translate(4px)}}.vcd-call__dir-office{font-family:Bebas Neue,sans-serif;font-size:52px;letter-spacing:1px;color:#fff;line-height:1;text-shadow:0 0 40px rgba(59,130,246,.4);margin-bottom:10px}.vcd-call__dir-floor{display:inline-flex;align-items:center;gap:6px;font-size:15px;font-weight:500;color:#e2eaf48c;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:5px 16px;margin-top:4px}.vcd-call__dir-floor svg{color:#06b6d4b3}.vcd-call__dir-desk{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:#06b6d4cc;background:#06b6d414;border:1px solid rgba(6,182,212,.2);border-radius:20px;padding:4px 14px;margin-top:8px}.vcd-call__dir-desk svg{color:#06b6d499}.vcd-call__meta{font-size:12px;color:#e2eaf440;font-family:JetBrains Mono,monospace;letter-spacing:1px;margin-bottom:16px}.vcd-call__progress-track{width:100%;max-width:600px;height:3px;background:#ffffff0f;border-radius:3px;overflow:hidden}.vcd-call__progress-bar{height:100%;background:linear-gradient(90deg,#2563eb,#06b6d4);border-radius:3px;transition:width .25s linear;box-shadow:0 0 8px #3b82f680}.vcd-ticker{position:relative;z-index:10;display:flex;align-items:center;gap:0;border-top:1px solid rgba(59,130,246,.12);background:#050d1ad9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:0 40px;min-height:48px;overflow:hidden}.vcd-ticker__label{font-size:9px;font-weight:700;letter-spacing:3px;color:#3b82f680;text-transform:uppercase;white-space:nowrap;padding-right:20px;border-right:1px solid rgba(59,130,246,.15);margin-right:20px;flex-shrink:0}.vcd-ticker__items{display:flex;gap:32px;align-items:center;overflow:hidden}.vcd-ticker__item{display:flex;align-items:center;gap:10px;flex-shrink:0;transition:opacity .5s}.vcd-ticker__pass{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;color:#3b82f6;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:6px;padding:1px 8px}.vcd-ticker__name{font-size:12px;font-weight:600;color:#e2eaf4a6}.vcd-ticker__office{font-size:11px;color:#e2eaf459}.vcd-ticker__desk{font-size:10px;color:#06b6d48c;background:#06b6d40f;border:1px solid rgba(6,182,212,.15);border-radius:10px;padding:1px 7px}.vcd-ticker__time{font-family:JetBrains Mono,monospace;font-size:10px;color:#e2eaf433}.vcd-ticker__item:after{content:"·";color:#ffffff1a;margin-left:16px}.vcd-ticker__item:last-child:after{display:none}.vcd-instruction{position:relative;z-index:10;text-align:center;font-size:11px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:#e2eaf426;padding:10px 20px;border-top:1px solid rgba(255,255,255,.04);background:#050d1ae6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vcd-attend-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 15px;border-radius:9px;border:none;background:#16a34a;color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;position:relative;overflow:hidden;white-space:nowrap}.vcd-attend-btn:hover:not(:disabled){background:#15803d;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a59}.vcd-attend-btn:disabled{opacity:.5;cursor:not-allowed}.vcd-attend-btn--calling{background:#2563eb;animation:vcd-btn-pulse 1s ease-in-out infinite}.vcd-attend-btn--done{background:#0891b2}.vcd-attend-btn__pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:#fff;animation:vcd-pulse-dot .7s ease-in-out infinite alternate}@keyframes vcd-btn-pulse{0%,to{box-shadow:0 0 #2563eb80}50%{box-shadow:0 0 0 8px #2563eb00}}@keyframes vcd-pulse-dot{0%{opacity:.4;transform:scale(.7)}to{opacity:1;transform:scale(1.1)}}@media(max-width:768px){.vcd-header{padding:12px 20px}.vcd-header__sub{display:none}.vcd-clock__time{font-size:26px}.vcd-stage{padding:16px 20px}.vcd-call__pass-digit{width:66px;height:80px;font-size:66px}.vcd-call__dir-office{font-size:32px}.vcd-ticker{padding:0 20px;overflow-x:auto}.vcd-call__identity{padding:10px 16px}}@media(max-width:480px){.vcd-call__pass-number{gap:6px}.vcd-call__pass-digit{width:52px;height:64px;font-size:52px;border-radius:10px}.vcd-call__dir-office{font-size:26px}.vcd-call__visitor-name{font-size:20px}}@keyframes vcd-call-enter{0%{opacity:0;transform:translateY(32px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.hp3-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hp3-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:14px;color:var(--tx3, #94a3b8);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:14px}.hp3-toasts{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;width:340px;max-width:calc(100vw - 32px);pointer-events:none}.hp3-toast{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:12px;border:1px solid transparent;box-shadow:0 8px 24px #0000001f;font-size:13px;font-weight:500;pointer-events:all;line-height:1.45;animation:hp3-toast-in .22s cubic-bezier(.4,0,.2,1);font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes hp3-toast-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:none}}.hp3-toast--success{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.hp3-toast--error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.hp3-toast--warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.hp3-toast--info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.hp3-toast__icon{flex-shrink:0;margin-top:1px}.hp3-toast__msg{flex:1}.hp3-toast__x{background:none;border:none;cursor:pointer;padding:2px;border-radius:4px;opacity:.5;transition:opacity .15s;line-height:1;color:currentColor}.hp3-toast__x:hover{opacity:1}.hp3-offline{min-height:70vh;display:flex;align-items:center;justify-content:center;font-family:Plus Jakarta Sans,system-ui,sans-serif}.hp3-offline__card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 20px 60px #00000014;padding:40px 44px;max-width:480px;width:100%;text-align:center;animation:hp3-card-in .4s cubic-bezier(.4,0,.2,1)}@keyframes hp3-card-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}.hp3-offline__visual{position:relative;width:80px;height:80px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center}.hp3-offline__ring{position:absolute;inset:0;border-radius:50%;border:2px dashed #cbd5e1;animation:hp3-spin 8s linear infinite}@keyframes hp3-spin{to{transform:rotate(360deg)}}.hp3-offline__icon{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);display:flex;align-items:center;justify-content:center;color:#94a3b8}.hp3-clock{margin-bottom:20px}.hp3-clock__time{font-size:32px;font-weight:800;letter-spacing:-1px;color:var(--tx1, #0f172a);font-family:DM Mono,monospace}.hp3-clock__date{font-size:13px;color:var(--tx3, #94a3b8);margin-top:2px}.hp3-offline__title{font-size:22px;font-weight:800;color:var(--tx1, #0f172a);margin-bottom:10px}.hp3-offline__desc{font-size:14px;color:var(--tx2, #475569);line-height:1.7;margin-bottom:24px}.hp3-offline__features{display:grid;grid-template-columns:1fr 1fr;gap:8px;text-align:left;margin-bottom:28px}.hp3-offline__feat{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--tx2, #475569);font-weight:500;background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:10px;padding:8px 12px}.hp3-offline__feat span{font-size:16px}.hp3-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px;gap:16px;flex-wrap:wrap;font-family:Plus Jakarta Sans,system-ui,sans-serif}.hp3-hdr__left{flex:1}.hp3-hdr__right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.hp3-hdr__title{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:800;color:var(--tx1, #0f172a);letter-spacing:-.5px}.hp3-hdr__icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #2563eb4d;flex-shrink:0}.hp3-hdr__sub{font-size:13px;color:var(--tx3, #64748b);margin-top:4px;margin-left:48px}.hp3-presence{display:flex;align-items:center;justify-content:space-between;gap:16px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;border-radius:14px;padding:14px 18px;margin-bottom:18px;font-family:Plus Jakarta Sans,system-ui,sans-serif}.hp3-presence__left{display:flex;align-items:center;gap:12px;min-width:0}.hp3-presence__dot{width:10px;height:10px;border-radius:50%;background:#16a34a;flex-shrink:0;box-shadow:0 0 0 3px #16a34a40;animation:hp3-pulse-dot 2s ease-in-out infinite}@keyframes hp3-pulse-dot{0%,to{box-shadow:0 0 0 3px #16a34a40}50%{box-shadow:0 0 0 7px #16a34a1a}}.hp3-presence__name{font-size:14px;font-weight:700;color:#15803d}.hp3-presence__meta{font-size:12px;color:#166534;margin-top:2px}.hp3-presence__unread{color:#15803d}.hp3-ring{position:relative;width:44px;height:44px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hp3-ring__label{position:absolute;font-size:9px;font-weight:700;font-family:DM Mono,monospace;white-space:nowrap}.hp3-kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;font-family:Plus Jakarta Sans,system-ui,sans-serif}.hp3-kpi{background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:12px;position:relative;overflow:hidden;animation:hp3-kpi-in .4s ease var(--kd, 0ms) both}.hp3-kpi:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--kc, #2563eb);border-radius:14px 0 0 14px}@keyframes hp3-kpi-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.hp3-kpi__icon{width:40px;height:40px;border-radius:11px;background:var(--kb, #eff6ff);color:var(--kc, #2563eb);display:flex;align-items:center;justify-content:center;flex-shrink:0}.hp3-kpi__val{font-size:26px;font-weight:800;letter-spacing:-1px;line-height:1;color:var(--kc, #2563eb);font-family:DM Mono,monospace}.hp3-kpi__lbl{font-size:11px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}.hp3-tabs{display:flex;gap:2px;padding:4px;background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:12px;margin-bottom:16px;font-family:Plus Jakarta Sans,system-ui,sans-serif}.hp3-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 12px;border-radius:8px;border:none;background:transparent;color:var(--tx3, #64748b);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s;font-family:inherit;position:relative;white-space:nowrap}.hp3-tab:hover:not(.hp3-tab--active){background:var(--bg-card, #fff);color:var(--tx1, #0f172a)}.hp3-tab--active{background:var(--bg-card, #fff);color:var(--primary, #2563eb);box-shadow:0 2px 8px #00000014;font-weight:700}.hp3-tab__badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--primary, #2563eb);color:#fff;font-size:10px;font-weight:800}.hp3-tab__badge--red{background:#dc2626}.hp3-panel{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #0000000a;font-family:Plus Jakarta Sans,system-ui,sans-serif}.hp3-filter-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:12px 16px;border-bottom:1px solid var(--border, #e2e8f0);background:var(--bg-input, #f8fafc)}.hp3-chip--filter{padding:5px 12px;border-radius:20px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.hp3-chip--filter:hover{border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.hp3-chip--filter-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.hp3-filter-bar__count{margin-left:auto;font-size:12px;color:var(--tx3, #94a3b8);font-weight:500}.hp3-visitor-list{display:flex;flex-direction:column}.hp3-vc{display:flex;border-bottom:1px solid var(--border, #e2e8f0);transition:background .12s;animation:hp3-row-in .22s ease both}.hp3-vc:last-child{border-bottom:none}.hp3-vc:hover{background:#fafbff}.hp3-vc--overstay{background:#fff5f5!important}.hp3-vc--overstay:hover{background:#fee2e2!important}.hp3-vc--attended{opacity:.75}@keyframes hp3-row-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.hp3-vc__bar{width:4px;flex-shrink:0;min-height:80px}.hp3-vc__main{flex:1;min-width:0;padding:14px 16px}.hp3-vc__head{display:flex;align-items:flex-start;gap:12px}.hp3-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0;position:relative;font-family:Plus Jakarta Sans,system-ui,sans-serif}.hp3-avatar--sm{width:28px;height:28px;font-size:10px}.hp3-avatar--lg{width:48px;height:48px;font-size:16px}.hp3-avatar__pulse{position:absolute;inset:-3px;border-radius:50%;border:2px solid;animation:hp3-pulse-ring 1.5s ease-in-out infinite}@keyframes hp3-pulse-ring{0%,to{opacity:.7;transform:scale(1)}50%{opacity:.2;transform:scale(1.15)}}.hp3-vc__info{flex:1;min-width:0}.hp3-vc__name{font-size:14px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.3}.hp3-vc__org{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--tx3, #64748b);margin-top:2px}.hp3-vc__chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.hp3-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;background:var(--bg-input, #f1f5f9);color:var(--tx2, #475569);border:1px solid var(--border, #e2e8f0);white-space:nowrap}.hp3-chip--status{border:none}.hp3-chip--cell{background:#eff6ff;color:#2563eb;border-color:#bfdbfe}.hp3-chip--group{background:#f5f3ff;color:#7c3aed;border-color:#ddd6fe}.hp3-chip--muted{opacity:.7}.hp3-dot-pulse{width:6px;height:6px;border-radius:50%;flex-shrink:0;animation:hp3-dot-anim 1.4s ease-in-out infinite}@keyframes hp3-dot-anim{0%,to{opacity:1}50%{opacity:.3}}.hp3-vc__timer{text-align:right;min-width:52px;flex-shrink:0}.hp3-vc__timer-val{display:block;font-size:18px;font-weight:800;color:var(--tx1, #0f172a);font-family:DM Mono,monospace;line-height:1}.hp3-vc__timer-lbl{font-size:10px;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.5px}.hp3-vc__timer--over .hp3-vc__timer-val{color:#dc2626}.hp3-vc__detail{margin-top:10px;padding:10px 12px;background:var(--bg-input, #f8fafc);border-radius:8px;border:1px solid var(--border, #e2e8f0);display:flex;flex-direction:column;gap:6px}.hp3-vc__detail-row{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--tx2, #475569)}.hp3-vc__detail-row svg{color:var(--tx3, #94a3b8);flex-shrink:0}.hp3-vc__actions{display:flex;align-items:center;gap:6px;margin-top:10px;flex-wrap:wrap}.hp3-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:9px;border:1.5px solid transparent;font-size:13px;font-weight:700;cursor:pointer;transition:all .17s;font-family:Plus Jakarta Sans,system-ui,sans-serif;white-space:nowrap;line-height:1}.hp3-btn--sm{font-size:12px;padding:6px 12px}.hp3-btn--lg{font-size:14px;padding:11px 22px}.hp3-btn--xl{font-size:15px;padding:13px 36px;border-radius:11px}.hp3-btn--full{width:100%}.hp3-btn--icon{width:30px;height:30px;padding:0;flex-shrink:0}.hp3-btn--primary{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.hp3-btn--primary:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.hp3-btn--success{background:#16a34a;color:#fff;border-color:#16a34a}.hp3-btn--success:hover:not(:disabled){background:#15803d;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}.hp3-btn--danger{background:#dc2626;color:#fff;border-color:#dc2626}.hp3-btn--danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.hp3-btn--ghost{background:var(--bg-card, #fff);color:var(--tx2, #475569);border-color:var(--border, #e2e8f0)}.hp3-btn--ghost:hover:not(:disabled){background:var(--bg-input, #f8fafc);border-color:#cbd5e1}.hp3-btn--outline{background:transparent;color:var(--tx2, #475569);border-color:var(--border, #e2e8f0)}.hp3-btn--outline:hover:not(:disabled){border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.hp3-btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}.hp3-sound-btn{width:34px;height:34px;border-radius:8px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx3, #94a3b8);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s}.hp3-sound-btn--on{color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);background:#eff6ff}.hp3-sound-btn:hover{transform:translateY(-1px)}.hp3-spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:hp3-spin-anim .55s linear infinite}.hp3-spinner--lg{width:28px;height:28px;border-width:3px;border-top-color:var(--primary, #2563eb);border-color:#2563eb26}@keyframes hp3-spin-anim{to{transform:rotate(360deg)}}.hp3-notif-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border, #e2e8f0);background:var(--bg-input, #f8fafc)}.hp3-notif-toolbar__count{font-size:13px;color:var(--tx2, #475569)}.hp3-notif-feed{display:flex;flex-direction:column}.hp3-notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border, #e2e8f0);transition:background .12s;position:relative;animation:hp3-row-in .2s ease both}.hp3-notif-item:last-child{border-bottom:none}.hp3-notif-item:hover{background:#fafbff}.hp3-notif-item--unread{background:#f8fbff}.hp3-notif-item--unread:hover{background:#eff6ff}.hp3-notif-item__icon{width:34px;height:34px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.hp3-notif-item__body{flex:1;min-width:0}.hp3-notif-item__top{display:flex;align-items:center;gap:8px;margin-bottom:3px;flex-wrap:wrap}.hp3-notif-item__name{font-size:13px;font-weight:700;color:var(--tx1, #0f172a)}.hp3-notif-item__type{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px}.hp3-notif-item__msg{font-size:12px;color:var(--tx2, #475569);line-height:1.5}.hp3-notif-item__meta{font-size:11px;color:var(--tx3, #94a3b8);margin-top:3px}.hp3-notif-item__aside{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.hp3-notif-item__time{font-size:11px;color:var(--tx3, #94a3b8);font-family:DM Mono,monospace;white-space:nowrap}.hp3-unread-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--primary, #2563eb);flex-shrink:0}.hp3-handover{display:grid;grid-template-columns:1fr auto 1fr;gap:0;min-height:200px}.hp3-handover__col{padding:16px}.hp3-handover__arrow{display:flex;align-items:center;justify-content:center;padding:0 4px;color:var(--tx3, #94a3b8);border-left:1px solid var(--border, #e2e8f0);border-right:1px solid var(--border, #e2e8f0)}.hp3-section-hdr{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--tx2, #475569);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border, #e2e8f0)}.hp3-section-hdr__count{margin-left:auto;background:var(--bg-input, #f1f5f9);border:1px solid var(--border, #e2e8f0);border-radius:10px;padding:1px 8px;font-size:11px;color:var(--tx2, #475569)}.hp3-check-all{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--tx1, #0f172a);font-weight:500;cursor:pointer;margin-bottom:10px}.hp3-check-all input{accent-color:var(--primary, #2563eb);width:15px;height:15px;cursor:pointer}.hp3-pass-list{display:flex;flex-direction:column;gap:6px;max-height:260px;overflow-y:auto}.hp3-pass-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-input, #f8fafc);cursor:pointer;transition:all .15s;font-family:inherit}.hp3-pass-item input{accent-color:var(--primary, #2563eb);flex-shrink:0;cursor:pointer}.hp3-pass-item--sel{border-color:var(--primary, #2563eb);background:#eff6ff}.hp3-pass-name{font-size:13px;font-weight:600;color:var(--tx1, #0f172a)}.hp3-pass-meta{font-size:11px;color:var(--tx3, #94a3b8);margin-top:2px}.hp3-staff-list{display:flex;flex-direction:column;gap:6px;max-height:280px;overflow-y:auto}.hp3-staff-item{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:10px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);cursor:pointer;transition:all .15s}.hp3-staff-item:hover{border-color:var(--primary, #2563eb);background:#fafbff}.hp3-staff-item--sel{border-color:#16a34a;background:#f0fdf4}.hp3-staff-name{font-size:13px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:6px}.hp3-staff-meta{font-size:11px;color:var(--tx3, #94a3b8);margin-top:2px}.hp3-staff-pending{font-size:11px;font-weight:600;color:#d97706;background:#fef3c7;border:1px solid #fde68a;border-radius:8px;padding:2px 7px;flex-shrink:0}.hp3-online-pip{display:inline-block;width:7px;height:7px;border-radius:50%;background:#16a34a;box-shadow:0 0 0 2px #16a34a33}.hp3-alert--warn{display:flex;align-items:flex-start;gap:8px;background:#fffbeb;border:1px solid #fde68a;border-radius:9px;padding:11px 13px;font-size:13px;color:#92400e;line-height:1.55}.hp3-log{display:flex;flex-direction:column}.hp3-log-row{display:grid;grid-template-columns:140px 90px 1fr 120px 1fr 30px;align-items:center;gap:12px;padding:11px 16px;border-bottom:1px solid var(--border, #e2e8f0);font-size:12px;animation:hp3-row-in .2s ease both;transition:background .12s}.hp3-log-row:last-child{border-bottom:none}.hp3-log-row:hover{background:#fafbff}.hp3-log-row--unread{background:#f8fbff}.hp3-log-row:nth-child(odd){background:#fafbfc}.hp3-log-row:nth-child(odd).hp3-log-row--unread{background:#f0f7ff}.hp3-log-row__time{font-family:DM Mono,monospace;color:var(--tx3, #94a3b8);white-space:nowrap;font-size:11px}.hp3-log-row__type{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:10px;font-size:10px;font-weight:700;white-space:nowrap}.hp3-log-row__name{font-weight:700;color:var(--tx1, #0f172a)}.hp3-log-row__org{color:var(--tx3, #94a3b8)}.hp3-log-row__msg{color:var(--tx2, #475569)}.hp3-log-row__read{display:flex;justify-content:center}.hp3-arrival-bg{position:fixed;inset:0;z-index:1000;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px;animation:hp3-bg-in .25s ease;font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes hp3-bg-in{0%{opacity:0}to{opacity:1}}.hp3-arrival{background:var(--bg-card, #fff);border-radius:24px;padding:40px 36px;max-width:420px;width:100%;text-align:center;box-shadow:0 40px 80px -20px #00000080;animation:hp3-modal-spring .3s cubic-bezier(.4,0,.2,1)}@keyframes hp3-modal-spring{0%{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:none}}.hp3-arrival__ring{position:relative;width:80px;height:80px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center}.hp3-arrival__ring-inner,.hp3-arrival__ring-outer{position:absolute;inset:0;border-radius:50%;border:2px solid}.hp3-arrival__ring-inner{border-color:#2563eb66;animation:hp3-ring-pulse 1.5s ease-in-out infinite}.hp3-arrival__ring-outer{border-color:#2563eb26;animation:hp3-ring-pulse 1.5s ease-in-out .5s infinite}@keyframes hp3-ring-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.18);opacity:.4}}.hp3-arrival__ring-icon{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 20px #2563eb66}.hp3-arrival__eyebrow{font-size:11px;font-weight:700;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}.hp3-arrival__name{font-size:22px;font-weight:800;color:var(--tx1, #0f172a);margin-bottom:14px}.hp3-arrival__chips{display:flex;justify-content:center;flex-wrap:wrap;gap:6px;margin-bottom:14px}.hp3-arrival__chip{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:20px;background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);font-size:12px;color:var(--tx2, #475569);font-weight:500}.hp3-arrival__since{font-size:12px;color:var(--tx3, #94a3b8);display:flex;align-items:center;justify-content:center;gap:5px;margin-bottom:24px}.hp3-arrival__actions{display:flex;flex-direction:column;gap:8px}.hp3-modal-bg{position:fixed;inset:0;z-index:900;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;animation:hp3-bg-in .2s ease;font-family:Plus Jakarta Sans,system-ui,sans-serif}.hp3-modal{background:var(--bg-card, #fff);border-radius:18px;max-width:540px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 32px 64px -20px #00000059;animation:hp3-modal-spring .22s cubic-bezier(.4,0,.2,1)}.hp3-modal--sm{max-width:420px}.hp3-modal__hdr{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 14px;border-bottom:1px solid var(--border, #f1f5f9);gap:12px}.hp3-modal__hdr-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.hp3-modal__icon--warn{background:#fef3c7;color:#d97706}.hp3-modal__title{font-size:15px;font-weight:800;color:var(--tx1, #0f172a)}.hp3-modal__sub{font-size:12px;color:var(--tx3, #64748b);margin-top:2px}.hp3-modal__close{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-input, #f8fafc);color:var(--tx2, #475569);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.hp3-modal__close:hover{background:#fee2e2;color:#dc2626;border-color:#dc2626;transform:rotate(90deg)}.hp3-modal__body{padding:18px 22px}.hp3-modal__text{font-size:13px;color:var(--tx2, #475569);line-height:1.7;margin:0}.hp3-modal__foot{padding:12px 22px;border-top:1px solid var(--border, #f1f5f9);display:flex;justify-content:flex-end;gap:8px}.hp3-detail-grid{display:flex;flex-direction:column;border:1px solid var(--border, #e2e8f0);border-radius:10px;overflow:hidden}.hp3-detail-row{display:flex;align-items:flex-start;gap:12px;padding:9px 13px;border-bottom:1px solid var(--border, #f1f5f9)}.hp3-detail-row:last-child{border-bottom:none}.hp3-detail-row:nth-child(odd){background:var(--bg-input, #f8fafc)}.hp3-detail-k{font-size:10px;font-weight:700;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.4px;min-width:110px;flex-shrink:0;padding-top:1px}.hp3-detail-v{font-size:12px;font-weight:600;color:var(--tx1, #0f172a)}.hp3-skel-list{display:flex;flex-direction:column;gap:0}.hp3-skel-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border, #e2e8f0);animation:hp3-row-in .25s ease both}.hp3-skel-card:last-child{border-bottom:none}.hp3-skel{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;border-radius:5px;height:12px;animation:hp3-shimmer 1.4s linear infinite}.hp3-skel--circle{width:38px;height:38px;border-radius:50%;flex-shrink:0}@keyframes hp3-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.hp3-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 24px}.hp3-empty--inline{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:8px;padding:14px 0;text-align:left;font-size:13px;color:var(--tx3, #94a3b8)}.hp3-empty__icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);display:flex;align-items:center;justify-content:center;color:#94a3b8;margin-bottom:16px}.hp3-empty__title{font-size:15px;font-weight:700;color:var(--tx1, #0f172a);margin-bottom:6px}.hp3-empty__sub{font-size:13px;color:var(--tx3, #64748b);max-width:320px;line-height:1.6}@media(max-width:1024px){.hp3-kpi-strip{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.hp3-kpi-strip{grid-template-columns:repeat(2,1fr)}.hp3-hdr{flex-direction:column}.hp3-handover{grid-template-columns:1fr}.hp3-handover__arrow{display:none}.hp3-handover__col{border-bottom:1px solid var(--border, #e2e8f0)}.hp3-log-row{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}.hp3-log-row__org,.hp3-log-row__read{display:none}.hp3-tabs{gap:1px;padding:3px}.hp3-tab{font-size:11px;padding:8px 6px;gap:4px}.hp3-modal__hdr,.hp3-modal__body,.hp3-modal__foot{padding:14px 16px}}@media(max-width:480px){.hp3-kpi-strip{grid-template-columns:1fr 1fr}.hp3-offline__card{padding:28px 22px}.hp3-offline__features{grid-template-columns:1fr}}.hp3-alert{display:flex;align-items:flex-start;gap:8px;padding:11px 13px;border-radius:9px;font-size:13px;line-height:1.55}.hp3-kpi__body{flex:1;min-width:0}@media print{.hp3-hdr__right,.hp3-tabs,.hp3-filter-bar,.hp3-vc__actions,.hp3-arrival-bg,.hp3-modal-bg{display:none!important}.hp3-vc--attended{opacity:.7}}.hp3-tab__badge--amber{background:#d97706}.hp3-vc__desc{font-size:11px;font-style:italic;color:var(--tx3, #94a3b8);margin-top:4px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:360px}.hp3-followup-badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#fef3c7;color:#d97706;border:1px solid #fde68a;margin-left:5px;vertical-align:middle}.hp3-arrival__desc{font-size:12px;font-style:italic;color:var(--tx3, #94a3b8);margin-bottom:10px;text-align:center;max-width:320px}.hp3-modal__icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hp3-form-group{display:flex;flex-direction:column;gap:6px}.hp3-form-label{font-size:12px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:4px}.hp3-spin{animation:hp3-spin-icon 1s linear infinite}@keyframes hp3-spin-icon{to{transform:rotate(360deg)}}.hp3-eq-list{display:flex;flex-direction:column}.hp3-eq-row{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border-bottom:1px solid var(--border, #e2e8f0);animation:hp3-row-in .2s ease both;transition:background .12s}.hp3-eq-row:last-child{border-bottom:none}.hp3-eq-row:hover{background:#fafbff}.hp3-eq-row__vis{display:flex;align-items:flex-start;gap:9px;min-width:160px;flex-shrink:0}.hp3-eq-row__vis-info{min-width:0}.hp3-eq-row__name{font-size:13px;font-weight:700;color:var(--tx1, #0f172a);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.hp3-eq-row__meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:3px;font-size:11px;color:var(--tx3, #64748b)}.hp3-eq-row__meta span{display:inline-flex;align-items:center;gap:3px}.hp3-eq-row__body{flex:1;min-width:0}.hp3-eq-row__cats{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.hp3-eq-row__status-line{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:5px}.hp3-eq-status{display:inline-flex;align-items:center;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700}.hp3-eq-followup{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;background:#fef3c7;color:#d97706;border:1px solid #fde68a;font-size:10px;font-weight:600}.hp3-eq-time{font-size:10px;color:var(--tx3, #94a3b8);font-family:DM Mono,monospace;margin-left:auto}.hp3-eq-row__remarks{font-size:12px;color:var(--tx2, #475569);line-height:1.55;margin-bottom:3px}.hp3-eq-row__desc{font-size:11px;font-style:italic;color:var(--tx3, #94a3b8)}@media(max-width:768px){.hp3-eq-row{flex-direction:column}.hp3-eq-row__vis{min-width:unset}.hp3-eq-time{margin-left:0}}.hp3-returning-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:10px;background:linear-gradient(135deg,#fef3c7,#fffbeb);color:#92400e;border:1px solid #fde68a;font-size:10px;font-weight:700;margin-left:5px;vertical-align:middle}.hp3-vc__visit-desc{display:flex;align-items:flex-start;gap:5px;margin-top:5px;font-size:12px;color:var(--tx2, #475569);line-height:1.5;background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-left:3px solid var(--primary, #2563eb);border-radius:6px;padding:5px 10px}.hp3-vc__visit-desc svg{color:var(--primary, #2563eb);flex-shrink:0;margin-top:1px}.hp3-vc__phone{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--tx3, #64748b);margin-top:2px}.hp3-modal__desc-banner{display:flex;align-items:flex-start;gap:8px;padding:10px 22px;background:linear-gradient(135deg,#eff6ff,#f0f9ff);border-bottom:1px solid #bfdbfe;font-size:13px;color:#1e40af;line-height:1.55}.hp3-modal__desc-banner svg{flex-shrink:0;margin-top:1px;color:#2563eb}.hp3-modal__tabs{display:flex;gap:2px;padding:0 22px;border-bottom:1px solid var(--border, #e2e8f0);background:var(--bg-input, #f8fafc)}.hp3-modal__tab{display:flex;align-items:center;gap:6px;padding:10px 14px;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--tx3, #64748b);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;margin-bottom:-1px}.hp3-modal__tab:hover{color:var(--tx1, #0f172a)}.hp3-modal__tab--active{color:var(--primary, #2563eb);border-bottom-color:var(--primary, #2563eb);background:var(--bg-card, #fff)}.hp3-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3, #94a3b8);margin-bottom:8px}.hp3-eq-timeline{display:flex;flex-direction:column;gap:0;position:relative}.hp3-eq-tl-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border, #f1f5f9);position:relative}.hp3-eq-tl-item:last-child{border-bottom:none}.hp3-eq-tl-item:before{content:"";position:absolute;left:5px;top:30px;bottom:-1px;width:2px;background:var(--border, #e2e8f0);z-index:0}.hp3-eq-tl-item:last-child:before{display:none}.hp3-eq-tl-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:4px;z-index:1;border:2px solid #fff;box-shadow:0 0 0 2px currentColor}.hp3-eq-tl-body{flex:1;min-width:0}.hp3-eq-tl-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.hp3-eq-tl-date{font-size:11px;color:var(--tx3, #94a3b8);font-family:DM Mono,monospace}.hp3-eq-tl-visit-ctx{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:4px}.hp3-eq-tl-remarks{font-size:12px;color:var(--tx2, #475569);line-height:1.55;margin-top:4px;padding:6px 10px;background:var(--bg-input, #f8fafc);border-radius:6px;border-left:2px solid var(--border, #e2e8f0)}.hp3-eq-tl-followup-notes{display:flex;align-items:flex-start;gap:5px;font-size:11px;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:5px 8px;margin-top:4px}.hp3-eq-tl-item--compact{padding:8px 0}.hp3-arrival__desc-box{display:flex;align-items:flex-start;justify-content:center;gap:6px;font-size:12px;color:#1e40af;background:linear-gradient(135deg,#eff6ff,#f0f9ff);border:1px solid #bfdbfe;border-radius:10px;padding:8px 14px;margin-bottom:12px;max-width:340px;margin-left:auto;margin-right:auto;line-height:1.5}.hp3-arrival__desc-box svg{flex-shrink:0;margin-top:1px}@media(max-width:768px){.hp3-modal__tabs{padding:0 16px;overflow-x:auto}.hp3-modal__desc-banner{padding:8px 16px}}.hp3-vc--completed{opacity:.65;background:#f8fafc}.hp3-vc--completed:hover{background:#f1f5f9!important;opacity:.8}.hp3-status-legend{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:8px 16px;border-bottom:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff)}.hp3-status-legend:before{content:"Status:";font-size:10px;font-weight:700;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.4px;flex-shrink:0}.rpt-kpi-strip{display:grid;grid-template-columns:repeat(8,1fr);gap:10px;margin-bottom:22px}.rpt-kpi-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:12px 14px;transition:transform .18s,box-shadow .18s}.rpt-kpi-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000012}.rpt-kpi-val{font-size:22px;font-weight:800;letter-spacing:-1px;line-height:1;margin-bottom:3px}.rpt-kpi-lbl{font-size:9px;font-weight:700;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px}.rpt-date-bar{display:flex;gap:4px;flex-wrap:wrap;align-items:center}.rpt-date-input{background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:12px;padding:7px 10px;outline:none;font-family:inherit;font-weight:600;cursor:pointer;transition:border-color .18s,box-shadow .18s}.rpt-date-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.rpt-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;flex-wrap:wrap}.rpt-catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.rpt-report-card{position:relative;background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:14px;padding:16px 18px 14px;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s;text-align:left;overflow:hidden;font-family:inherit}.rpt-report-card:hover{transform:translateY(-3px);box-shadow:0 10px 32px #0000001a;border-color:var(--accent, #e2e8f0)}.rpt-report-card__accent{position:absolute;top:0;left:0;bottom:0;width:4px;border-radius:14px 0 0 14px}.rpt-report-card__icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center}.rpt-report-card__label{font-size:13px;font-weight:800;color:var(--tx1, #0f172a);margin-bottom:4px;letter-spacing:-.2px;line-height:1.3}.rpt-report-card__desc{font-size:11px;color:var(--tx3, #64748b);line-height:1.55}.rpt-report-card__cat{display:inline-flex;align-items:center;font-size:9px;font-weight:700;padding:2px 7px;border-radius:6px;background:var(--bg, #f1f5f9);color:var(--tx3, #64748b);margin-top:9px;letter-spacing:.4px;text-transform:uppercase}.rpt-sub-actions{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}.rpt-dl-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;transition:all .16s;font-family:inherit;white-space:nowrap;border:1.5px solid transparent}.rpt-dl-btn--excel{background:#16a34a;color:#fff;border-color:#16a34a}.rpt-dl-btn--excel:hover{background:#15803d;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}.rpt-dl-btn--pdf{background:#dc2626;color:#fff;border-color:#dc2626}.rpt-dl-btn--pdf:hover{background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.rpt-tr--peak td{background:#eff6ff!important}.rpt-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding:0 2px;flex-wrap:wrap;gap:10px}.rpt-pagination__info{font-size:12px;color:var(--tx3, #94a3b8)}@media(max-width:1600px){.rpt-kpi-strip{grid-template-columns:repeat(4,1fr)}}@media(max-width:1200px){.rpt-kpi-strip{grid-template-columns:repeat(4,1fr)}.rpt-catalog-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:1024px){.rpt-kpi-strip{grid-template-columns:repeat(4,1fr)}.rpt-catalog-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.rpt-kpi-strip{grid-template-columns:repeat(2,1fr)}.rpt-catalog-grid{grid-template-columns:1fr}.rpt-date-bar{display:none}.av2-page-header{flex-direction:column;gap:12px}}@media(max-width:480px){.rpt-kpi-strip{grid-template-columns:1fr 1fr}}@media print{.av2-page-header__right,.rpt-sub-actions,.rpt-date-bar,.rpt-breadcrumb,.rpt-pagination,.av2-filter-row,.av2-tab-bar{display:none!important}.rpt-kpi-strip{break-inside:avoid}}:root{--ai-bg: #f8fafc;--ai-card: #ffffff;--ai-border: #e2e8f0;--ai-border2: #cbd5e1;--ai-text: #0f172a;--ai-text2: #334155;--ai-muted: #64748b;--ai-faint: #94a3b8;--ai-primary: #2563eb;--ai-primary-lt: #eff6ff;--ai-success: #16a34a;--ai-success-lt: #f0fdf4;--ai-warning: #d97706;--ai-warning-lt: #fffbeb;--ai-danger: #dc2626;--ai-danger-lt: #fef2f2;--ai-purple: #7c3aed;--ai-cyan: #0891b2;--ai-shadow: 0 1px 4px rgba(0, 0, 0, .06);--ai-shadow-md: 0 4px 16px rgba(0, 0, 0, .09);--ai-radius: 12px;--ai-radius-sm: 8px}[data-theme=dark]{--ai-bg: #0f172a;--ai-card: #1e293b;--ai-border: #334155;--ai-border2: #475569;--ai-text: #f1f5f9;--ai-text2: #cbd5e1;--ai-muted: #94a3b8;--ai-faint: #64748b;--ai-primary-lt: rgba(37, 99, 235, .15);--ai-success-lt: rgba(22, 163, 74, .12);--ai-warning-lt: rgba(217, 119, 6, .12);--ai-danger-lt: rgba(220, 38, 38, .12)}.ai2-root{display:flex;flex-direction:column;font-family:inherit;color:var(--ai-text);background:var(--ai-bg);min-height:calc(100vh - 64px)}.ai-banner{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:13px;font-weight:500;animation:ai-slide-down .25s ease}@keyframes ai-slide-down{0%{transform:translateY(-100%);opacity:0}to{transform:none;opacity:1}}.ai-banner--critical{background:#fef2f2;border-bottom:2px solid #dc2626;color:#7f1d1d}.ai-banner--warning{background:#fffbeb;border-bottom:2px solid #d97706;color:#78350f}.ai-banner--info{background:#eff6ff;border-bottom:2px solid #2563eb;color:#1e3a8a}[data-theme=dark] .ai-banner--critical{background:#dc262626}[data-theme=dark] .ai-banner--warning{background:#d9770626}[data-theme=dark] .ai-banner--info{background:#2563eb26}.ai-banner__icon{flex-shrink:0}.ai-banner__body{flex:1}.ai-banner__title{font-weight:700}.ai-banner__body-text{opacity:.85}.ai-banner__action{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;background:#00000014;color:inherit;text-decoration:none;transition:background .15s}.ai-banner__action:hover{background:#00000026}.ai-banner__dismiss{background:none;border:none;cursor:pointer;opacity:.6;padding:2px}.ai-banner__dismiss:hover{opacity:1}.ai2-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 12px;gap:16px;flex-wrap:wrap}.ai2-hdr-left,.ai2-hdr-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ai2-title-wrap{display:flex;align-items:center;gap:12px}.ai2-title-icon{width:40px;height:40px;border-radius:12px;position:relative;background:linear-gradient(135deg,#2563eb,#7c3aed);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 14px #2563eb59}.ai2-title-glow{position:absolute;inset:0;border-radius:12px;background:linear-gradient(135deg,#2563eb,#7c3aed);animation:ai-glow 3s infinite;opacity:.5}@keyframes ai-glow{0%,to{box-shadow:0 0 8px #2563eb66}50%{box-shadow:0 0 18px #7c3aed99}}.ai2-page-title{font-size:22px;font-weight:800;color:var(--ai-text);letter-spacing:-.4px}.ai2-page-sub{font-size:12px;color:var(--ai-muted);margin-top:2px}.ai2-v3-badge{display:inline-flex;align-items:center;padding:1px 7px;background:linear-gradient(135deg,#7c3aed,#2563eb);color:#fff;border-radius:6px;font-size:10px;font-weight:800;letter-spacing:.5px;vertical-align:middle;margin-left:6px}.ai2-status{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid var(--ai-border)}.ai2-status--ok{background:var(--ai-success-lt);color:var(--ai-success);border-color:#16a34a4d}.ai2-status--warn{background:var(--ai-warning-lt);color:var(--ai-warning);border-color:#d977064d}.ai2-status--err{background:var(--ai-danger-lt);color:var(--ai-danger);border-color:#dc26264d}.ai2-status--loading{background:var(--ai-bg);color:var(--ai-muted)}.ai2-dot{width:7px;height:7px;border-radius:50%;background:currentColor;animation:ai-pulse 1.8s infinite}@keyframes ai-pulse{0%,to{opacity:1}50%{opacity:.35}}.ai2-icon-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--ai-border);background:var(--ai-card);color:var(--ai-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.ai2-icon-btn:hover{background:var(--ai-bg);color:var(--ai-text)}.ai2-session-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:12px;background:var(--ai-bg);border:1px solid var(--ai-border);font-size:11px;color:var(--ai-muted)}.ai2-tabs{display:flex;align-items:center;gap:2px;padding:0 24px;border-bottom:1px solid var(--ai-border);overflow-x:auto}.ai2-tab{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;border:none;background:none;color:var(--ai-muted);font-size:13px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap}.ai2-tab:hover{color:var(--ai-text)}.ai2-tab--active{color:var(--ai-primary);border-bottom-color:var(--ai-primary)}.ai2-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;background:var(--ai-danger);color:#fff;border-radius:8px;font-size:10px;font-weight:800;margin-left:4px}.ai2-tab-badge--warn{background:var(--ai-warning)}.ai2-tabs-spacer{flex:1}.ai2-shortcut-hint{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--ai-faint);padding:0 4px}.ai2-chat-panel{display:flex;flex-direction:column;flex:1;padding:0 24px 16px}.ai2-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 0 8px}.ai2-toolbar__count{font-size:12px;color:var(--ai-muted)}.ai2-toolbar-actions{display:flex;gap:8px}.ai2-sm-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--ai-radius-sm);border:1px solid var(--ai-border);background:var(--ai-card);color:var(--ai-text2);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.ai2-sm-btn:hover:not(:disabled){background:var(--ai-bg)}.ai2-sm-btn:disabled{opacity:.5;cursor:not-allowed}.ai2-sm-btn--danger{color:var(--ai-danger);border-color:#dc262640}.ai2-sm-btn--danger:hover:not(:disabled){background:var(--ai-danger-lt)}.ai2-messages{display:flex;flex-direction:column;gap:16px;padding:8px 0;flex:1;overflow-y:auto;min-height:200px}.ai2-bubble{display:flex;gap:10px;animation:ai-msg-in .2s ease}@keyframes ai-msg-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.ai2-bubble--user{flex-direction:row-reverse}.ai2-bubble__avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:4px}.ai2-bubble--ai .ai2-bubble__avatar{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff}.ai2-bubble--user .ai2-bubble__avatar{background:var(--ai-bg);border:1px solid var(--ai-border);color:var(--ai-muted)}.ai2-bubble__body{max-width:80%;display:flex;flex-direction:column;gap:4px}.ai2-bubble--user .ai2-bubble__body{align-items:flex-end}.ai2-bubble__content{padding:11px 14px;border-radius:var(--ai-radius);font-size:13.5px;line-height:1.6;background:var(--ai-card);border:1px solid var(--ai-border);color:var(--ai-text)}.ai2-bubble--user .ai2-bubble__content{background:var(--ai-primary);color:#fff;border-color:transparent}.ai2-bubble__content--md h2,.ai2-bubble__content--md h3{font-weight:700;margin:10px 0 4px}.ai2-bubble__content--md ul{padding-left:18px;margin:6px 0}.ai2-bubble__content--md li{margin:3px 0}.ai2-bubble__content--md pre{background:#0000000f;border-radius:6px;padding:10px 12px;overflow-x:auto;font-size:12px;margin:8px 0}.ai2-bubble__content--md code{background:#00000012;border-radius:4px;padding:1px 5px;font-size:12px}.ai2-bubble__content--md table{width:100%;border-collapse:collapse;font-size:12px;margin:8px 0}.ai2-bubble__content--md th{background:var(--ai-bg);padding:6px 10px;border:1px solid var(--ai-border);font-weight:700;font-size:11px;text-align:left}.ai2-bubble__content--md td{padding:6px 10px;border:1px solid var(--ai-border)}.ai2-tools-used{display:flex;align-items:center;gap:5px;flex-wrap:wrap;padding:4px 8px;background:var(--ai-primary-lt);border:1px solid rgba(37,99,235,.2);border-radius:6px;font-size:10px;font-weight:600;color:var(--ai-primary);margin-top:2px}.ai2-thinking{display:flex;align-items:center;gap:8px;padding:8px 0 4px}.ai2-thinking__dots{display:flex;gap:4px}.ai2-thinking__dots span{width:5px;height:5px;border-radius:50%;background:var(--ai-primary);animation:ai-bounce .7s infinite}.ai2-thinking__dots span:nth-child(2){animation-delay:.12s}.ai2-thinking__dots span:nth-child(3){animation-delay:.24s}@keyframes ai-bounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.ai2-thinking__label{font-size:11px;color:var(--ai-muted)}.ai2-cursor{display:inline-block;width:2px;height:14px;background:var(--ai-primary);margin-left:3px;animation:ai-blink .9s infinite;vertical-align:middle}@keyframes ai-blink{0%,to{opacity:1}50%{opacity:0}}.ai2-bubble__actions{display:flex;align-items:center;gap:8px;padding-top:4px}.ai2-action-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;border:1px solid var(--ai-border);background:none;font-size:11px;font-weight:600;color:var(--ai-muted);cursor:pointer;transition:all .15s}.ai2-action-btn:hover{background:var(--ai-bg);color:var(--ai-text)}.ai2-bubble__rating{display:flex;gap:4px;margin-left:auto}.ai2-rate-btn{width:24px;height:24px;border-radius:6px;border:1px solid var(--ai-border);background:none;color:var(--ai-faint);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.ai2-rate-btn:hover{background:var(--ai-bg)}.ai2-rate-btn--good{background:var(--ai-success-lt);color:var(--ai-success);border-color:#16a34a4d}.ai2-rate-btn--bad{background:var(--ai-danger-lt);color:var(--ai-danger);border-color:#dc26264d}.ai2-quick-section{padding:8px 0 0}.ai2-category-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.ai2-cat-btn{padding:5px 12px;border-radius:16px;border:1px solid var(--ai-border);background:var(--ai-card);font-size:12px;font-weight:600;color:var(--ai-muted);cursor:pointer;transition:all .15s}.ai2-cat-btn:hover{border-color:var(--ai-primary);color:var(--ai-primary)}.ai2-cat-btn--active{background:var(--ai-primary);border-color:var(--ai-primary);color:#fff}.ai2-search-input{width:100%;padding:8px 12px;border:1.5px solid var(--ai-border);border-radius:var(--ai-radius-sm);font-size:13px;background:var(--ai-card);color:var(--ai-text);outline:none;margin-bottom:8px}.ai2-search-input:focus{border-color:var(--ai-primary)}.ai2-quick-label{font-size:11px;font-weight:700;color:var(--ai-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.ai2-quick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;margin-bottom:12px}.ai2-quick-btn{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 10px;border-radius:10px;border:1.5px solid var(--ai-border);background:var(--ai-card);cursor:pointer;font-size:12px;font-weight:600;color:var(--ai-text2);transition:all .15s;position:relative}.ai2-quick-btn:hover{border-color:var(--ai-primary);background:var(--ai-primary-lt);color:var(--ai-primary)}.ai2-quick-btn--highlight{border-color:var(--ai-purple);background:linear-gradient(135deg,#f5f3ff,#eff6ff);color:var(--ai-purple)}.ai2-quick-btn--highlight:hover{background:linear-gradient(135deg,#ede9fe,#dbeafe)}.ai2-quick-btn__icon{color:inherit}.ai2-sparkle{position:absolute;top:6px;right:6px;color:var(--ai-purple)}.ai2-mic-btn{width:48px;height:48px;border-radius:50%;border:2px solid var(--ai-border);background:var(--ai-card);color:var(--ai-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;align-self:flex-end}.ai2-mic-btn:hover:not(:disabled){border-color:var(--ai-primary);color:var(--ai-primary);background:var(--ai-primary-lt)}.ai2-mic-btn--active{background:linear-gradient(135deg,var(--ai-danger),#ff4d4f);border-color:var(--ai-danger);color:#fff;box-shadow:0 0 0 4px #dc262633;animation:ai-mic-pulse 1.2s infinite}@keyframes ai-mic-pulse{0%,to{box-shadow:0 0 0 4px #dc262633}50%{box-shadow:0 0 0 8px #dc262614}}.ai2-mic-btn:disabled{opacity:.4;cursor:not-allowed}.ai2-voice-status{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--ai-primary-lt);border:1px solid rgba(37,99,235,.2);border-radius:8px;font-size:12px;color:var(--ai-primary);margin-bottom:8px}.ai2-voice-status--listening{background:#fef2f2;border-color:#dc262640;color:var(--ai-danger)}.ai2-voice-pulse{width:8px;height:8px;border-radius:50%;background:currentColor;animation:ai-pulse .6s infinite;flex-shrink:0}.ai2-voice-intent{font-weight:600}.ai2-voice-error{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ai-danger);margin-bottom:6px}.ai2-input-area{display:flex;flex-direction:column;gap:6px;padding-top:8px;border-top:1px solid var(--ai-border)}.ai2-input-row{display:flex;gap:8px;align-items:flex-end}.ai2-input-wrap{flex:1}.ai2-textarea{width:100%;padding:10px 13px;border:1.5px solid var(--ai-border);border-radius:var(--ai-radius);font-size:13px;font-family:inherit;background:var(--ai-card);color:var(--ai-text);resize:none;outline:none;transition:border-color .15s}.ai2-textarea:focus{border-color:var(--ai-primary);box-shadow:0 0 0 3px #2563eb14}.ai2-textarea:disabled{opacity:.6}.ai2-input-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding-top:4px}.ai2-char-count{font-size:10px;color:var(--ai-faint)}.ai2-char-count--warn{color:var(--ai-warning)}.ai2-char-bar{width:60px;height:3px;background:var(--ai-border);border-radius:2px;overflow:hidden}.ai2-char-fill{height:100%;border-radius:2px;transition:width .2s}.ai2-send-row{display:flex;flex-direction:column}.ai2-send-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:var(--ai-radius-sm);border:none;background:var(--ai-primary);color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:all .18s}.ai2-send-btn:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d}.ai2-send-btn:disabled{opacity:.5;cursor:not-allowed}.ai2-send-btn--stop{background:var(--ai-danger)}.ai2-send-btn--stop:hover{background:#b91c1c}.ai2-error-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--ai-danger-lt);border:1px solid rgba(220,38,38,.25);border-radius:8px;font-size:12px;color:var(--ai-danger)}.ai2-error-bar button{margin-left:auto;background:none;border:none;cursor:pointer;color:inherit}.ai2-followups{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:6px 0 0}.ai2-followups__label{font-size:11px;color:var(--ai-muted);font-weight:600;flex-shrink:0}.ai2-followup-chip{padding:5px 12px;border-radius:14px;border:1px solid var(--ai-border);background:var(--ai-card);font-size:12px;color:var(--ai-text2);cursor:pointer;transition:all .15s}.ai2-followup-chip:hover{border-color:var(--ai-primary);color:var(--ai-primary);background:var(--ai-primary-lt)}.ai2-insights-panel{display:flex;flex-direction:column;gap:14px;padding:16px 24px}.ai2-insights-hdr{display:flex;align-items:center;justify-content:space-between;gap:8px}.ai2-insights-title{display:flex;align-items:center;gap:7px;font-size:15px;font-weight:700;color:var(--ai-text)}.ai2-insights-subtitle{font-size:12px;font-weight:400;color:var(--ai-muted);margin-left:4px}.ai2-insights-list{display:flex;flex-direction:column;gap:8px}.ai2-insight{border-radius:10px;border:1.5px solid transparent;overflow:hidden;animation:ai-msg-in .2s ease both}.ai2-insight--critical{background:var(--ai-danger-lt);border-color:#dc26264d}.ai2-insight--warning{background:var(--ai-warning-lt);border-color:#d977064d}.ai2-insight--success{background:var(--ai-success-lt);border-color:#16a34a4d}.ai2-insight--info{background:var(--ai-primary-lt);border-color:#2563eb33}.ai2-insight--pulse{animation:ai-insight-pulse 2s infinite}@keyframes ai-insight-pulse{0%,to{box-shadow:none}50%{box-shadow:0 0 0 3px #dc262633}}.ai2-insight__header{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer}.ai2-insight__icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#00000012}.ai2-insight--critical .ai2-insight__icon{color:var(--ai-danger)}.ai2-insight--warning .ai2-insight__icon{color:var(--ai-warning)}.ai2-insight--success .ai2-insight__icon{color:var(--ai-success)}.ai2-insight--info .ai2-insight__icon{color:var(--ai-primary)}.ai2-insight__title{flex:1;font-size:13px;font-weight:700;color:var(--ai-text)}.ai2-insight__toggle{background:none;border:none;cursor:pointer;color:var(--ai-muted);padding:2px}.ai2-insight__body{padding:4px 14px 12px 52px}.ai2-insight__text{font-size:13px;color:var(--ai-text2);line-height:1.5;margin-bottom:8px}.ai2-insight__ctas{display:flex;gap:8px}.ai2-insight__ask{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;background:var(--ai-primary);color:#fff;border:none;border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;transition:background .15s}.ai2-insight__ask:hover{background:#1d4ed8}.ai2-insight__link{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border:1px solid var(--ai-border);border-radius:6px;font-size:11px;font-weight:600;color:var(--ai-text2);text-decoration:none;transition:all .15s}.ai2-insight__link:hover{background:var(--ai-bg)}.ai2-shortcuts{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.ai2-shortcuts__title{width:100%;font-size:11px;font-weight:700;color:var(--ai-muted);text-transform:uppercase;letter-spacing:.5px}.ai2-shortcut{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:1px solid var(--ai-border);background:var(--ai-card);font-size:12px;color:var(--ai-text2);text-decoration:none;transition:all .15s}.ai2-shortcut:hover{border-color:var(--ai-primary);color:var(--ai-primary);background:var(--ai-primary-lt)}.ai2-charts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.ai-chart-wrap{background:var(--ai-card);border:1px solid var(--ai-border);border-radius:var(--ai-radius);padding:14px 16px}.ai-chart-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--ai-text2);margin-bottom:10px;text-transform:uppercase;letter-spacing:.4px}.ai2-anomaly-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.ai2-anomaly{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:10px;border:1.5px solid transparent;animation:ai-msg-in .2s ease}.ai2-anomaly--high{background:var(--ai-danger-lt);border-color:#dc26264d}.ai2-anomaly--medium{background:var(--ai-warning-lt);border-color:#d977064d}.ai2-anomaly--ok{background:var(--ai-success-lt);border-color:#16a34a4d}.ai2-anomaly--high .ai2-anomaly__icon{color:var(--ai-danger)}.ai2-anomaly--medium .ai2-anomaly__icon{color:var(--ai-warning)}.ai2-anomaly--ok .ai2-anomaly__icon{color:var(--ai-success)}.ai2-anomaly__icon{flex-shrink:0;margin-top:2px}.ai2-anomaly__body{flex:1}.ai2-anomaly__type{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;opacity:.65;margin-bottom:3px}.ai2-anomaly__msg{font-size:13px;line-height:1.5}.ai2-anomaly__ask{padding:6px 12px;background:transparent;border:1px solid currentColor;border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;opacity:.7;transition:opacity .15s;flex-shrink:0;align-self:center}.ai2-anomaly__ask:hover{opacity:1}.ai2-baseline-card{padding:14px 16px;background:var(--ai-bg);border:1px solid var(--ai-border);border-radius:10px;margin-bottom:14px}.ai2-baseline-card__title{font-size:11px;font-weight:700;color:var(--ai-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.ai2-baseline-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}.ai2-baseline-grid>div{display:flex;flex-direction:column;gap:2px}.ai2-baseline-grid span{font-size:11px;color:var(--ai-muted)}.ai2-baseline-grid strong{font-size:18px;font-weight:800}.ai2-forecast-card{padding:14px 16px;background:var(--ai-primary-lt);border:1px solid rgba(37,99,235,.2);border-radius:10px;margin-top:14px}.ai2-forecast-card__title{font-size:11px;font-weight:700;color:var(--ai-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.ai2-forecast-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:13px}.ai2-forecast-grid>div{display:flex;flex-direction:column;gap:2px}.ai2-forecast-grid span:first-child{font-size:11px;color:var(--ai-primary)}.ai2-forecast-grid strong{font-weight:700}.ai2-forecast-peak,.ai2-forecast-rec{grid-column:1/-1}.ai2-trend-summary{margin-bottom:14px}.ai2-trend-direction{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:700;margin-bottom:12px}.ai2-trend-direction--up{background:var(--ai-success-lt);color:var(--ai-success);border:1px solid rgba(22,163,74,.3)}.ai2-trend-direction--down{background:var(--ai-danger-lt);color:var(--ai-danger);border:1px solid rgba(220,38,38,.3)}.ai2-trend-direction--stable{background:var(--ai-bg);color:var(--ai-muted);border:1px solid var(--ai-border)}.ai2-trend-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid var(--ai-border)}.ai2-trend-table-title{font-size:11px;font-weight:700;color:var(--ai-muted);padding:10px 14px 0;text-transform:uppercase;letter-spacing:.4px}.ai2-trend-table{width:100%;border-collapse:collapse;font-size:13px}.ai2-trend-table th{padding:8px 14px;background:var(--ai-bg);font-size:11px;font-weight:700;text-transform:uppercase;color:var(--ai-muted);text-align:left;border-bottom:1px solid var(--ai-border)}.ai2-trend-table td{padding:9px 14px;border-bottom:1px solid var(--ai-border)}.ai2-trend-table tr:last-child td{border-bottom:none}.ai2-trend-table tr:hover td{background:var(--ai-bg)}.ai2-skel-list{display:flex;flex-direction:column;gap:10px}.ai2-skel-card{display:flex;gap:12px;padding:14px;background:var(--ai-card);border:1px solid var(--ai-border);border-radius:10px;animation:ai-msg-in .2s ease both;min-height:64px}.ai2-skel{border-radius:6px;background:linear-gradient(90deg,var(--ai-border) 25%,var(--ai-bg) 50%,var(--ai-border) 75%);background-size:200% 100%;animation:ai-shimmer 1.4s infinite}.ai2-skel--icon{width:32px;height:32px;border-radius:8px;flex-shrink:0}.ai2-skel--title{height:14px;margin-bottom:8px;width:70%}.ai2-skel--body{height:12px;width:90%}@keyframes ai-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ai2-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;text-align:center;color:var(--ai-muted);gap:10px}.ai2-empty svg{opacity:.3}.ai2-empty p{font-size:15px;font-weight:600;color:var(--ai-text);margin:0}.ai2-empty span{font-size:13px;margin:0;max-width:280px}.ai2-spin{animation:ai2-spin .6s linear infinite}@keyframes ai2-spin{to{transform:rotate(360deg)}}.qra-spinner-xs{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:currentColor;border-radius:50%;animation:ai2-spin .55s linear infinite}.ai2-footer{display:flex;align-items:center;gap:6px;padding:10px 24px;font-size:11px;color:var(--ai-faint);border-top:1px solid var(--ai-border);margin-top:auto;flex-wrap:wrap}@media(max-width:768px){.ai2-page-hdr{padding:14px 16px 10px}.ai2-tabs{padding:0 16px}.ai2-chat-panel,.ai2-insights-panel{padding-left:16px;padding-right:16px}.ai2-quick-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.ai2-charts-grid{grid-template-columns:1fr}.ai2-bubble__body{max-width:92%}.ai-banner{padding:8px 14px;font-size:12px}}@media(max-width:480px){.ai2-input-row{flex-wrap:wrap}.ai2-mic-btn{width:42px;height:42px}.ai2-send-row{width:100%}.ai2-send-btn{width:100%;justify-content:center}}.ai2-bubble__content--rendered{padding:12px 14px;border-radius:var(--ai-radius, 12px);font-size:13.5px;line-height:1.65;background:var(--ai-card, #ffffff);border:1px solid var(--ai-border, #e2e8f0);color:var(--ai-text, #0f172a);max-width:100%}.ai2-bubble__content--rendered strong{font-weight:700;color:var(--ai-text)}.ai2-bubble__content--rendered .ai-section-hdr+.ai-table-wrap,.ai2-bubble__content--rendered .ai-section-hdr+.ai-recommended,.ai2-bubble__content--rendered .ai-section-hdr+.ai-ul,.ai2-bubble__content--rendered .ai-section-hdr+.ai-ol{margin-top:6px}.ai2-bubble__content--rendered>*:first-child{margin-top:0}.ai2-bubble__content--rendered>*:last-child{margin-bottom:0}@media(max-width:600px){.ai-table-wrap:after{content:"← scroll →";display:block;text-align:center;font-size:10px;color:var(--ai-muted, #64748b);padding:4px;background:var(--ai-bg, #f8fafc);border-top:1px solid var(--ai-border, #e2e8f0)}}.ai-rich-table tbody tr{animation:ai-row-in .18s ease both}.ai-rich-table tbody tr:nth-child(1){animation-delay:0s}.ai-rich-table tbody tr:nth-child(2){animation-delay:.03s}.ai-rich-table tbody tr:nth-child(3){animation-delay:.06s}.ai-rich-table tbody tr:nth-child(4){animation-delay:.09s}.ai-rich-table tbody tr:nth-child(5){animation-delay:.12s}.ai-rich-table tbody tr:nth-child(6){animation-delay:.15s}.ai-rich-table tbody tr:nth-child(7){animation-delay:.18s}.ai-rich-table tbody tr:nth-child(8){animation-delay:.21s}@keyframes ai-row-in{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:none}}@keyframes ai-bar-grow{0%{width:0!important}}.ai-cell-bar{animation:ai-bar-grow .5s cubic-bezier(.25,.46,.45,.94) both}.ai-chip:active{transform:scale(.96)}.ai-recommended.ai-recommended--critical{border-color:#dc262666;animation:ai-pulse-border 2s infinite}@media print{.ai-chip,.ai2-bubble__actions,.ai2-toolbar,.ai2-followups{display:none!important}.ai-rich-table{border:1px solid #ccc}.ai-status-line{border:2px solid currentColor}}.alm-root{font-family:Plus Jakarta Sans,system-ui,sans-serif;display:flex;flex-direction:column;gap:0}.alm-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.alm-page-hdr__left{flex:1}.alm-page-hdr__right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.alm-page-title{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:800;color:var(--tx1, #0f172a);letter-spacing:-.5px}.alm-title-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#dc2626,#b91c1c);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #dc26264d;flex-shrink:0;position:relative}.alm-title-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;border-radius:9px;background:#fff;color:#dc2626;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 4px;border:1.5px solid #dc2626}.alm-page-sub{font-size:13px;color:var(--tx3, #64748b);margin-top:4px;margin-left:48px}.alm-ring{position:relative;width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.alm-ring__num{position:absolute;font-size:9px;font-weight:700;color:var(--primary, #2563eb);font-family:DM Mono,monospace}.alm-kpi-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:22px}.alm-kpi{position:relative;background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:14px;padding:14px 14px 12px 16px;display:flex;align-items:center;gap:12px;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .15s;animation:alm-kpi-in .4s cubic-bezier(.4,0,.2,1) var(--delay, 0ms) both;text-align:left;cursor:default;font-family:inherit}.alm-kpi:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--kc, #2563eb);border-radius:14px 0 0 14px}.alm-kpi--click{cursor:pointer}.alm-kpi--click:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.alm-kpi--active{border-color:var(--kc, #2563eb);box-shadow:0 0 0 3px color-mix(in srgb,var(--kc) 15%,transparent)}.alm-kpi__icon{width:38px;height:38px;border-radius:10px;background:var(--kb, #eff6ff);color:var(--kc, #2563eb);display:flex;align-items:center;justify-content:center;flex-shrink:0}.alm-kpi__body{flex:1;min-width:0}.alm-kpi__val{font-size:26px;font-weight:800;letter-spacing:-1px;line-height:1;color:var(--kc, #2563eb);font-family:DM Mono,monospace}.alm-kpi__lbl{font-size:10px;font-weight:700;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}@keyframes alm-kpi-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.alm-fbar{display:flex;align-items:center;gap:10px;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:11px 14px;margin-bottom:16px;flex-wrap:wrap}.alm-search-box{position:relative;flex:1;min-width:200px;max-width:340px}.alm-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.alm-search-input{width:100%;padding:8px 34px 8px 36px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13px;outline:none;transition:all .2s;font-family:inherit}.alm-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px #2563eb1a;background:#fff}.alm-search-input::placeholder{color:var(--tx3, #94a3b8)}.alm-search-clear{position:absolute;right:9px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--tx3);cursor:pointer;display:flex;padding:2px;border-radius:4px;transition:all .15s}.alm-search-clear:hover{color:#dc2626;background:#fee2e2}.alm-filter-chips{display:flex;gap:5px;align-items:center;flex-wrap:wrap}.alm-chip-divider{width:1px;height:22px;background:var(--border, #e2e8f0);flex-shrink:0}.alm-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 11px;border-radius:20px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.alm-chip:hover{border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.alm-chip--active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb);box-shadow:0 2px 8px #2563eb40}.alm-chip--sev svg{width:12px;height:12px}.alm-count{font-size:12px;color:var(--tx3, #94a3b8);font-weight:500}.alm-count-sel{color:var(--primary, #2563eb);font-weight:700}.alm-table-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;overflow:hidden;box-shadow:0 2px 12px #0000000a}.alm-table-wrap{overflow-x:auto}.alm-table{width:100%;border-collapse:separate;border-spacing:0}.alm-table thead tr{background:linear-gradient(to bottom,#f8fafc,#f1f5f9)}.alm-table th{padding:12px 14px;font-size:11px;font-weight:700;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:2px solid var(--border, #e2e8f0);white-space:nowrap;-webkit-user-select:none;user-select:none}.alm-th--sort{cursor:pointer;transition:color .15s}.alm-th--sort:hover{color:var(--tx1, #0f172a)}.alm-th--check{width:40px}.alm-table td{padding:12px 14px;font-size:13px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;transition:background .12s}.alm-table tr:last-child td{border-bottom:none}.alm-tr{animation:alm-row-in .2s ease both}.alm-tr:hover td{background:#f8fafc}.alm-tr--resolved td{opacity:.65}.alm-tr--resolved:hover td{opacity:.85;background:#f8fafc}.alm-tr--selected td{background:#eff6ff!important}@keyframes alm-row-in{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}.alm-td--check{width:40px}.alm-sort-icon{margin-left:4px;opacity:.45;vertical-align:middle}.alm-sort-icon--active{opacity:1;color:var(--primary, #2563eb)}.alm-table-foot{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border, #e2e8f0);background:#fafbfc;flex-wrap:wrap;gap:8px}.alm-severity-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 9px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid transparent;white-space:nowrap}.alm-severity-badge svg{width:12px;height:12px}.alm-type-cell{display:flex;align-items:center;gap:6px}.alm-type-code{font-family:DM Mono,monospace;font-size:11px;font-weight:600;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 7px;border-radius:6px;color:var(--tx1, #0f172a);white-space:nowrap}.alm-session-ref{font-size:11px;color:var(--tx3, #94a3b8);font-family:DM Mono,monospace}.alm-type-desc{font-size:11px;color:var(--tx3, #64748b);margin-top:3px;line-height:1.4}.alm-person-cell{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--tx1, #0f172a)}.alm-person-type{font-size:10px;font-weight:600;color:#7c3aed;background:#ede9fe;padding:1px 6px;border-radius:10px}.alm-detail-preview{font-size:11px;color:var(--tx3, #64748b);margin-top:3px;line-height:1.45}.alm-staff-name{font-size:12px;font-weight:600;color:var(--tx1, #0f172a)}.alm-time-cell{display:flex;flex-direction:column;gap:2px}.alm-time-main{font-size:12px;font-family:DM Mono,monospace;color:var(--tx2, #475569);white-space:nowrap}.alm-time-rel{font-size:10px;color:var(--tx3, #94a3b8)}.alm-status{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap}.alm-status--open{background:#fee2e2;color:#dc2626}.alm-status--resolved{background:#dcfce7;color:#15803d}.alm-resolved-by{font-size:10px;color:var(--tx3, #94a3b8);margin-top:3px}.alm-pulse{display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor;animation:alm-pulse-anim 1.6s ease-in-out infinite}@keyframes alm-pulse-anim{0%,to{opacity:1}50%{opacity:.35}}.alm-row-acts{display:flex;align-items:center;gap:5px;justify-content:flex-end}.alm-act{width:30px;height:30px;border-radius:7px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.alm-act:hover{background:#eff6ff;color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-1px)}.alm-act--resolve:hover{background:#dcfce7;color:#16a34a;border-color:#bbf7d0}.alm-check-btn{background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:5px;transition:background .12s}.alm-check-btn:hover{background:#f1f5f9}.alm-check-empty{width:15px;height:15px;border-radius:3px;border:1.5px solid var(--border, #cbd5e1);transition:border-color .15s}.alm-check-btn:hover .alm-check-empty{border-color:var(--primary, #2563eb)}.alm-skel-wrap{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:16px 20px}.alm-skel-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border, #f1f5f9);animation:alm-row-in .25s ease both}.alm-skel-row:last-child{border-bottom:none}.alm-skel{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;border-radius:5px;animation:alm-shimmer 1.4s linear infinite}.alm-skel--xs{width:18px;height:18px;border-radius:4px;flex-shrink:0}.alm-skel--icon{width:60px;height:22px;border-radius:11px}.alm-skel--wide{flex:1;max-width:180px;height:12px}.alm-skel--mid{width:100px;height:12px}.alm-skel--short{width:70px;height:12px}@keyframes alm-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.alm-empty{text-align:center;padding:60px 24px;background:var(--bg-card, #fff);border:2px dashed var(--border, #e2e8f0);border-radius:14px}.alm-empty__ring{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);display:flex;align-items:center;justify-content:center;color:#94a3b8;margin:0 auto 18px}.alm-empty h3{font-size:16px;font-weight:700;color:#0f172a;margin-bottom:6px}.alm-empty p{font-size:13px;color:#64748b;margin-bottom:16px}.alm-overlay{position:fixed;inset:0;background:#00000085;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:alm-ovl-in .2s ease;font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes alm-ovl-in{0%{opacity:0}to{opacity:1}}.alm-modal{background:var(--bg-card, #fff);border-radius:18px;box-shadow:0 32px 64px -20px #00000059,0 0 0 1px #0000000a;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:alm-modal-in .22s cubic-bezier(.4,0,.2,1)}.alm-modal--sm{max-width:440px}@keyframes alm-modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}.alm-modal__hdr{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 14px;border-bottom:1px solid var(--border, #f1f5f9);gap:12px}.alm-modal__hdr-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.alm-modal__hdr-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.alm-modal__title{font-size:15px;font-weight:800;color:var(--tx1, #0f172a)}.alm-modal__sub{font-size:12px;color:var(--tx3, #64748b);margin-top:1px;font-family:DM Mono,monospace}.alm-modal__close{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-input, #f8fafc);color:var(--tx2, #475569);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.alm-modal__close:hover:not(:disabled){background:#fee2e2;color:#dc2626;border-color:#dc2626;transform:rotate(90deg)}.alm-modal__close:disabled{opacity:.5;cursor:not-allowed}.alm-modal__body{padding:18px 22px}.alm-modal__desc{font-size:13px;color:var(--tx2, #475569);margin-bottom:16px;line-height:1.6}.alm-modal__foot{padding:12px 22px;border-top:1px solid var(--border, #f1f5f9);display:flex;justify-content:flex-end;gap:10px}.alm-resolve-detail{background:var(--bg-input, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:10px;padding:14px;margin-bottom:16px;display:flex;flex-direction:column;gap:10px}.alm-resolve-detail__row{display:flex;align-items:flex-start;gap:12px;font-size:13px}.alm-resolve-detail__row>span:first-child{font-size:11px;font-weight:700;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.4px;min-width:80px;flex-shrink:0;padding-top:1px}.alm-resolve-detail__row>strong{font-weight:600;color:var(--tx1, #0f172a)}.alm-resolve-detail__row--full{flex-direction:column;gap:4px}.alm-resolve-detail__row--full>span:first-child{min-width:auto}.alm-resolve-detail__row p{margin:0;font-size:12px;color:var(--tx2, #475569);line-height:1.55;background:#fff;padding:8px 10px;border-radius:7px;border:1px solid var(--border, #e2e8f0)}.alm-fg{display:flex;flex-direction:column;gap:6px}.alm-fg>label{font-size:12px;font-weight:700;color:var(--tx2, #475569);display:flex;align-items:center;gap:6px}.alm-opt{font-size:10px;font-weight:500;color:var(--tx3, #94a3b8);background:var(--bg-input, #f1f5f9);padding:1px 6px;border-radius:6px;border:1px solid var(--border, #e2e8f0)}.alm-textarea{background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13px;padding:10px 12px;outline:none;width:100%;resize:vertical;transition:all .2s;font-family:inherit;line-height:1.55}.alm-textarea:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px #2563eb1a;background:#fff}.alm-textarea:disabled{opacity:.6;cursor:not-allowed}.alm-drawer-bg{position:fixed;inset:0;background:#0006;z-index:900;display:flex;justify-content:flex-end;animation:alm-ovl-in .2s ease;font-family:Plus Jakarta Sans,system-ui,sans-serif}.alm-drawer{width:420px;max-width:95vw;height:100%;background:var(--bg-card, #fff);display:flex;flex-direction:column;box-shadow:-8px 0 40px #00000024;animation:alm-drawer-in .25s cubic-bezier(.4,0,.2,1);overflow-y:auto}@keyframes alm-drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.alm-drawer__hdr{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 14px;border-bottom:1px solid var(--border, #e2e8f0);position:sticky;top:0;background:var(--bg-card, #fff);z-index:1}.alm-drawer__title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--tx1, #0f172a);font-family:DM Mono,monospace}.alm-drawer__body{flex:1;padding:18px 20px}.alm-drawer__foot{padding:14px 20px;border-top:1px solid var(--border, #e2e8f0);display:flex;gap:10px;justify-content:flex-end;background:var(--bg-card, #fff);position:sticky;bottom:0}.alm-detail-grid{display:flex;flex-direction:column;gap:0;border:1px solid var(--border, #e2e8f0);border-radius:10px;overflow:hidden;margin-bottom:14px}.alm-detail-row{display:flex;gap:12px;padding:9px 13px;border-bottom:1px solid var(--border, #f1f5f9);align-items:flex-start}.alm-detail-row:last-child{border-bottom:none}.alm-detail-row:nth-child(odd){background:var(--bg-input, #f8fafc)}.alm-detail-k{font-size:10px;font-weight:700;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.4px;min-width:90px;flex-shrink:0;padding-top:1px}.alm-detail-v{font-size:12px;font-weight:600;color:var(--tx1, #0f172a)}.alm-detail-note{background:#eff6ff;border:1px solid #bfdbfe;border-radius:9px;padding:12px 14px;margin-bottom:12px}.alm-detail-note--resolved{background:#f0fdf4;border-color:#bbf7d0}.alm-detail-note__lbl{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:#1d4ed8;text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}.alm-detail-note--resolved .alm-detail-note__lbl{color:#15803d}.alm-detail-note p{margin:0;font-size:12px;color:#1e40af;line-height:1.6}.alm-detail-note--resolved p{color:#166534}.alm-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:700;padding:8px 16px;border-radius:8px;border:1.5px solid transparent;cursor:pointer;transition:all .17s;font-family:inherit;white-space:nowrap}.alm-btn--sm{font-size:12px;padding:6px 12px}.alm-btn--primary{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.alm-btn--primary:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.alm-btn--success{background:#16a34a;color:#fff;border-color:#16a34a}.alm-btn--success:hover:not(:disabled){background:#15803d;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}.alm-btn--ghost{background:var(--bg-card, #fff);color:var(--tx2, #475569);border-color:var(--border, #e2e8f0)}.alm-btn--ghost:hover:not(:disabled){background:var(--bg-input, #f8fafc);color:var(--tx1, #0f172a);border-color:#cbd5e1}.alm-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.alm-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:alm-spin .55s linear infinite}@keyframes alm-spin{to{transform:rotate(360deg)}}.alm-spin{animation:alm-spin 1s linear infinite}.alm-muted{color:var(--tx3, #94a3b8)}.alm-table-foot__info{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.alm-pager{display:flex;gap:4px;align-items:center}.alm-pager__btn{width:32px;height:32px;border-radius:8px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit;flex-shrink:0}.alm-pager__btn:hover:not(:disabled){background:var(--bg-input, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.alm-pager__btn--active{background:var(--primary, #2563eb)!important;color:#fff!important;border-color:var(--primary, #2563eb)!important;box-shadow:0 2px 8px #2563eb40}.alm-pager__btn--dots{cursor:default;border-color:transparent;background:none;color:var(--tx3, #94a3b8)}.alm-pager__btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:1280px){.alm-kpi-strip{grid-template-columns:repeat(3,1fr)}}@media(max-width:1024px){.alm-kpi-strip{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.alm-kpi-strip{grid-template-columns:repeat(2,1fr)}.alm-page-hdr{flex-direction:column}.alm-fbar{flex-direction:column;align-items:stretch}.alm-search-box{max-width:none}.alm-drawer{width:100vw}.alm-modal{max-width:98%}.alm-modal__hdr,.alm-modal__body,.alm-modal__foot{padding:14px 16px}}@media(max-width:480px){.alm-kpi-strip{grid-template-columns:1fr 1fr}}@media print{.alm-page-hdr__right,.alm-fbar,.alm-row-acts,.alm-overlay,.alm-drawer-bg{display:none!important}.alm-table-card{box-shadow:none;border-color:#e2e8f0}.alm-tr--resolved{opacity:.6}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.rp-root{--rp-font: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--rp-font-mono: "DM Mono", "Fira Mono", monospace;--rp-bg: #f1f5f9;--rp-bg-card: #ffffff;--rp-bg-input: #f8fafc;--rp-bg-hover: #f1f5f9;--rp-border: #e2e8f0;--rp-border-focus: #2563eb;--rp-tx1: #0f172a;--rp-tx2: #475569;--rp-tx3: #94a3b8;--rp-primary: #2563eb;--rp-primary-hover: #1d4ed8;--rp-primary-light: #dbeafe;--rp-success: #16a34a;--rp-success-light: #dcfce7;--rp-success-border: #bbf7d0;--rp-danger: #dc2626;--rp-danger-light: #fee2e2;--rp-danger-border: #fecaca;--rp-warning: #d97706;--rp-warning-light: #fef3c7;--rp-warning-border: #fde68a;--rp-radius-sm: 6px;--rp-radius: 10px;--rp-radius-lg: 8px;--rp-shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--rp-shadow: 0 2px 10px rgba(0, 0, 0, .1);--rp-shadow-lg: 0 8px 30px rgba(0, 0, 0, .14);--rp-bg-image: url(/images/smart-bg.png)}.rp-root[data-theme=dark]{--rp-bg: #0f172a;--rp-bg-card: #1e293b;--rp-bg-input: #0f172a;--rp-bg-hover: #334155;--rp-border: #334155;--rp-border-focus: #3b82f6;--rp-tx1: #f1f5f9;--rp-tx2: #cbd5e1;--rp-tx3: #64748b;--rp-primary: #3b82f6;--rp-primary-hover: #2563eb;--rp-primary-light: #1e3a8a;--rp-danger-light: #7f1d1d;--rp-danger-border: #991b1b;--rp-success-light: #14532d;--rp-success-border: #166534;--rp-warning-light: #78350f;--rp-warning-border: #92400e}.rp-root{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;font-family:var(--rp-font);color:var(--rp-tx1);padding:16px}.rp-backdrop{position:fixed;inset:0;background-image:var(--rp-bg-image);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}.rp-backdrop:after{content:"";position:absolute;inset:0;background:#000000a6;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:background .3s}.rp-root[data-theme=dark] .rp-backdrop:after{background:#000000bf}.rp-main{position:relative;z-index:2;width:100%;max-width:440px;display:flex;flex-direction:column;align-items:center;justify-content:center}.rp-main__controls{position:absolute;top:20px;right:20px;display:flex;align-items:center;gap:8px;z-index:10}.rp-icon-btn{width:34px;height:34px;border-radius:var(--rp-radius-sm);border:1.5px solid rgba(255,255,255,.3);background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;display:flex;align-items:center;justify-content:center;transition:all .15s;cursor:pointer}.rp-icon-btn:hover{border-color:var(--rp-primary);background:#2563eb99;color:#fff}.rp-main__controls .language-switcher{background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-color:#ffffff4d}.rp-main__controls .language-switcher button{color:#fff}.rp-main__controls .language-switcher button:hover{background:#ffffff26}.rp-card{width:100%;background:var(--rp-bg-card);border-radius:var(--rp-radius-lg);box-shadow:var(--rp-shadow-lg);border:1px solid var(--rp-border);overflow:hidden;position:relative;animation:rp-fade-up .4s ease both}.rp-bar{height:3px;background:var(--rp-border);width:100%;overflow:hidden}.rp-bar__fill{height:100%;background:linear-gradient(90deg,var(--rp-primary),#60a5fa);border-radius:0 2px 2px 0;transition:width .25s ease}.rp-bar--done .rp-bar__fill{background:linear-gradient(90deg,var(--rp-success),#34d399)}.rp-header{display:flex;align-items:center;justify-content:center;gap:10px;padding:28px 28px 0}.rp-header__logo{width:36px;height:36px;border-radius:10px;background:var(--rp-primary);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #2563eb4d}.rp-header__wordmark{font-size:20px;font-weight:700;color:var(--rp-tx1);letter-spacing:-.3px}.rp-panel{padding:28px 28px 24px;animation:rp-fade-in .25s ease both}.rp-panel--center{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:40px 28px}.rp-shake{animation:rp-shake .55s ease}.rp-card__hdr{margin-bottom:22px}.rp-card__title{font-size:20px;font-weight:700;color:var(--rp-tx1);letter-spacing:-.3px;margin-bottom:4px}.rp-card__sub{font-size:13px;color:var(--rp-tx2);line-height:1.5}.rp-card__foot{display:flex;align-items:center;justify-content:center;gap:5px;font-size:11px;color:var(--rp-tx3);padding:12px 28px;border-top:1px solid var(--rp-border);background:var(--rp-bg-input);margin-top:8px}.rp-panel-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.rp-panel-icon--primary{background:var(--rp-primary-light);color:var(--rp-primary)}.rp-alert{display:flex;align-items:flex-start;gap:7px;font-size:13px;border-radius:var(--rp-radius-sm);padding:9px 12px;margin-bottom:16px;line-height:1.45}.rp-alert--error{color:var(--rp-danger);background:var(--rp-danger-light);border:1px solid var(--rp-danger-border)}.rp-alert--success{color:var(--rp-success);background:var(--rp-success-light);border:1px solid var(--rp-success-border)}.rp-alert--warning{color:var(--rp-warning);background:var(--rp-warning-light);border:1px solid var(--rp-warning-border)}.rp-alert svg{flex-shrink:0;margin-top:2px}.rp-form{display:flex;flex-direction:column;gap:16px}.rp-field{display:flex;flex-direction:column;gap:5px}.rp-field__lbl{font-size:12px;font-weight:600;color:var(--rp-tx2);letter-spacing:.1px}.rp-field__msg{display:flex;align-items:center;gap:4px;font-size:11px;margin-top:2px}.rp-field__msg--err{color:var(--rp-danger)}.rp-field__msg--hint{color:var(--rp-tx3)}.rp-field--err .rp-inp{border-color:var(--rp-danger);background:var(--rp-danger-light)}.rp-field--err .rp-inp:focus{border-color:var(--rp-danger);box-shadow:0 0 0 3px var(--rp-danger-light)}.rp-inp-wrap{position:relative;display:flex;align-items:center}.rp-inp-icon{position:absolute;left:11px;color:var(--rp-tx3);pointer-events:none;flex-shrink:0}.rp-inp{width:100%;height:40px;padding:0 12px 0 36px;background:var(--rp-bg-input);border:1.5px solid var(--rp-border);border-radius:var(--rp-radius-sm);color:var(--rp-tx1);font-size:14px;font-family:var(--rp-font);outline:none;transition:border-color .15s,box-shadow .15s,background .15s}.rp-inp:focus{border-color:var(--rp-border-focus);box-shadow:0 0 0 3px var(--rp-primary-light);background:var(--rp-bg-card)}.rp-inp::placeholder{color:var(--rp-tx3)}.rp-inp:disabled{opacity:.6;cursor:not-allowed}.rp-inp--pwd{padding-right:40px}.rp-inp--err{border-color:var(--rp-danger);background:var(--rp-danger-light)}.rp-inp--err:focus{border-color:var(--rp-danger);box-shadow:0 0 0 3px var(--rp-danger-light)}.rp-eye{position:absolute;right:10px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:4px;border:none;background:transparent;color:var(--rp-tx3);transition:color .15s,background .15s;cursor:pointer}.rp-eye:hover{color:var(--rp-tx2);background:var(--rp-bg-hover)}.rp-strength{margin-top:6px}.rp-strength__bars{display:flex;gap:4px;margin-bottom:4px}.rp-strength__bar{flex:1;height:3px;border-radius:2px;transition:background .2s}.rp-strength__label{font-size:11px;font-weight:600}.rp-match-ok{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--rp-success);margin-top:3px}.rp-caps{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--rp-warning);margin-top:3px}.rp-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;height:42px;padding:0 18px;background:var(--rp-primary);color:#fff;border:1.5px solid transparent;border-radius:var(--rp-radius-sm);font-size:14px;font-weight:600;font-family:var(--rp-font);cursor:pointer;transition:background .15s,box-shadow .15s,opacity .15s;white-space:nowrap;margin-top:4px}.rp-btn:hover:not(:disabled){background:var(--rp-primary-hover);box-shadow:0 4px 14px #2563eb59}.rp-btn:active:not(:disabled){transform:translateY(1px)}.rp-btn:disabled{opacity:.55;cursor:not-allowed}.rp-btn--ghost{background:transparent;color:var(--rp-tx2);border-color:var(--rp-border)}.rp-btn--ghost:hover:not(:disabled){background:var(--rp-bg-hover);border-color:var(--rp-border-focus);color:var(--rp-primary);box-shadow:none}.rp-spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:rp-spin .65s linear infinite;flex-shrink:0}.rp-btn--ghost .rp-spin{border-color:#00000026;border-top-color:var(--rp-tx2)}.rp-success-ring{width:68px;height:68px;border-radius:50%;background:var(--rp-success-light);border:2px solid var(--rp-success-border);display:flex;align-items:center;justify-content:center;margin-bottom:4px;animation:rp-success-pop .45s cubic-bezier(.34,1.56,.64,1) both}@keyframes rp-spin{to{transform:rotate(360deg)}}@keyframes rp-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes rp-fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes rp-fade-in{0%{opacity:0}to{opacity:1}}@keyframes rp-success-pop{0%{transform:scale(.7);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@media(max-width:768px){.rp-main{max-width:100%;padding:0}.rp-main__controls{top:16px;right:16px}.rp-card{border-radius:var(--rp-radius);margin:0 8px}.rp-panel{padding:20px 20px 18px}.rp-header{padding:20px 20px 0}}@media(max-width:480px){.rp-panel{padding:18px 16px}.rp-card__title{font-size:18px}.rp-main__controls{gap:6px}.rp-icon-btn{width:30px;height:30px}}:root{--ab-red: #dc2626;--ab-red-light: #fef2f2;--ab-red-border: #fecaca;--ab-amber: #d97706;--ab-amber-light: #fffbeb;--ab-amber-border: #fde68a;--ab-green: #16a34a;--ab-green-light: #f0fdf4;--ab-green-border: #bbf7d0;--ab-blue: #2563eb;--ab-blue-light: #eff6ff;--ab-blue-border: #bfdbfe;--ab-slate: #64748b;--ab-slate-light: #f8fafc;--ab-border: #e2e8f0;--ab-text: #0f172a;--ab-text-muted: #64748b;--ab-radius: 12px;--ab-shadow: 0 1px 3px rgba(0, 0, 0, .05);--ab-shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--ab-shadow-lg: 0 8px 24px rgba(0, 0, 0, .12)}.ab-page{padding:28px 32px;max-width:1400px;margin:0 auto;font-family:Plus Jakarta Sans,system-ui,sans-serif;color:var(--ab-text);background:#fafbff;min-height:100vh}.ab-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}.ab-header__left{flex:1;min-width:0}.ab-header__title{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:800;color:var(--ab-text);letter-spacing:-.5px;margin-bottom:8px}.ab-header__title-icon{width:40px;height:40px;background:var(--ab-red-light);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--ab-red);flex-shrink:0}.ab-header__subtitle{font-size:13px;color:var(--ab-text-muted);line-height:1.5;margin-left:52px}.ab-header__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ab-kpi-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:28px}.ab-kpi{background:#fff;border:1px solid var(--ab-border);border-radius:var(--ab-radius);padding:18px 20px;display:flex;align-items:center;gap:14px;transition:all .2s;animation:abKpiIn .4s ease var(--kd, 0ms) both}.ab-kpi:hover{transform:translateY(-2px);box-shadow:var(--ab-shadow-md);border-color:#cbd5e1}@keyframes abKpiIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.ab-kpi__icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ab-kpi__body{flex:1;min-width:0}.ab-kpi__value{font-size:28px;font-weight:800;line-height:1.2;color:var(--ab-text);font-family:DM Mono,monospace;letter-spacing:-1px}.ab-kpi__label{font-size:11px;font-weight:600;color:var(--ab-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.ab-kpi__sub{font-size:11px;color:var(--ab-text-muted);margin-top:4px}.ab-toolbar{display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}.ab-toolbar__search{position:relative;flex:1;min-width:240px;max-width:400px}.ab-toolbar__search input{width:100%;padding:10px 14px 10px 40px;border:1.5px solid var(--ab-border);border-radius:10px;font-size:13px;font-family:inherit;outline:none;background:#fff;transition:all .15s}.ab-toolbar__search input:focus{border-color:var(--ab-blue);box-shadow:0 0 0 3px #2563eb1a}.ab-toolbar__search-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--ab-text-muted);pointer-events:none}.ab-toolbar__filters{display:flex;gap:8px;flex-wrap:wrap}.ab-filter-btn{padding:7px 16px;border-radius:20px;border:1.5px solid var(--ab-border);background:#fff;font-size:12px;font-weight:600;color:var(--ab-text-muted);cursor:pointer;transition:all .15s;font-family:inherit}.ab-filter-btn:hover{background:var(--ab-slate-light);border-color:#cbd5e1}.ab-filter-btn.active{background:var(--ab-blue);border-color:var(--ab-blue);color:#fff}.ab-list{display:flex;flex-direction:column;gap:16px}.ab-card{background:#fff;border:1px solid var(--ab-border);border-radius:var(--ab-radius);overflow:hidden;transition:all .2s}.ab-card:hover{box-shadow:var(--ab-shadow-md);border-color:#cbd5e1}.ab-card--resolved{opacity:.75}.ab-card__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,#fef2f2,#fff);border-bottom:1px solid var(--ab-red-border);gap:16px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.ab-card__header:hover{background:linear-gradient(135deg,#fee2e2,#fff)}.ab-card--resolved .ab-card__header{background:linear-gradient(135deg,#f8fafc,#fff);border-bottom-color:var(--ab-border)}.ab-card__header-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.ab-card__header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.ab-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0;font-family:Plus Jakarta Sans,system-ui,sans-serif}.ab-card__info{flex:1;min-width:0}.ab-person-name{font-size:15px;font-weight:700;color:var(--ab-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ab-person-meta{font-size:12px;color:var(--ab-text-muted);display:flex;align-items:center;gap:4px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ab-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.ab-badge--red{background:var(--ab-red-light);color:var(--ab-red);border:1px solid var(--ab-red-border)}.ab-badge--amber{background:var(--ab-amber-light);color:var(--ab-amber);border:1px solid var(--ab-amber-border)}.ab-badge--green{background:var(--ab-green-light);color:var(--ab-green);border:1px solid var(--ab-green-border)}.ab-badge--blue{background:var(--ab-blue-light);color:var(--ab-blue);border:1px solid var(--ab-blue-border)}.ab-badge--slate{background:#f1f5f9;color:var(--ab-slate);border:1px solid #e2e8f0}.ab-card__expand-icon{color:var(--ab-text-muted);transition:transform .2s}.ab-card__expand-icon.open{transform:rotate(180deg)}.ab-card__body{padding:20px}.ab-detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px 24px;margin-bottom:20px}.ab-detail-item{min-width:0}.ab-detail-item__label{font-size:10px;font-weight:600;color:var(--ab-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}.ab-detail-item__value{font-size:13px;font-weight:500;color:var(--ab-text);word-break:break-word}.ab-detail-item__value--red{color:var(--ab-red);font-weight:600}.ab-note-preview{font-size:12px;color:var(--ab-text-muted);background:var(--ab-slate-light);padding:12px;border-radius:8px;white-space:pre-wrap;font-family:inherit;margin:8px 0 0;border:1px solid var(--ab-border)}.ab-sticker-table-wrap{border:1px solid var(--ab-border);border-radius:10px;overflow-x:auto;overflow-y:hidden}.ab-sticker-table{width:100%;border-collapse:collapse;font-size:13px;min-width:600px}.ab-sticker-table th{background:var(--ab-slate-light);padding:12px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--ab-text-muted);text-align:left;border-bottom:1px solid var(--ab-border)}.ab-sticker-table td{padding:12px 16px;border-bottom:1px solid var(--ab-border);vertical-align:middle}.ab-sticker-table tr:last-child td{border-bottom:none}.ab-sticker-table tr:hover td{background:#fafbff}.ab-qr-code{font-family:DM Mono,monospace;font-size:12px;color:var(--ab-text);background:#f1f5f9;padding:3px 8px;border-radius:6px;display:inline-block}.ab-timeline{display:flex;flex-direction:column;gap:0}.ab-timeline__item{display:flex;gap:14px;padding:10px 0;position:relative}.ab-timeline__item:not(:last-child):before{content:"";position:absolute;left:11px;top:32px;bottom:-8px;width:2px;background:var(--ab-border)}.ab-timeline__dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;position:relative;z-index:1}.ab-timeline__dot--active{background:var(--ab-green-light);color:var(--ab-green);border:2px solid var(--ab-green-border)}.ab-timeline__dot--checkout{background:var(--ab-blue-light);color:var(--ab-blue);border:2px solid var(--ab-blue-border)}.ab-timeline__dot--abandoned{background:var(--ab-red-light);color:var(--ab-red);border:2px solid var(--ab-red-border)}.ab-timeline__dot--resolved{background:var(--ab-green-light);color:var(--ab-green);border:2px solid var(--ab-green-border)}.ab-timeline__dot--default{background:#f1f5f9;color:var(--ab-slate);border:2px solid var(--ab-border)}.ab-timeline__content{flex:1}.ab-timeline__event{font-size:13px;font-weight:600;color:var(--ab-text)}.ab-timeline__time{font-size:11px;color:var(--ab-text-muted);margin-top:2px;font-family:DM Mono,monospace}.ab-actions-bar{display:flex;align-items:center;gap:10px;padding-top:16px;margin-top:8px;border-top:1px solid var(--ab-border);flex-wrap:wrap}.ab-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:all .15s;font-family:inherit;white-space:nowrap}.ab-btn:disabled{opacity:.5;cursor:not-allowed}.ab-btn--primary{background:var(--ab-blue);color:#fff;border-color:var(--ab-blue)}.ab-btn--primary:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.ab-btn--danger{background:var(--ab-red);color:#fff;border-color:var(--ab-red)}.ab-btn--danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.ab-btn--success{background:var(--ab-green);color:#fff;border-color:var(--ab-green)}.ab-btn--success:hover:not(:disabled){background:#15803d;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}.ab-btn--amber{background:var(--ab-amber);color:#fff;border-color:var(--ab-amber)}.ab-btn--amber:hover:not(:disabled){background:#b45309;transform:translateY(-1px);box-shadow:0 4px 12px #d977064d}.ab-btn--ghost{background:transparent;color:var(--ab-text-muted);border-color:var(--ab-border)}.ab-btn--ghost:hover:not(:disabled){background:var(--ab-slate-light);border-color:#cbd5e1;color:var(--ab-text)}.ab-btn--sm{padding:5px 12px;font-size:12px}.ab-notes-section{margin-top:8px}.ab-notes-section__label{font-size:12px;font-weight:600;color:var(--ab-text-muted);margin-bottom:8px}.ab-notes-section textarea{width:100%;padding:10px 12px;border:1.5px solid var(--ab-border);border-radius:8px;font-size:13px;font-family:inherit;resize:vertical;outline:none;transition:all .15s}.ab-notes-section textarea:focus{border-color:var(--ab-blue);box-shadow:0 0 0 3px #2563eb1a}.ab-warning-box,.ab-info-box{border-radius:10px;padding:14px 16px;margin-bottom:20px;display:flex;gap:12px;align-items:flex-start;font-size:13px;line-height:1.5}.ab-warning-box{background:var(--ab-amber-light);border:1px solid var(--ab-amber-border);color:#92400e}.ab-info-box{background:var(--ab-blue-light);border:1px solid var(--ab-blue-border);color:#1e40af}.ab-modal-overlay{position:fixed;inset:0;z-index:1000;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;animation:abFadeIn .2s ease}@keyframes abFadeIn{0%{opacity:0}to{opacity:1}}.ab-modal{background:#fff;border-radius:16px;width:100%;max-width:540px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--ab-shadow-lg);animation:abSlideUp .25s cubic-bezier(.4,0,.2,1)}@keyframes abSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ab-modal--wide{max-width:720px}.ab-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--ab-border)}.ab-modal__title{font-size:16px;font-weight:700;color:var(--ab-text);display:flex;align-items:center;gap:10px}.ab-modal__title-icon{color:var(--ab-red)}.ab-modal__close{width:32px;height:32px;border-radius:8px;border:1px solid var(--ab-border);background:#fff;color:var(--ab-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.ab-modal__close:hover{background:var(--ab-red-light);color:var(--ab-red);border-color:var(--ab-red-border);transform:rotate(90deg)}.ab-modal__body{padding:20px 24px;overflow-y:auto;flex:1}.ab-modal__footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--ab-border)}.ab-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:64px 24px;background:#fff;border-radius:var(--ab-radius);border:1px solid var(--ab-border)}.ab-empty__icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);display:flex;align-items:center;justify-content:center;color:var(--ab-text-muted);margin-bottom:20px}.ab-empty__title{font-size:16px;font-weight:700;color:var(--ab-text);margin-bottom:8px}.ab-empty__sub{font-size:13px;color:var(--ab-text-muted);max-width:360px;line-height:1.6}.ab-empty--inline{display:flex;align-items:center;gap:8px;padding:12px;font-size:13px;color:var(--ab-text-muted);background:var(--ab-slate-light);border-radius:8px}.ab-skeleton-list{display:flex;flex-direction:column;gap:12px}.ab-skeleton-card{display:flex;align-items:center;gap:14px;padding:16px 20px;background:#fff;border:1px solid var(--ab-border);border-radius:var(--ab-radius);animation:abRowIn .25s ease both}@keyframes abRowIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.ab-skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;border-radius:6px;animation:abShimmer 1.4s linear infinite}@keyframes abShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ab-skeleton--circle{width:44px;height:44px;border-radius:50%;flex-shrink:0}.ab-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:24px 0}.ab-pagination__btn{padding:7px 16px;border-radius:8px;border:1.5px solid var(--ab-border);background:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.ab-pagination__btn:hover:not(:disabled){background:var(--ab-slate-light);border-color:#cbd5e1}.ab-pagination__btn:disabled{opacity:.4;cursor:not-allowed}.ab-pagination__info{font-size:13px;color:var(--ab-text-muted)}.ab-toast-portal{position:fixed;bottom:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:10px}.ab-toast{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-radius:10px;box-shadow:var(--ab-shadow-lg);min-width:280px;max-width:380px;animation:abSlideUp .2s ease;font-size:13px;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.ab-toast--success{background:var(--ab-green-light);border:1px solid var(--ab-green-border);color:#166534}.ab-toast--error{background:var(--ab-red-light);border:1px solid var(--ab-red-border);color:#991b1b}.ab-toast--info{background:var(--ab-blue-light);border:1px solid var(--ab-blue-border);color:#1e40af}.ab-toast__msg{flex:1}.ab-toast__close{background:none;border:none;cursor:pointer;opacity:.6;padding:2px;border-radius:4px;transition:opacity .15s;color:currentColor}.ab-toast__close:hover{opacity:1}.spin{animation:abSpin .8s linear infinite}@keyframes abSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1024px){.ab-page{padding:20px}.ab-kpi-strip{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.ab-page{padding:16px}.ab-kpi-strip{grid-template-columns:repeat(2,1fr)}.ab-header{flex-direction:column}.ab-header__subtitle{margin-left:0}.ab-detail-grid{grid-template-columns:1fr}.ab-modal{max-width:calc(100vw - 32px);margin:16px}.ab-modal-overlay{align-items:flex-end}}@media(max-width:480px){.ab-kpi-strip{grid-template-columns:1fr}.ab-card__header{flex-direction:column;align-items:flex-start}.ab-card__header-right{width:100%;justify-content:flex-start;flex-wrap:wrap}.ab-toolbar{flex-direction:column;align-items:stretch}.ab-toolbar__search{max-width:none}}@media print{.ab-header__actions,.ab-toolbar,.ab-actions-bar,.ab-modal-overlay,.ab-toast-portal{display:none!important}.ab-card{break-inside:avoid;page-break-inside:avoid}}.lm-toasts{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.lm-toast{display:flex;align-items:center;gap:11px;padding:13px 16px;background:#fff;border-radius:12px;box-shadow:0 8px 30px #0f172a24,0 1px 4px #0f172a0f;min-width:300px;max-width:400px;border-left:3.5px solid #0f766e;animation:lm-toast-in .28s cubic-bezier(.4,0,.2,1);font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-toast--success{border-left-color:#16a34a}.lm-toast--error{border-left-color:#dc2626}.lm-toast--warning{border-left-color:#d97706}.lm-toast--info{border-left-color:#2563eb}.lm-toast__icon{flex-shrink:0;display:flex}.lm-toast--success .lm-toast__icon{color:#16a34a}.lm-toast--error .lm-toast__icon{color:#dc2626}.lm-toast--warning .lm-toast__icon{color:#d97706}.lm-toast--info .lm-toast__icon{color:#2563eb}.lm-toast__msg{flex:1;font-size:13px;font-weight:500;color:#0f172a;line-height:1.45}.lm-toast__x{background:none;border:none;color:#94a3b8;cursor:pointer;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s}.lm-toast__x:hover{background:#f1f5f9;color:#0f172a}@keyframes lm-toast-in{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.lm-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-page-hdr__left{flex:1}.lm-page-title{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:800;color:#0f172a;letter-spacing:-.5px}.lm-title-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#0f766e,#0d6460);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #0f766e4d;flex-shrink:0}.lm-page-sub{font-size:13px;color:#64748b;margin-top:4px;margin-left:48px}.lm-kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.lm-kpi{position:relative;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:16px 16px 14px 18px;display:flex;align-items:center;gap:12px;overflow:hidden;transition:transform .2s,box-shadow .2s;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-kpi:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000012}.lm-kpi__bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--kc, #0f766e);border-radius:14px 0 0 14px}.lm-kpi__icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lm-kpi__val{font-size:26px;font-weight:800;letter-spacing:-1px;line-height:1;font-family:DM Mono,monospace}.lm-kpi__lbl{font-size:10px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-top:3px}.lm-tab-bar{display:flex;gap:2px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:4px;margin-bottom:20px;overflow-x:auto;scrollbar-width:none;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-tab-bar::-webkit-scrollbar{display:none}.lm-tab{position:relative;display:flex;align-items:center;gap:7px;padding:10px 18px;border-radius:10px;border:none;background:transparent;color:#64748b;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;font-family:Plus Jakarta Sans,system-ui,sans-serif;flex-shrink:0}.lm-tab:hover:not(.lm-tab--active){background:#fff;color:#0f172a;box-shadow:0 1px 4px #0000000d}.lm-tab--active{background:#fff;color:var(--tc, #0f766e);box-shadow:0 2px 8px #00000014,0 0 0 1px #0000000a}.lm-tab__ind{position:absolute;bottom:0;left:12px;right:12px;height:2px;border-radius:2px;animation:lm-ind-in .2s ease}@keyframes lm-ind-in{0%{transform:scaleX(0);opacity:0}to{transform:scaleX(1);opacity:1}}.lm-tab-body{animation:lm-fade-in .18s ease both;font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes lm-fade-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.lm-fbar{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:11px 14px;margin-bottom:16px;flex-wrap:wrap}.lm-search-wrap{position:relative;flex:1;min-width:200px;max-width:340px}.lm-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.lm-search{width:100%;padding:8px 32px 8px 34px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;color:#0f172a;font-size:13px;outline:none;transition:all .2s;font-family:inherit}.lm-search:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1a;background:#fff}.lm-search-x{position:absolute;right:9px;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:2px;transition:color .15s}.lm-search-x:hover{color:#dc2626}.lm-sel{padding:7px 10px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;color:#0f172a;font-size:12px;outline:none;cursor:pointer;font-family:inherit;transition:all .2s}.lm-sel:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1a}.lm-table-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden;box-shadow:0 2px 12px #0000000a}.lm-table{width:100%;border-collapse:separate;border-spacing:0}.lm-table thead tr{background:linear-gradient(to bottom,#f8fafc,#f1f5f9)}.lm-table th{padding:12px 14px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:2px solid #e2e8f0;white-space:nowrap;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-table td{padding:12px 14px;font-size:13px;color:#475569;border-bottom:1px solid #f1f5f9;vertical-align:middle;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-table tr:last-child td{border-bottom:none}.lm-tr{transition:background .12s;animation:lm-row-in .22s ease both}.lm-tr:hover td{background:#f8fafc}@keyframes lm-row-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.lm-cell-primary{display:flex;align-items:center;gap:10px}.lm-cell-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lm-cell-name{font-size:13px;font-weight:600;color:#0f172a;display:block}.lm-cell-text{font-size:13px;color:#0f172a;display:block}.lm-cell-muted{font-size:11.5px;color:#94a3b8;display:block}.lm-cell-num{font-size:14px;font-weight:700;color:#0f172a;font-family:DM Mono,monospace}.lm-room-cell{display:flex;align-items:center;gap:8px}.lm-room-cell__icon{color:#64748b;flex-shrink:0;margin-top:1px}.lm-desk-cell{display:flex;flex-direction:column;gap:2px}.lm-desk-cell__num{font-family:DM Mono,monospace;font-size:12px;font-weight:600;color:#0f172a;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 7px;border-radius:5px;display:inline-block;width:fit-content}.lm-desk-cell__label{font-size:11px;color:#64748b}.lm-desk-cell__phone{display:flex;align-items:center;gap:3px;font-size:10.5px;color:#94a3b8}.lm-staff-cell{display:flex;align-items:center;gap:9px}.lm-avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0;position:relative}.lm-avatar--xs{width:24px;height:24px;font-size:9px}.lm-avatar--sm{width:30px;height:30px;font-size:10px}.lm-avatar__dot{position:absolute;bottom:1px;right:1px;width:7px;height:7px;border-radius:50%;background:#16a34a;border:2px solid #fff}.lm-vacant-tag{display:inline-flex;align-items:center;padding:3px 9px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.3px}.lm-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.lm-badge--sm{font-size:10px;padding:2px 6px}.lm-badge--green{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.lm-badge--gray{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}.lm-badge--blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.lm-badge--teal{background:#ccfbf1;color:#0f766e;border-color:#99f6e4}.lm-acts{display:flex;align-items:center;gap:5px}.lm-act{width:32px;height:32px;border-radius:8px;border:1.5px solid #e2e8f0;background:#fff;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .16s;flex-shrink:0}.lm-act:hover{background:#f0fdf9;color:#0f766e;border-color:#0f766e;transform:translateY(-1px);box-shadow:0 3px 8px #0f766e2e}.lm-act--red:hover{background:#fee2e2;color:#dc2626;border-color:#dc2626;box-shadow:0 3px 8px #dc26262e}.lm-act:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.lm-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:700;padding:9px 16px;border-radius:9px;border:1.5px solid transparent;cursor:pointer;transition:all .17s;font-family:Plus Jakarta Sans,system-ui,sans-serif;white-space:nowrap}.lm-btn--sm{font-size:12px;padding:7px 13px}.lm-btn--xs{font-size:11px;padding:5px 10px;border-radius:7px}.lm-btn--teal{background:#0f766e;color:#fff;border-color:#0f766e}.lm-btn--teal:hover:not(:disabled){background:#0d6460;transform:translateY(-1px);box-shadow:0 4px 12px #0f766e4d}.lm-btn--ghost{background:#fff;color:#475569;border-color:#e2e8f0}.lm-btn--ghost:hover:not(:disabled){background:#f8fafc;color:#0f172a;border-color:#cbd5e1}.lm-btn--danger{background:#dc2626;color:#fff;border-color:#dc2626}.lm-btn--danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.lm-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.lm-spin-sm{display:inline-block;width:11px;height:11px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:lm-spin .5s linear infinite}.lm-spin{animation:lm-spin 1s linear infinite}@keyframes lm-spin{to{transform:rotate(360deg)}}.lm-code{font-family:DM Mono,monospace;font-size:11px;font-weight:500;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 7px;border-radius:5px;color:#475569}.lm-empty{text-align:center;padding:56px 24px;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-empty__ring{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);display:flex;align-items:center;justify-content:center;color:#94a3b8;margin:0 auto 16px}.lm-empty__title{font-size:15px;font-weight:700;color:#0f172a;margin-bottom:5px}.lm-empty__body{font-size:13px;color:#64748b;line-height:1.6}.lm-empty-sm{padding:20px 14px;font-size:12px;color:#cbd5e1;text-align:center;font-style:italic}.lm-overlay{position:fixed;inset:0;background:#00000085;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:lm-ovl-in .2s ease;font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes lm-ovl-in{0%{opacity:0}to{opacity:1}}.lm-modal{background:#fff;border-radius:20px;box-shadow:0 32px 64px -20px #00000061,0 0 0 1px #0000000a;width:100%;max-height:92vh;overflow-y:auto;animation:lm-modal-in .22s cubic-bezier(.4,0,.2,1)}.lm-modal--sm{max-width:440px}.lm-modal--center{max-width:400px;padding:32px;display:flex;flex-direction:column;align-items:center;text-align:center}@keyframes lm-modal-in{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:none}}.lm-modal__hdr{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #f1f5f9;gap:12px}.lm-modal__hdr-left{display:flex;align-items:center;gap:12px}.lm-modal__hdr-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#0f766e,#0d6460);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 3px 10px #0f766e40;flex-shrink:0}.lm-modal__title{font-size:16px;font-weight:800;color:#0f172a;letter-spacing:-.2px}.lm-modal__sub{font-size:12px;color:#64748b;margin-top:1px}.lm-modal__close{width:32px;height:32px;border-radius:50%;border:1.5px solid #e2e8f0;background:#f8fafc;color:#475569;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.lm-modal__close:hover{background:#fee2e2;color:#dc2626;border-color:#dc2626;transform:rotate(90deg)}.lm-modal__body{padding:20px 24px}.lm-modal__foot{padding:14px 24px;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.lm-modal__foot--center{justify-content:center}.lm-confirm-orb{width:72px;height:72px;border-radius:50%;background:#fee2e2;color:#dc2626;box-shadow:0 0 0 12px #fff5f5;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}.lm-confirm-title{font-size:17px;font-weight:800;color:#0f172a;margin-bottom:8px}.lm-confirm-msg{font-size:13px;color:#64748b;line-height:1.65;max-width:300px;margin:0 auto 4px}.lm-form-grid{display:grid;gap:14px}.lm-form-grid--2{grid-template-columns:1fr 1fr}.lm-form-grid--3{grid-template-columns:1fr 1fr 1fr}.lm-field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.lm-label{font-size:12px;font-weight:700;color:#475569}.lm-req{color:#dc2626;margin-left:2px}.lm-hint{font-size:11px;color:#64748b}.lm-err{font-size:11px;color:#dc2626;font-weight:600}.lm-input{background:#fff;border:1.5px solid #e2e8f0;border-radius:9px;color:#0f172a;font-size:13px;padding:9px 12px;outline:none;width:100%;transition:all .2s;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-input:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1a}.lm-input--mono{font-family:DM Mono,monospace;letter-spacing:.03em}.lm-input:disabled{opacity:.6;cursor:not-allowed;background:#f8fafc}select.lm-input{cursor:pointer}.lm-info-strip{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#f0fdf9;border:1px solid #99f6e4;border-radius:9px;color:#0f766e;font-size:12px;font-weight:500;margin-bottom:16px}.lm-switch-row{display:flex;align-items:center;gap:10px}.lm-switch{position:relative;cursor:pointer;display:inline-block}.lm-switch input{opacity:0;width:0;height:0;position:absolute}.lm-switch__track{display:block;width:44px;height:24px;background:#e2e8f0;border:2px solid #cbd5e1;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.lm-switch input:checked~.lm-switch__track{background:#0f766e;border-color:#0f766e}.lm-switch__knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 4px #0003}.lm-switch input:checked~.lm-switch__track .lm-switch__knob{transform:translate(20px)}.lm-switch-lbl--on{font-size:13px;font-weight:600;color:#16a34a}.lm-switch-lbl--off{font-size:13px;font-weight:600;color:#dc2626}.lm-building-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.lm-building-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1.5px solid #e2e8f0;border-radius:9px;background:#fff;color:#64748b;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-building-tab:hover{border-color:#0f766e;color:#0f766e;background:#f0fdf9}.lm-building-tab--active{border-color:#0f766e;background:#0f766e;color:#fff}.lm-floors-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:16px}.lm-floors-col,.lm-rooms-col{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden}.lm-col-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:12px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.4px}.lm-floor-item{padding:12px 14px;border-bottom:1px solid #f1f5f9;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-floor-item:last-child{border-bottom:none}.lm-floor-item:hover{background:#fafbfc}.lm-floor-item__top{display:flex;align-items:center;gap:8px;margin-bottom:5px}.lm-floor-item__icon{width:28px;height:28px;border-radius:7px;background:#eff6ff;color:#2563eb;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lm-floor-item__name{font-size:13px;font-weight:600;color:#0f172a}.lm-floor-item__num{font-size:11px;font-family:DM Mono,monospace;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;padding:1px 5px;border-radius:4px;margin-left:4px}.lm-floor-item__meta{display:flex;align-items:center;gap:8px;padding-left:36px}.lm-room-item{padding:12px 14px;border-bottom:1px solid #f1f5f9;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-room-item:last-child{border-bottom:none}.lm-room-item:hover{background:#fafbfc}.lm-room-item__top{display:flex;align-items:center;gap:8px;margin-bottom:5px}.lm-room-item__icon{width:28px;height:28px;border-radius:7px;background:#f5f3ff;color:#7c3aed;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lm-room-item__name{font-size:13px;font-weight:600;color:#0f172a}.lm-room-item__meta{display:flex;align-items:center;gap:7px;padding-left:36px;flex-wrap:wrap}.lm-tree{display:flex;flex-direction:column;gap:16px}.lm-tree__building{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden}.lm-tree__building-hdr{display:flex;align-items:center;gap:8px;padding:14px 16px;background:linear-gradient(to right,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;font-size:14px;font-weight:700;color:#0f172a;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-tree__building-hdr svg{color:#0f766e}.lm-tree__floor{border-bottom:1px solid #f1f5f9}.lm-tree__floor:last-child{border-bottom:none}.lm-tree__floor-hdr{display:flex;align-items:center;gap:7px;padding:10px 16px 10px 28px;font-size:12px;font-weight:600;color:#475569;background:#fafbfc;border-bottom:1px solid #f1f5f9;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-tree__floor-hdr svg{color:#2563eb}.lm-tree__floor-level{font-family:DM Mono,monospace;font-size:10px;background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe;padding:1px 5px;border-radius:4px;margin-left:4px}.lm-tree__room{padding:10px 16px 10px 44px;border-bottom:1px solid #f8fafc}.lm-tree__room:last-child{border-bottom:none}.lm-tree__room-hdr{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#64748b;margin-bottom:10px;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-tree__room-hdr svg{color:#7c3aed}.lm-desk-grid{display:flex;flex-wrap:wrap;gap:8px}.lm-desk-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;padding:10px 12px;width:175px;flex-shrink:0;transition:all .15s;font-family:Plus Jakarta Sans,system-ui,sans-serif}.lm-desk-card:hover{border-color:#cbd5e1;box-shadow:0 3px 10px #0000000f;transform:translateY(-1px)}.lm-desk-card--occupied{border-color:#bfdbfe;background:#f0f9ff}.lm-desk-card--vacant{border-color:#bbf7d0;background:#f0fdf4}.lm-desk-card--online{border-color:#6ee7b7}.lm-desk-card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}.lm-desk-card__num{font-family:DM Mono,monospace;font-size:11.5px;font-weight:600;color:#0f172a}.lm-dot-online{width:7px;height:7px;border-radius:50%;background:#16a34a;animation:lm-pulse 1.6s ease-in-out infinite}@keyframes lm-pulse{0%,to{opacity:1}50%{opacity:.35}}.lm-desk-card__label{font-size:10.5px;color:#64748b;margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lm-desk-card__phone{display:flex;align-items:center;gap:4px;font-size:10px;color:#94a3b8;margin-bottom:5px}.lm-desk-card__staff{display:flex;align-items:center;gap:6px;margin-top:6px;padding-top:6px;border-top:1px solid rgba(0,0,0,.06)}.lm-desk-card__staff-info{min-width:0}.lm-desk-card__staff-name{font-size:11px;font-weight:600;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lm-desk-card__staff-num{font-size:10px;color:#94a3b8;font-family:DM Mono,monospace}.lm-desk-card__vacant{font-size:11px;color:#94a3b8;font-weight:500;margin-top:4px;text-transform:uppercase;letter-spacing:.3px}.lm-desk-card__acts{margin-top:8px}@media(max-width:1024px){.lm-kpi-strip{grid-template-columns:repeat(2,1fr)}.lm-floors-layout{grid-template-columns:1fr}.lm-form-grid--3{grid-template-columns:1fr 1fr}}@media(max-width:768px){.lm-kpi-strip{grid-template-columns:1fr 1fr}.lm-form-grid--2,.lm-form-grid--3{grid-template-columns:1fr}.lm-fbar{flex-direction:column;align-items:stretch}.lm-search-wrap{max-width:none}}@media print{.lm-toasts,.lm-fbar,.lm-acts,.lm-tab-bar,.lm-overlay{display:none!important}.lm-table-card,.lm-desk-card{box-shadow:none;border-color:#e2e8f0}}.qr-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap;font-family:Plus Jakarta Sans,system-ui,sans-serif}.qr-page-title{display:flex;align-items:center;gap:10px;font-size:22px;font-weight:800;color:#0f172a;letter-spacing:-.4px}.qr-title-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #2563eb4d;flex-shrink:0}.qr-page-sub{font-size:13px;color:#64748b;margin-top:4px;margin-left:48px}.qr-kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}.qr-kpi{position:relative;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:14px 16px 13px 18px;display:flex;align-items:center;gap:12px;overflow:hidden;transition:transform .2s,box-shadow .2s;animation:qr-kpi-in .35s cubic-bezier(.4,0,.2,1) var(--delay, 0ms) both;font-family:Plus Jakarta Sans,system-ui,sans-serif}.qr-kpi:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000012}.qr-kpi__bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--kc, #2563eb);border-radius:14px 0 0 14px}.qr-kpi__icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.qr-kpi__val{font-size:26px;font-weight:800;letter-spacing:-1px;line-height:1;font-family:DM Mono,monospace}.qr-kpi__lbl{font-size:10px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-top:3px}@keyframes qr-kpi-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.qr-purpose-strip{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}.qr-purpose-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:20px;font-size:12px;font-weight:600;color:#475569;font-family:Plus Jakarta Sans,system-ui,sans-serif;border-left:3px solid var(--pc, #2563eb)}.qr-purpose-chip__dot{width:7px;height:7px;border-radius:50%;background:var(--pc, #2563eb)}.qr-purpose-chip__count{background:#f1f5f9;border:1px solid #e2e8f0;padding:1px 7px;border-radius:10px;font-size:11px;font-weight:700;font-family:DM Mono,monospace;color:#0f172a}.qr-batch-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:10px 14px;margin-bottom:16px;flex-wrap:wrap;font-family:Plus Jakarta Sans,system-ui,sans-serif}.qr-batch-bar__left{display:flex;align-items:center;gap:10px;flex:1;min-width:0;position:relative}.qr-batch-bar__right{display:flex;gap:8px;flex-shrink:0}.qr-batch-bar__label{font-size:12px;font-weight:700;color:#64748b;white-space:nowrap}.qr-batch-selector{position:relative;flex:1;min-width:0}.qr-batch-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;cursor:pointer;font-family:inherit;font-size:13px;color:#64748b;transition:all .15s;text-align:left}.qr-batch-trigger:hover{border-color:#2563eb;background:#fff}.qr-batch-trigger--active{border-color:var(--bc, #2563eb);background:#fff;color:#0f172a;box-shadow:0 0 0 3px color-mix(in srgb,var(--bc, #2563eb) 12%,transparent)}.qr-batch-trigger__dot{width:8px;height:8px;border-radius:50%;background:var(--bc, #2563eb);animation:qr-pulse 1.6s ease-in-out infinite;flex-shrink:0}@keyframes qr-pulse{0%,to{opacity:1}50%{opacity:.35}}.qr-batch-trigger__code{font-family:DM Mono,monospace;font-size:12px;font-weight:600;color:#0f172a}.qr-batch-trigger__purpose{font-size:12px;color:#64748b;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qr-batch-trigger__count{font-family:DM Mono,monospace;font-size:12px;font-weight:700;background:#f1f5f9;border:1px solid #e2e8f0;padding:1px 7px;border-radius:6px;color:#0f172a;flex-shrink:0}.qr-batch-trigger__arrow{color:#94a3b8;flex-shrink:0;transition:transform .2s}.qr-batch-trigger__arrow--open{transform:rotate(180deg)}.qr-batch-drop{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:200;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 16px 48px -8px #0f172a33,0 0 0 1px #0f172a08;overflow:hidden;animation:qr-drop-in .16s cubic-bezier(.4,0,.2,1);max-height:320px;overflow-y:auto}@keyframes qr-drop-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.qr-batch-drop__hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 8px;font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #f1f5f9;background:#fafbfc;position:sticky;top:0;z-index:1}.qr-batch-drop__close{background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:2px;border-radius:4px;transition:color .15s}.qr-batch-drop__close:hover{color:#dc2626}.qr-batch-drop__empty{padding:20px;font-size:12px;color:#94a3b8;text-align:center;font-style:italic}.qr-batch-item{display:flex;align-items:center;gap:11px;width:100%;padding:10px 14px;border:none;background:transparent;cursor:pointer;font-family:inherit;text-align:left;border-bottom:1px solid #f8fafc;transition:background .1s}.qr-batch-item:hover{background:#f8fafc}.qr-batch-item--active{background:#eff6ff}.qr-batch-item__dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.qr-batch-item__body{flex:1;min-width:0}.qr-batch-item__code{font-family:DM Mono,monospace;font-size:12px;font-weight:600;color:#0f172a}.qr-batch-item__meta{font-size:11px;color:#64748b;margin-top:1px}.qr-batch-item__check{color:#2563eb;flex-shrink:0}.qr-main{display:grid;grid-template-columns:380px 1fr;gap:16px;align-items:start}.qr-scanner-panel{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:22px;box-shadow:0 4px 24px #0000000f;font-family:Plus Jakarta Sans,system-ui,sans-serif;cursor:default}.qr-no-batch{text-align:center;padding:40px 16px}.qr-no-batch__icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);display:flex;align-items:center;justify-content:center;color:#94a3b8;margin:0 auto 16px}.qr-no-batch__title{font-size:16px;font-weight:700;color:#0f172a;margin-bottom:6px}.qr-no-batch__body{font-size:13px;color:#64748b;line-height:1.6;margin-bottom:18px}.qr-flash{display:flex;flex-direction:column;align-items:center;padding:14px;border-radius:14px;margin-bottom:14px;text-align:center;animation:qr-flash-in .18s ease}@keyframes qr-flash-in{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:none}}.qr-flash--success{background:#f0fdf4;border:2px solid #bbf7d0}.qr-flash--warning{background:#fffbeb;border:2px solid #fde68a}.qr-flash--error{background:#fff5f5;border:2px solid #fca5a5}.qr-flash__icon{margin-bottom:5px}.qr-flash--success .qr-flash__icon{color:#16a34a}.qr-flash--warning .qr-flash__icon{color:#d97706}.qr-flash--error .qr-flash__icon{color:#dc2626}.qr-flash__label{font-size:12px;font-weight:800;color:#0f172a}.qr-flash__val{font-family:DM Mono,monospace;font-size:11px;color:#475569;margin-top:3px;word-break:break-all}.qr-flash__msg{font-size:10px;color:#64748b;margin-top:2px}.qr-scan-area{margin-bottom:14px}.qr-scan-area__hdr{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:#0f172a;margin-bottom:10px}.qr-scan-area__hdr svg{color:#0f766e}.qr-scan-status{margin-left:auto;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;flex-shrink:0}.qr-scan-status--ready{color:#16a34a;background:#dcfce7;border:1px solid #bbf7d0;animation:qr-status-pulse 2s ease-in-out infinite}.qr-scan-status--saving{color:#2563eb;background:#dbeafe;border:1px solid #bfdbfe}@keyframes qr-status-pulse{0%,to{opacity:1}50%{opacity:.6}}.qr-scan-input-wrap{position:relative;display:flex;align-items:center;background:#fff;border:2.5px solid #0f766e;border-radius:12px;transition:all .2s;margin-bottom:10px;cursor:text;box-shadow:0 0 0 4px #0f766e1a}.qr-scan-input-wrap:focus-within{border-color:#0f766e;box-shadow:0 0 0 5px #0f766e2e}.qr-scan-input-wrap--scanning{border-color:#2563eb;box-shadow:0 0 0 5px #2563eb26;background:#f8faff}.qr-scan-input-icon{position:absolute;left:13px;color:#94a3b8;flex-shrink:0}.qr-scan-input{flex:1;padding:13px 40px 13px 42px;background:transparent;border:none;outline:none;font-family:DM Mono,monospace;font-size:14px;font-weight:500;color:#0f172a;letter-spacing:.04em}.qr-scan-input::placeholder{color:#94a3b8;font-weight:400}.qr-scan-clear{position:absolute;right:11px;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:4px;border-radius:6px;transition:all .15s}.qr-scan-clear:hover{background:#f1f5f9;color:#dc2626}.qr-scan-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;background:linear-gradient(135deg,#0f766e,#0d6460);color:#fff;border:none;border-radius:11px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .17s;box-shadow:0 4px 14px #0f766e4d}.qr-scan-btn:hover:not(:disabled){background:linear-gradient(135deg,#0d6460,#0b5955);transform:translateY(-1px);box-shadow:0 6px 18px #0f766e59}.qr-scan-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.qr-session-counter{display:flex;flex-direction:column;align-items:center;padding:16px;background:#f0fdf9;border:1.5px solid #99f6e4;border-radius:12px;margin:14px 0}.qr-session-counter__val{font-size:44px;font-weight:800;color:#0f766e;font-family:DM Mono,monospace;letter-spacing:-2px;line-height:1}.qr-session-counter__lbl{font-size:11px;font-weight:700;color:#0f766e;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.qr-active-batch-info{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px 14px;margin-bottom:14px}.qr-active-batch-info__row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:5px 0;border-bottom:1px solid #f1f5f9}.qr-active-batch-info__row:last-child{border-bottom:none}.qr-active-batch-info__k{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px}.qr-active-batch-info__v{font-size:12px;color:#0f172a;font-weight:600}.qr-instructions{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:12px 14px;font-family:Plus Jakarta Sans,system-ui,sans-serif}.qr-instructions__hdr{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:#1d4ed8;text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}.qr-instructions__list{padding-left:17px;margin:0;font-size:12px;color:#1d4ed8;line-height:1.9}.qr-instructions__list kbd{font-family:DM Mono,monospace;font-size:10px;background:#dbeafe;border:1px solid #bfdbfe;border-radius:4px;padding:1px 5px;color:#1d4ed8}.qr-log-panel{background:#fff;border:1px solid #e2e8f0;border-radius:18px;overflow:hidden;box-shadow:0 2px 12px #0000000a;font-family:Plus Jakarta Sans,system-ui,sans-serif;min-height:500px;display:flex;flex-direction:column}.qr-log-panel__hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:linear-gradient(to bottom,#f8fafc,#f1f5f9);border-bottom:2px solid #e2e8f0;flex-shrink:0}.qr-log-panel__hdr-left{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:#0f172a}.qr-log-panel__hdr-left svg{color:#2563eb}.qr-log-panel__count{font-size:11px;font-weight:500;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 8px;border-radius:10px}.qr-view-toggle{display:flex;gap:2px;background:#f1f5f9;border-radius:8px;padding:3px}.qr-view-btn{padding:5px 14px;border:none;border-radius:6px;background:transparent;color:#64748b;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.qr-view-btn:hover{color:#0f172a}.qr-view-btn--active{background:#fff;color:#2563eb;box-shadow:0 1px 4px #00000014}.qr-log-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#94a3b8;padding:40px;text-align:center;font-size:13px}.qr-log-empty svg{color:#cbd5e1}.qr-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;padding:14px;flex:1}.qr-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;overflow:hidden;display:flex;flex-direction:column;align-items:center;padding:12px 12px 10px;gap:8px;transition:all .15s;animation:qr-card-in .2s ease both;position:relative}.qr-card:hover{border-color:#bfdbfe;box-shadow:0 6px 20px #2563eb1a;transform:translateY(-2px)}.qr-card--new{animation:qr-card-flash .4s ease}@keyframes qr-card-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:none}}@keyframes qr-card-flash{0%{background:#dcfce7;border-color:#86efac}to{background:#fff;border-color:#e2e8f0}}.qr-card__qr{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}.qr-card__seq{position:absolute;bottom:-6px;right:-6px;background:#2563eb;color:#fff;font-size:9px;font-weight:800;font-family:DM Mono,monospace;padding:2px 5px;border-radius:5px;box-shadow:0 1px 4px #2563eb66}.qr-img-wrap{position:relative;border-radius:8px;overflow:hidden;background:#f8fafc;border:1px solid #e2e8f0}.qr-img-canvas{display:block;opacity:0;transition:opacity .2s}.qr-img-canvas--ready{opacity:1}.qr-img-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#cbd5e1;background:#f8fafc}.qr-card__body{width:100%;min-width:0}.qr-card__val{font-family:DM Mono,monospace;font-size:11px;font-weight:600;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;margin-bottom:4px}.qr-card__meta{display:flex;align-items:center;justify-content:center;gap:4px;font-size:10px;color:#94a3b8;flex-wrap:wrap}.qr-card__date{color:#cbd5e1}.qr-card__badge{display:inline-block;font-size:9px;font-weight:700;text-transform:uppercase;background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe;padding:1px 6px;border-radius:4px;margin-top:3px}.qr-card__del{width:100%}.qr-card__confirm{display:flex;align-items:center;gap:5px;justify-content:center}.qr-card__confirm-txt{font-size:11px;color:#dc2626;font-weight:600}.qr-delbtn{width:30px;height:30px;border-radius:8px;border:1.5px solid #e2e8f0;background:#fff;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.qr-delbtn--ghost:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5}.qr-delbtn--red{background:#dc2626;color:#fff;border-color:#dc2626}.qr-delbtn--red:hover{background:#b91c1c}.qr-delbtn:disabled{opacity:.5;cursor:not-allowed}.qr-card-skel{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:12px;display:flex;flex-direction:column;align-items:center;gap:10px}.qr-card-skel__img{border-radius:8px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:qr-shimmer 1.4s linear infinite;flex-shrink:0}.qr-card-skel__lines{width:100%;display:flex;flex-direction:column;gap:6px}.qr-card-skel__bar{height:10px;border-radius:5px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:qr-shimmer 1.4s linear infinite}.qr-card-skel__bar--lg{width:100%}.qr-card-skel__bar--sm{width:60%}@keyframes qr-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.qr-pagination{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;border-top:1px solid #f1f5f9;background:#fafbfc;flex-wrap:wrap;flex-shrink:0;font-family:Plus Jakarta Sans,system-ui,sans-serif}.qr-pg-info{font-size:12px;color:#64748b;font-weight:500;white-space:nowrap}.qr-pg-controls{display:flex;align-items:center;gap:4px}.qr-pg-nav{width:38px;height:38px;border-radius:10px;border:1.5px solid #e2e8f0;background:#fff;color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.qr-pg-nav:hover:not(:disabled){border-color:#2563eb;color:#2563eb;background:#eff6ff}.qr-pg-nav:disabled{opacity:.35;cursor:not-allowed}.qr-pg-nums{display:flex;align-items:center;gap:3px}.qr-pg-num{min-width:38px;height:38px;padding:0 4px;border-radius:10px;border:1.5px solid #e2e8f0;background:#fff;color:#475569;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;display:flex;align-items:center;justify-content:center}.qr-pg-num:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.qr-pg-num--active{background:#2563eb!important;color:#fff!important;border-color:#2563eb!important;box-shadow:0 2px 8px #2563eb4d}.qr-pg-dots{padding:0 4px;color:#94a3b8;font-size:13px}.qr-pg-mobile{display:none;font-size:13px;font-weight:700;color:#0f172a;font-family:DM Mono,monospace;padding:0 8px}.qr-pg-perpage{display:flex;align-items:center;gap:5px;font-size:12px;color:#64748b;white-space:nowrap}.qr-pg-pp{width:34px;height:30px;border-radius:8px;border:1.5px solid #e2e8f0;background:#fff;color:#475569;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;display:flex;align-items:center;justify-content:center}.qr-pg-pp:hover{border-color:#2563eb;color:#2563eb}.qr-pg-pp--active{background:#2563eb;color:#fff;border-color:#2563eb}.qr-view-all-prompt{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid #f1f5f9;background:#fafbfc;font-size:12px;color:#64748b;flex-shrink:0}.qr-overlay{position:fixed;inset:0;background:#00000085;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:qr-ovl-in .2s ease;font-family:Plus Jakarta Sans,system-ui,sans-serif}@keyframes qr-ovl-in{0%{opacity:0}to{opacity:1}}.qr-modal{background:#fff;border-radius:20px;box-shadow:0 32px 64px -20px #00000061,0 0 0 1px #0000000a;width:100%;max-width:460px;animation:qr-modal-in .22s cubic-bezier(.4,0,.2,1)}@keyframes qr-modal-in{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:none}}.qr-modal__hdr{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 14px;border-bottom:1px solid #f1f5f9;gap:12px}.qr-modal__hdr-left{display:flex;align-items:center;gap:12px}.qr-modal__icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 3px 10px #2563eb40;flex-shrink:0}.qr-modal__title{font-size:15px;font-weight:800;color:#0f172a}.qr-modal__sub{font-size:12px;color:#64748b;margin-top:1px}.qr-modal__close{width:32px;height:32px;border-radius:50%;border:1.5px solid #e2e8f0;background:#f8fafc;color:#475569;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.qr-modal__close:hover{background:#fee2e2;color:#dc2626;border-color:#dc2626;transform:rotate(90deg)}.qr-modal__body{padding:18px 22px}.qr-modal__foot{padding:12px 22px;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:9px;flex-wrap:wrap}.qr-fg{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.qr-fg>label{font-size:12px;font-weight:700;color:#475569}.qr-req{color:#dc2626;margin-left:1px}.qr-opt{font-size:10px;font-weight:500;color:#94a3b8;background:#f1f5f9;padding:1px 6px;border-radius:5px;border:1px solid #e2e8f0;margin-left:4px}.qr-input{background:#fff;border:1.5px solid #e2e8f0;border-radius:9px;color:#0f172a;font-size:13px;padding:9px 12px;outline:none;width:100%;transition:all .2s;font-family:inherit}.qr-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}select.qr-input{cursor:pointer}.qr-info-strip{display:flex;align-items:flex-start;gap:8px;padding:10px 13px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:9px;color:#1d4ed8;font-size:12px;line-height:1.5;margin-top:4px}.qr-info-strip svg{flex-shrink:0;margin-top:1px}.qr-alert{display:flex;align-items:center;gap:8px;padding:10px 13px;border-radius:9px;font-size:13px;font-weight:500;margin-bottom:14px}.qr-alert--error{background:#fee2e2;border:1px solid #fca5a5;color:#dc2626}.qr-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:700;padding:9px 16px;border-radius:9px;border:1.5px solid transparent;cursor:pointer;transition:all .17s;font-family:inherit;white-space:nowrap}.qr-btn--sm{font-size:12px;padding:7px 13px}.qr-btn--primary{background:#2563eb;color:#fff;border-color:#2563eb}.qr-btn--primary:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.qr-btn--ghost{background:#fff;color:#475569;border-color:#e2e8f0}.qr-btn--ghost:hover:not(:disabled){background:#f8fafc;color:#0f172a;border-color:#cbd5e1}.qr-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.qr-spinner{display:inline-block;width:11px;height:11px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:qr-spin .5s linear infinite}.qr-spinner--sm{width:9px;height:9px}.qr-mono{font-family:DM Mono,monospace;font-size:12px}.qr-spin{animation:qr-spin 1s linear infinite}@keyframes qr-spin{to{transform:rotate(360deg)}}.qr-toasts{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.qr-toast{display:flex;align-items:center;gap:11px;padding:12px 15px;background:#fff;border-radius:12px;box-shadow:0 8px 30px #0f172a24,0 1px 4px #0f172a0f;min-width:280px;max-width:380px;border-left:3.5px solid #2563eb;animation:qr-toast-slide .25s cubic-bezier(.4,0,.2,1);font-family:Plus Jakarta Sans,system-ui,sans-serif}.qr-toast--success{border-left-color:#16a34a}.qr-toast--error{border-left-color:#dc2626}.qr-toast--warning{border-left-color:#d97706}.qr-toast--info{border-left-color:#2563eb}.qr-toast__icon{flex-shrink:0;display:flex}.qr-toast--success .qr-toast__icon{color:#16a34a}.qr-toast--error .qr-toast__icon{color:#dc2626}.qr-toast--warning .qr-toast__icon{color:#d97706}.qr-toast--info .qr-toast__icon{color:#2563eb}.qr-toast__msg{flex:1;font-size:13px;font-weight:500;color:#0f172a;line-height:1.4}.qr-toast__x{background:none;border:none;color:#94a3b8;cursor:pointer;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s}.qr-toast__x:hover{background:#f1f5f9;color:#0f172a}@keyframes qr-toast-slide{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:1024px){.qr-main{grid-template-columns:1fr}.qr-kpi-strip{grid-template-columns:repeat(2,1fr)}.qr-cards-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media(max-width:767px){.qr-page-sub{margin-left:0;margin-top:6px}.qr-kpi-strip{grid-template-columns:repeat(2,1fr)}.qr-batch-bar{flex-direction:column;align-items:stretch}.qr-batch-bar__left{flex-direction:column;align-items:flex-start;gap:6px}.qr-batch-bar__right{justify-content:flex-end}.qr-cards-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:10px}.qr-pg-nums{display:none}.qr-pg-mobile{display:block}.qr-pg-nav{width:44px;height:44px;border-radius:12px}.qr-pagination{justify-content:center;gap:8px}.qr-pg-info{width:100%;text-align:center;margin-bottom:2px}.qr-pg-perpage{width:100%;justify-content:center}.qr-pg-pp{width:40px;height:36px;font-size:13px}}@media(max-width:480px){.qr-kpi-strip{grid-template-columns:1fr 1fr}.qr-cards-grid{grid-template-columns:repeat(2,1fr);gap:8px;padding:8px}.qr-page-title{font-size:18px}.qr-title-icon{width:32px;height:32px}.qr-toasts .qr-toast{min-width:auto;width:calc(100vw - 32px)}.qr-pg-controls{gap:6px}.qr-pg-nav{width:48px;height:48px}}@media(max-width:360px){.qr-cards-grid{grid-template-columns:1fr}}@media print{.qr-toasts,.qr-scan-area,.qr-instructions,.qr-overlay{display:none!important}.qr-cards-grid{grid-template-columns:repeat(4,1fr)}}.enq-ref-toast-wrap{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.enq-ref-toast{display:flex;align-items:center;gap:12px;padding:13px 18px;background:var(--bg-card, #fff);border-radius:10px;box-shadow:0 8px 20px #00000021;min-width:300px;max-width:400px;border-left:4px solid var(--primary, #2563eb);animation:enq-ref-slide-in .28s ease}.enq-ref-toast-success{border-left-color:var(--success, #16a34a)}.enq-ref-toast-error{border-left-color:var(--danger, #dc2626)}.enq-ref-toast-warning{border-left-color:var(--warning, #d97706)}.enq-ref-toast-icon{display:flex;flex-shrink:0}.enq-ref-toast-success .enq-ref-toast-icon{color:var(--success, #16a34a)}.enq-ref-toast-error .enq-ref-toast-icon{color:var(--danger, #dc2626)}.enq-ref-toast-warning .enq-ref-toast-icon{color:var(--warning, #d97706)}.enq-ref-toast-info .enq-ref-toast-icon{color:var(--primary, #2563eb)}.enq-ref-toast-msg{flex:1;font-size:13.5px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.enq-ref-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);font-size:19px;cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s,color .15s}.enq-ref-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes enq-ref-slide-in{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.enq-ref-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.enq-ref-page-title{font-size:23px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:10px}.enq-ref-page-title svg{color:var(--primary, #2563eb)}.enq-ref-page-sub{font-size:13px;color:var(--tx3, #64748b);margin-top:4px}.enq-ref-page-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.enq-ref-tabs{display:flex;gap:4px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:4px;margin-bottom:24px;width:fit-content}.enq-ref-tab{display:flex;align-items:center;gap:7px;padding:9px 18px;border:none;cursor:pointer;border-radius:9px;font-size:13.5px;font-weight:600;color:var(--tx2, #475569);background:transparent;transition:all .2s;font-family:inherit}.enq-ref-tab:hover{background:var(--bg-card, #fff);color:var(--tx1, #0f172a)}.enq-ref-tab.active{background:var(--bg-card, #fff);color:var(--primary, #2563eb);box-shadow:0 2px 6px #00000012}.enq-ref-tab-count{font-size:11px;font-weight:700;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);padding:2px 7px;border-radius:20px;min-width:22px;text-align:center}.enq-ref-tab.active .enq-ref-tab-count{background:var(--primary, #2563eb);color:#fff}.enq-ref-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.enq-ref-stat{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:20px 18px;display:flex;align-items:center;gap:14px;transition:transform .25s,box-shadow .25s;box-shadow:0 2px 6px #0000000a}.enq-ref-stat:hover{transform:translateY(-3px);box-shadow:0 10px 22px -6px #0000001c}.enq-ref-stat-primary{border-left:4px solid var(--primary, #2563eb)}.enq-ref-stat-success{border-left:4px solid var(--success, #16a34a)}.enq-ref-stat-warn{border-left:4px solid var(--warning, #d97706)}.enq-ref-stat-terminal{border-left:4px solid #7c3aed}.enq-ref-stat-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.enq-ref-stat-primary .enq-ref-stat-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.enq-ref-stat-success .enq-ref-stat-icon{background:#dcfce7;color:#16a34a}.enq-ref-stat-warn .enq-ref-stat-icon{background:#fef3c7;color:#d97706}.enq-ref-stat-terminal .enq-ref-stat-icon{background:#ede9fe;color:#7c3aed}.enq-ref-stat-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--tx3, #64748b);margin-bottom:4px}.enq-ref-stat-value{font-size:28px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.1}.enq-ref-filters{display:flex;gap:14px;flex-wrap:wrap;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border, #e2e8f0);margin-bottom:0}.enq-ref-search-wrap{position:relative;flex:1;min-width:240px}.enq-ref-search-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.enq-ref-search{width:100%;padding:10px 14px 10px 40px;background:var(--bg, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;font-size:13.5px;color:var(--tx1, #0f172a);outline:none;transition:border-color .2s,box-shadow .2s;font-family:inherit}.enq-ref-search:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.enq-ref-search::placeholder{color:var(--tx3, #94a3b8)}.enq-ref-select{padding:9px 13px;background:var(--bg, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;font-size:13px;color:var(--tx1, #0f172a);outline:none;cursor:pointer;font-family:inherit;transition:border-color .2s}.enq-ref-select:focus{border-color:var(--primary, #2563eb)}.enq-ref-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:16px;box-shadow:0 3px 10px #0000000a;overflow:hidden}.enq-ref-table-scroll{overflow-x:auto}.enq-ref-table{width:100%;border-collapse:separate;border-spacing:0}.enq-ref-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3, #64748b);padding:14px 16px;text-align:left;background:var(--bg, #f8fafc);border-bottom:2px solid var(--border, #e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background .15s}.enq-ref-table th:hover{background:#eef2f7}.enq-ref-table td{padding:14px 16px;font-size:13.5px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #fff);transition:background .15s}.enq-ref-table tr:last-child td{border-bottom:none}.enq-ref-table tr:hover td{background:var(--bg, #f8fafc)}.enq-ref-table tr.dragging{opacity:.45}.enq-ref-table tr.dragging td{background:var(--primary-light, #dbeafe)}.enq-ref-label-cell{font-weight:500;color:var(--tx1, #0f172a)}.enq-ref-code{font-family:SF Mono,Fira Code,monospace;font-size:11.5px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:3px 8px;border-radius:5px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block;white-space:nowrap}.enq-ref-terminal-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid transparent}.enq-ref-terminal-badge.is-terminal{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.enq-ref-terminal-badge.not-terminal{background:#f1f5f9;color:#475569;border-color:#e2e8f0}.enq-ref-order-pill{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:28px;padding:0 8px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:6px;font-weight:600;font-size:13px;color:var(--tx2, #475569)}.enq-ref-date{font-size:11.5px;color:var(--tx3, #64748b);background:var(--bg, #f8fafc);padding:3px 8px;border-radius:5px;display:inline-block;white-space:nowrap}.enq-ref-sort-icon{margin-left:6px;color:var(--tx3, #94a3b8);font-size:13px;display:inline-block}.enq-ref-sort-icon.active{color:var(--primary, #2563eb)}.enq-ref-grip{color:var(--tx3, #94a3b8);cursor:grab;transition:color .15s}.enq-ref-grip:hover{color:var(--primary, #2563eb)}.enq-ref-drag-hint{display:flex;align-items:center;gap:6px;padding:10px 16px;font-size:11.5px;color:var(--tx3, #64748b);border-top:1px dashed var(--border, #e2e8f0)}.enq-ref-drag-hint svg{color:var(--primary, #2563eb)}.enq-ref-toggle-wrap{display:flex;align-items:center;gap:10px}.enq-ref-toggle-label{font-size:12.5px;font-weight:500}.enq-ref-toggle-label.active{color:var(--success, #16a34a)}.enq-ref-toggle-label.inactive{color:var(--danger, #dc2626)}.enq-ref-switch{position:relative;display:inline-block;cursor:pointer}.enq-ref-switch input{opacity:0;width:0;height:0;position:absolute}.enq-ref-switch-track{display:block;width:38px;height:21px;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:20px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative}.enq-ref-switch input:checked+.enq-ref-switch-track{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.enq-ref-switch-thumb{position:absolute;top:1px;left:1px;width:15px;height:15px;background:#fff;border-radius:50%;transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0003}.enq-ref-switch input:checked+.enq-ref-switch-track .enq-ref-switch-thumb{transform:translate(17px)}.enq-ref-actions{display:flex;gap:6px}.enq-ref-act-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .18s}.enq-ref-act-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-1px);box-shadow:0 3px 8px #2563eb2e}.enq-ref-act-btn.danger:hover:not(:disabled){background:#fee2e2;color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);box-shadow:0 3px 8px #dc26262e}.enq-ref-act-btn:disabled{opacity:.45;cursor:not-allowed}.enq-ref-pagination{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-top:1px solid var(--border, #e2e8f0);flex-wrap:wrap;gap:12px}.enq-ref-pag-info{font-size:12.5px;color:var(--tx3, #64748b)}.enq-ref-pag-btns{display:flex;gap:5px}.enq-ref-pag-btn{width:34px;height:34px;border-radius:7px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.enq-ref-pag-btn:hover:not(:disabled){background:var(--bg, #f8fafc);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.enq-ref-pag-btn.active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.enq-ref-pag-btn:disabled{opacity:.38;cursor:not-allowed}.enq-ref-empty{text-align:center;padding:56px 20px;background:var(--bg-card, #fff);border-radius:16px;border:2px dashed var(--border, #e2e8f0)}.enq-ref-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:16px}.enq-ref-empty h3{font-size:17px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:6px}.enq-ref-empty p{font-size:13px;color:var(--tx3, #64748b);margin-bottom:20px}.enq-ref-skeleton{background:var(--bg-card, #fff);border-radius:16px;border:1px solid var(--border, #e2e8f0);padding:20px 24px}.enq-ref-skel-row{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid var(--border, #e2e8f0)}.enq-ref-skel-row:last-child{border-bottom:none}.enq-ref-skel-cell{height:18px;border-radius:4px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:enq-ref-shimmer 1.4s infinite}@keyframes enq-ref-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.enq-ref-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:9px;border:none;cursor:pointer;transition:all .18s;white-space:nowrap;line-height:1;font-family:inherit}.enq-ref-btn.sm{font-size:12px;padding:8px 14px}.enq-ref-btn.primary{background:var(--primary, #2563eb);color:#fff}.enq-ref-btn.primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb47}.enq-ref-btn.ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.enq-ref-btn.ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--tx2, #475569)}.enq-ref-btn.danger{background:var(--danger, #dc2626);color:#fff}.enq-ref-btn.danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc262647}.enq-ref-btn:disabled{opacity:.48;cursor:not-allowed}.enq-ref-spin{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:enq-ref-rotate .55s linear infinite}.enq-ref-spin-slow{animation:enq-ref-rotate 1s linear infinite}@keyframes enq-ref-rotate{to{transform:rotate(360deg)}}.enq-ref-modal-bg{position:fixed;inset:0;background:#00000075;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:enq-ref-fade .2s ease}@keyframes enq-ref-fade{0%{opacity:0}to{opacity:1}}.enq-ref-modal{background:var(--bg-card, #fff);border-radius:22px;border:1px solid var(--border, #e2e8f0);box-shadow:0 28px 56px -16px #00000047;width:100%;max-width:500px;max-height:92vh;overflow-y:auto;animation:enq-ref-pop .28s cubic-bezier(.34,1.56,.64,1)}.enq-ref-modal-sm{max-width:400px}@keyframes enq-ref-pop{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.enq-ref-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:22px 26px 8px}.enq-ref-modal-title{font-size:17px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.enq-ref-modal-title svg{color:var(--primary, #2563eb)}.enq-ref-modal-x{width:30px;height:30px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:17px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.enq-ref-modal-x:hover:not(:disabled){background:#fee2e2;color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.enq-ref-modal-x:disabled{opacity:.45;cursor:not-allowed}.enq-ref-modal-body{padding:18px 26px}.enq-ref-modal-foot{padding:18px 26px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:10px}.enq-ref-field{display:flex;flex-direction:column;gap:5px;margin-bottom:18px}.enq-ref-label{font-size:12.5px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:7px}.enq-ref-req{color:var(--danger, #dc2626);font-size:14px}.enq-ref-auto-tag{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:10px;border:1px solid #bfdbfe}.enq-ref-hint{font-size:11px;color:var(--tx3, #64748b);line-height:1.5}.enq-ref-err{font-size:11px;color:var(--danger, #dc2626);margin-top:2px}.enq-ref-input{padding:10px 13px;background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13.5px;outline:none;width:100%;transition:border-color .2s,box-shadow .2s;font-family:inherit}.enq-ref-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.enq-ref-input.has-error{border-color:var(--danger, #dc2626);background:#fff5f5}.enq-ref-input:disabled{opacity:.55;cursor:not-allowed}.enq-ref-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.enq-ref-terminal-card{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border-radius:10px;background:var(--bg, #f8fafc);border:1.5px solid var(--border, #e2e8f0);margin-bottom:18px}.enq-ref-terminal-info{display:flex;align-items:flex-start;gap:10px}.enq-ref-terminal-icon{color:#7c3aed;flex-shrink:0;margin-top:2px}.enq-ref-terminal-title{font-size:13px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:3px}.enq-ref-terminal-desc{font-size:12px;color:var(--tx3, #64748b);line-height:1.55}.enq-ref-terminal-desc strong{color:var(--tx2, #475569)}.enq-ref-terminal-desc code{font-family:SF Mono,Fira Code,monospace;font-size:11px;background:var(--bg-card, #fff);padding:1px 5px;border-radius:4px;border:1px solid var(--border, #e2e8f0)}.enq-ref-confirm-body{text-align:center;padding:20px 26px}.enq-ref-confirm-icon{margin-bottom:14px}.enq-ref-confirm-icon svg{color:var(--tx3, #94a3b8)}.enq-ref-confirm-icon.danger svg{color:var(--danger, #dc2626)}.enq-ref-confirm-msg{font-size:14px;color:var(--tx2, #475569);line-height:1.6}@media(max-width:1100px){.enq-ref-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.enq-ref-page-hdr{flex-direction:column}.enq-ref-page-actions{width:100%}.enq-ref-stats-grid{grid-template-columns:1fr;gap:12px}.enq-ref-row-2{grid-template-columns:1fr}.enq-ref-tabs{width:100%;justify-content:stretch}.enq-ref-tab{flex:1;justify-content:center}.enq-ref-modal{border-radius:16px}.enq-ref-modal-hdr,.enq-ref-modal-body,.enq-ref-modal-foot{padding:16px 18px}}@media print{.enq-ref-page-actions,.enq-ref-filters,.enq-ref-actions,.enq-ref-toggle-wrap,.enq-ref-drag-hint,.enq-ref-grip,.enq-ref-toast-wrap,.enq-ref-modal-bg{display:none!important}}.cfo-toast-wrap{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.cfo-toast{display:flex;align-items:center;gap:12px;padding:13px 18px;background:var(--bg-card, #fff);border-radius:10px;box-shadow:0 8px 20px #00000021;min-width:300px;max-width:400px;border-left:4px solid var(--primary, #2563eb);animation:cfo-slide-in .28s ease}.cfo-toast-success{border-left-color:var(--success, #16a34a)}.cfo-toast-error{border-left-color:var(--danger, #dc2626)}.cfo-toast-warning{border-left-color:var(--warning, #d97706)}.cfo-toast-msg{flex:1;font-size:13.5px;font-weight:500;color:var(--tx1, #0f172a)}.cfo-toast-x{background:none;border:none;color:var(--tx3, #94a3b8);font-size:19px;cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}@keyframes cfo-slide-in{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.cfo-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.cfo-page-title{font-size:23px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:10px}.cfo-page-title svg{color:var(--primary, #2563eb)}.cfo-page-sub{font-size:13px;color:var(--tx3, #64748b);margin-top:4px}.cfo-page-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.cfo-tabs{display:flex;gap:4px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:4px;margin-bottom:24px;flex-wrap:wrap}.cfo-tab{display:flex;align-items:center;gap:7px;padding:9px 18px;border:none;cursor:pointer;border-radius:9px;font-size:13px;font-weight:600;color:var(--tx2, #475569);background:transparent;transition:all .2s;font-family:inherit}.cfo-tab:hover:not(:disabled){background:var(--bg-card, #fff);color:var(--tx1, #0f172a)}.cfo-tab.active{background:var(--bg-card, #fff);color:var(--primary, #2563eb);box-shadow:0 2px 6px #00000012}.cfo-tab:disabled{opacity:.38;cursor:not-allowed}.cfo-tab-cnt{font-size:11px;font-weight:700;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);padding:2px 7px;border-radius:20px}.cfo-tab.active .cfo-tab-cnt{background:var(--primary, #2563eb);color:#fff}.cfo-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:9px;border:none;cursor:pointer;transition:all .18s;white-space:nowrap;line-height:1;font-family:inherit}.cfo-btn.sm{font-size:12px;padding:8px 14px}.cfo-btn.xs{font-size:11px;padding:5px 10px;border-radius:6px}.cfo-btn.primary{background:var(--primary, #2563eb);color:#fff}.cfo-btn.primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb47}.cfo-btn.ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.cfo-btn.ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--tx2, #475569)}.cfo-btn.danger{background:var(--danger, #dc2626);color:#fff}.cfo-btn.danger:hover:not(:disabled){background:#b91c1c}.cfo-btn.danger-outline{background:transparent;color:var(--danger, #dc2626);border:1.5px solid var(--danger, #dc2626)}.cfo-btn.danger-outline:hover:not(:disabled){background:#fee2e2}.cfo-btn.success{background:var(--success, #16a34a);color:#fff}.cfo-btn.success:hover:not(:disabled){background:#15803d;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a47}.cfo-btn:disabled{opacity:.48;cursor:not-allowed}.cfo-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid transparent;white-space:nowrap}.cfo-badge-active{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.cfo-badge-draft{background:#f1f5f9;color:#475569;border-color:#e2e8f0}.cfo-badge-paused{background:#fef3c7;color:#b45309;border-color:#fde68a}.cfo-badge-archived{background:#f1f5f9;color:#6b7280;border-color:#d1d5db}.cfo-badge-pending{background:#fef3c7;color:#b45309;border-color:#fde68a}.cfo-badge-assigned{background:#e0f2fe;color:#0369a1;border-color:#bae6fd}.cfo-badge-in-progress{background:#ede9fe;color:#6d28d9;border-color:#ddd6fe}.cfo-badge-completed{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.cfo-badge-no-answer,.cfo-badge-refused{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.cfo-badge-wrong{background:#f3f4f6;color:#6b7280;border-color:#e5e7eb}.cfo-badge-rescheduled{background:#fef9c3;color:#854d0e;border-color:#fde047}.cfo-badge-voicemail{background:#f0fdf4;color:#166534;border-color:#dcfce7}.cfo-badge-generated{background:#e0f2fe;color:#0369a1;border-color:#bae6fd}.cfo-badge-cancelled{background:#f3f4f6;color:#6b7280;border-color:#e5e7eb}.cfo-badge-default{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}.cfo-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:24px}.cfo-stat{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:16px;transition:transform .2s,box-shadow .2s}.cfo-stat:hover{transform:translateY(-2px);box-shadow:0 8px 16px #00000014}.cfo-stat.primary{border-left:4px solid var(--primary, #2563eb)}.cfo-stat.success{border-left:4px solid var(--success, #16a34a)}.cfo-stat.warn{border-left:4px solid var(--warning, #d97706)}.cfo-stat.draft{border-left:4px solid #94a3b8}.cfo-stat.danger{border-left:4px solid var(--danger, #dc2626)}.cfo-stat-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--tx3, #64748b);margin-bottom:6px}.cfo-stat-val{font-size:26px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.1}.cfo-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.cfo-search-box{display:flex;align-items:center;gap:8px;background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;padding:0 13px;flex:1;min-width:200px;transition:border-color .2s,box-shadow .2s}.cfo-search-box:focus-within{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cfo-search-box svg{color:var(--tx3, #94a3b8)}.cfo-search{flex:1;border:none;background:transparent;padding:10px 0;font-size:13.5px;color:var(--tx1, #0f172a);outline:none;font-family:inherit}.cfo-search::placeholder{color:var(--tx3, #94a3b8)}.cfo-filter-btns{display:flex;gap:4px;flex-wrap:wrap}.cfo-filter-btn{padding:7px 13px;border-radius:7px;font-size:12.5px;font-weight:500;background:transparent;border:1.5px solid var(--border, #e2e8f0);color:var(--tx2, #475569);cursor:pointer;transition:all .17s;font-family:inherit}.cfo-filter-btn:hover{background:var(--bg-hover, #f1f5f9)}.cfo-filter-btn.active{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-color:var(--primary-border, #bfdbfe)}.cfo-info-banner{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--warning-light, #fef3c7);border:1px solid var(--warning-border, #fde68a);border-radius:9px;font-size:13px;color:#92400e;margin-bottom:16px}.cfo-survey-list{display:flex;flex-direction:column;gap:16px}.cfo-survey-card{background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:16px;padding:20px 22px;transition:border-color .2s,box-shadow .2s;box-shadow:0 2px 6px #0000000a}.cfo-survey-card:hover{border-color:var(--primary-border, #bfdbfe);box-shadow:0 6px 18px #2563eb1a}.cfo-survey-card.selected{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cfo-sv-hdr{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;flex-wrap:wrap}.cfo-sv-hdr>div:first-child{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.cfo-sv-code{font-family:SF Mono,monospace;font-size:12px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:3px 8px;border-radius:5px;border:1px solid var(--primary-border, #bfdbfe)}.cfo-sv-actions{display:flex;gap:6px}.cfo-sv-title{font-size:17px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:4px}.cfo-sv-desc{font-size:13px;color:var(--tx3, #64748b);margin-bottom:10px;line-height:1.5}.cfo-sv-meta{display:flex;gap:16px;flex-wrap:wrap}.cfo-sv-meta span{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--tx3, #64748b)}.cfo-sv-expand-btn{display:flex;align-items:center;gap:6px;margin-top:14px;padding:7px 0;background:none;border:none;color:var(--primary, #2563eb);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:opacity .15s}.cfo-sv-expand-btn:hover{opacity:.75}.cfo-sv-questions{margin-top:16px;border-top:1px solid var(--border, #e2e8f0);padding-top:14px}.cfo-sv-q-hdr{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;font-weight:600;color:var(--tx2, #475569);margin-bottom:12px}.cfo-sv-q-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--border, #e2e8f0)}.cfo-sv-q-row:last-child{border-bottom:none}.cfo-sv-q-num{width:24px;height:24px;border-radius:50%;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cfo-sv-q-body{flex:1}.cfo-sv-q-text{font-size:13.5px;color:var(--tx1, #0f172a);margin-bottom:5px;line-height:1.5}.cfo-sv-q-tags{display:flex;gap:6px;flex-wrap:wrap}.cfo-sv-q-acts{display:flex;gap:5px}.cfo-type-tag{font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:4px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border:1px solid var(--primary-border, #bfdbfe)}.cfo-area-tag{font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:4px;background:#fef3c7;color:#b45309;border:1px solid #fde68a}.cfo-req-tag{font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;background:#fee2e2;color:var(--danger, #dc2626);border:1px solid #fecaca}.cfo-act-btn{width:32px;height:32px;border-radius:7px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .18s}.cfo-act-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.cfo-act-btn.success:hover:not(:disabled){color:var(--success, #16a34a);border-color:var(--success, #16a34a);background:#dcfce7}.cfo-act-btn.warn:hover:not(:disabled){color:var(--warning, #d97706);border-color:var(--warning, #d97706);background:#fef3c7}.cfo-act-btn.delete:hover:not(:disabled){color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);background:#fee2e2}.cfo-act-btn:disabled{opacity:.45;cursor:not-allowed}.cfo-batch-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:12px}.cfo-batch-survey-name{font-size:17px;font-weight:600;color:var(--tx1, #0f172a);margin-right:10px}.cfo-batch-list{display:flex;flex-direction:column;gap:14px}.cfo-batch-card{background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:14px;padding:18px 20px;cursor:pointer;transition:border-color .2s,box-shadow .2s}.cfo-batch-card:hover{border-color:var(--primary-border, #bfdbfe);box-shadow:0 4px 14px #2563eb1a}.cfo-batch-card.selected{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cfo-bc-hdr{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}.cfo-bc-code{font-family:SF Mono,monospace;font-size:12px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:3px 8px;border-radius:5px}.cfo-bc-dates{font-size:12.5px;color:var(--tx3, #64748b);display:flex;align-items:center;gap:6px;margin-bottom:10px}.cfo-bc-counters{display:flex;gap:14px;flex-wrap:wrap;font-size:12.5px;font-weight:600;margin-bottom:10px}.cfo-bc-counters .total{color:var(--tx2, #475569)}.cfo-bc-counters .done{color:var(--success, #16a34a)}.cfo-bc-counters .miss{color:var(--danger, #dc2626)}.cfo-bc-counters .pend{color:var(--warning, #d97706)}.cfo-bc-progress{height:6px;background:var(--bg, #f1f5f9);border-radius:6px;overflow:hidden;margin-bottom:8px}.cfo-bc-prog-bar{height:100%;background:var(--success, #16a34a);border-radius:6px;transition:width .5s ease}.cfo-bc-by{font-size:11px;color:var(--tx3, #64748b)}.cfo-call-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px}.cfo-call-batch-name{font-size:16px;font-weight:600;color:var(--tx1, #0f172a);margin-right:10px}.cfo-call-batch-meta{font-size:12px;color:var(--tx3, #64748b)}.cfo-calls-table-wrap{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;overflow:hidden}.cfo-calls-table{width:100%;border-collapse:separate;border-spacing:0}.cfo-calls-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3, #64748b);padding:13px 16px;text-align:left;background:var(--bg, #f8fafc);border-bottom:2px solid var(--border, #e2e8f0)}.cfo-calls-table td{padding:13px 16px;font-size:13.5px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #fff)}.cfo-calls-table tr:last-child td{border-bottom:none}.cfo-calls-table tr:hover td{background:var(--bg, #f8fafc)}.cfo-calls-table tr.cfo-row-done td{opacity:.6;background:#f8fafc}.cfo-visitor-cell .cfo-vis-name{display:block;font-weight:500;color:var(--tx1, #0f172a)}.cfo-visitor-cell .cfo-vis-org{display:block;font-size:11.5px;color:var(--tx3, #94a3b8)}.cfo-phone-cell{font-family:SF Mono,monospace;font-size:12.5px}.cfo-unassigned{color:var(--tx3, #94a3b8);font-style:italic;font-size:12px}.cfo-call-actions{display:flex;gap:6px}.cfo-field{display:flex;flex-direction:column;gap:5px;margin-bottom:18px}.cfo-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.cfo-field.sm{grid-column:span 1;max-width:120px}.cfo-label{font-size:12.5px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:7px}.cfo-req{color:var(--danger, #dc2626);font-size:14px}.cfo-err{font-size:11px;color:var(--danger, #dc2626)}.cfo-hint{font-size:11px;color:var(--tx3, #64748b)}.cfo-input{padding:10px 13px;background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13.5px;outline:none;width:100%;transition:border-color .2s,box-shadow .2s;font-family:inherit}.cfo-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cfo-input.has-error{border-color:var(--danger, #dc2626);background:#fff5f5}.cfo-textarea{padding:10px 13px;background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13.5px;outline:none;width:100%;resize:vertical;transition:border-color .2s,box-shadow .2s;font-family:inherit;line-height:1.6}.cfo-textarea:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cfo-textarea.has-error{border-color:var(--danger, #dc2626);background:#fff5f5}.cfo-select{padding:10px 13px;background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13.5px;outline:none;width:100%;cursor:pointer;transition:border-color .2s;font-family:inherit}.cfo-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cfo-select.has-error{border-color:var(--danger, #dc2626);background:#fff5f5}.cfo-check-wrap{display:flex;align-items:center;gap:10px;padding:10px 13px;background:var(--bg, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;cursor:pointer;transition:border-color .2s}.cfo-check-wrap:hover{border-color:var(--primary, #2563eb)}.cfo-check-wrap input[type=checkbox]{accent-color:var(--primary, #2563eb);width:15px;height:15px}.cfo-check-wrap span{font-size:13px;color:var(--tx2, #475569)}.cfo-overlay{position:fixed;inset:0;background:#00000075;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:cfo-fade .2s ease}@keyframes cfo-fade{0%{opacity:0}to{opacity:1}}.cfo-modal{background:var(--bg-card, #fff);border-radius:20px;border:1px solid var(--border, #e2e8f0);box-shadow:0 28px 56px -16px #00000042;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;animation:cfo-pop .28s cubic-bezier(.34,1.56,.64,1)}.cfo-modal.sm{max-width:400px}.cfo-modal.lg{max-width:640px}.cfo-modal.xl{max-width:780px;max-height:95vh}@keyframes cfo-pop{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.cfo-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:22px 26px 10px;gap:12px;flex-wrap:wrap}.cfo-modal-title{font-size:16px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.cfo-modal-x{width:30px;height:30px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cfo-modal-x:hover{background:#fee2e2;color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.cfo-modal-x:disabled{opacity:.45;cursor:not-allowed}.cfo-modal-body{padding:16px 26px}.cfo-modal-ftr{padding:16px 26px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:10px}.cfo-confirm-msg{font-size:14px;color:var(--tx2, #475569);line-height:1.6}.cfo-batch-info{font-size:13px;color:var(--tx2, #475569);background:var(--info-light, #e0f2fe);border:1px solid var(--info-border, #bae6fd);border-radius:9px;padding:12px 14px;margin-bottom:18px;line-height:1.6}.cfo-call-phone{font-size:13px;color:var(--tx3, #64748b);margin-left:10px;font-family:SF Mono,monospace}.cfo-call-hdr-actions{display:flex;gap:8px;flex-wrap:wrap}.cfo-conductor-body{padding:0 26px 16px;max-height:65vh;overflow-y:auto}.cfo-visitor-strip{display:flex;gap:20px;flex-wrap:wrap;padding:12px 16px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:10px;margin-bottom:20px}.cfo-visitor-strip>div{display:flex;flex-direction:column;gap:2px}.cfo-vstrip-lbl{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--tx3, #64748b)}.cfo-visitor-strip>div>span:last-child{font-size:13px;color:var(--tx1, #0f172a);font-weight:500}.cfo-questions-list{display:flex;flex-direction:column;gap:18px}.cfo-q-card{background:var(--bg-card, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:12px;padding:16px 18px}.cfo-q-hdr{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.cfo-q-num{width:26px;height:26px;border-radius:50%;background:var(--primary, #2563eb);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cfo-q-text{font-size:14.5px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:6px;line-height:1.5}.cfo-q-hint{font-size:11.5px;color:var(--warning, #d97706);background:#fef3c7;border-radius:6px;padding:6px 10px;margin-bottom:10px}.cfo-q-answer{margin-top:10px}.cfo-rating-row{display:flex;gap:8px;flex-wrap:wrap}.cfo-rating-btn{display:flex;align-items:center;gap:5px;padding:8px 14px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;transition:all .18s;font-family:inherit}.cfo-rating-btn:hover{border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.cfo-rating-btn.selected{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.cfo-nps-row{display:flex;flex-direction:column;gap:8px}.cfo-nps-row>div:first-of-type{display:flex;gap:6px;flex-wrap:wrap}.cfo-nps-btn{min-width:42px;height:42px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:14px;font-weight:600;cursor:pointer;transition:all .18s;font-family:inherit}.cfo-nps-btn:hover{border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.cfo-nps-btn.selected{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.cfo-nps-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--tx3, #64748b)}.cfo-yn-row{display:flex;gap:12px}.cfo-yn-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:12px;border-radius:10px;border:2px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit;color:var(--tx2, #475569)}.cfo-yn-btn.yes:hover,.cfo-yn-btn.yes.selected{background:#dcfce7;border-color:#16a34a;color:#166534}.cfo-yn-btn.no:hover,.cfo-yn-btn.no.selected{background:#fee2e2;border-color:#dc2626;color:#991b1b}.cfo-choices{display:flex;flex-direction:column;gap:8px}.cfo-choice-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);cursor:pointer;font-size:13.5px;color:var(--tx2, #475569);transition:all .18s}.cfo-choice-item:hover{border-color:var(--primary-border, #bfdbfe);background:var(--primary-light, #dbeafe)}.cfo-choice-item.selected{border-color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);font-weight:600}.cfo-choice-item input[type=radio]{accent-color:var(--primary, #2563eb)}.cfo-no-answer-panel{padding:16px;background:#fff5f5;border:1.5px solid #fecaca;border-radius:12px}.cfo-results-hdr{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.cfo-results-survey-name{font-size:18px;font-weight:600;color:var(--tx1, #0f172a)}.cfo-results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:24px}.cfo-result-stat{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:16px}.cfo-result-stat.primary{border-left:4px solid var(--primary, #2563eb)}.cfo-result-stat.success{border-left:4px solid var(--success, #16a34a)}.cfo-result-stat.warn{border-left:4px solid var(--warning, #d97706)}.cfo-result-stat.danger{border-left:4px solid var(--danger, #dc2626)}.cfo-rs-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--tx3, #64748b);margin-bottom:6px}.cfo-rs-value{font-size:26px;font-weight:700;color:var(--tx1, #0f172a)}.cfo-section-title{font-size:14px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:7px;margin-bottom:14px;margin-top:6px}.cfo-touch-area-scores{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:20px;margin-bottom:24px}.cfo-ta-row{display:flex;align-items:center;gap:14px;margin-bottom:12px}.cfo-ta-label{font-size:13px;font-weight:500;color:var(--tx2, #475569);min-width:160px}.cfo-ta-bar-wrap{flex:1;height:10px;background:var(--bg, #f1f5f9);border-radius:10px;overflow:hidden}.cfo-ta-bar{height:100%;background:linear-gradient(90deg,var(--primary, #2563eb),#7c3aed);border-radius:10px;transition:width .6s ease}.cfo-ta-score{font-size:13px;font-weight:700;color:var(--tx1, #0f172a);min-width:50px;text-align:right}.cfo-ta-n{font-size:11px;color:var(--tx3, #94a3b8);font-weight:400}.cfo-q-results{display:flex;flex-direction:column;gap:14px}.cfo-q-result-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:18px}.cfo-qr-hdr{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;flex-wrap:wrap}.cfo-qr-num{width:26px;height:26px;background:var(--primary, #2563eb);color:#fff;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cfo-qr-text{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.cfo-qr-n{font-size:11.5px;color:var(--tx3, #94a3b8);white-space:nowrap}.cfo-qr-avg{font-size:14px;color:var(--tx2, #475569)}.cfo-qr-avg strong{font-size:20px;color:var(--primary, #2563eb)}.cfo-nps-breakdown{display:flex;gap:18px;flex-wrap:wrap}.cfo-nps-breakdown span{font-size:13px;font-weight:600;padding:5px 12px;border-radius:8px}.cfo-nps-breakdown .promoter{background:#dcfce7;color:#15803d}.cfo-nps-breakdown .passive{background:#fef3c7;color:#b45309}.cfo-nps-breakdown .detractor{background:#fee2e2;color:#b91c1c}.cfo-yn-result{display:flex;gap:16px}.cfo-yn-result .yes{font-size:14px;font-weight:600;color:#15803d}.cfo-yn-result .no{font-size:14px;font-weight:600;color:#b91c1c}.cfo-choice-results{display:flex;flex-direction:column;gap:6px}.cfo-cr-row{display:flex;justify-content:space-between;font-size:13px;padding:7px 10px;background:var(--bg, #f8fafc);border-radius:7px}.cfo-cr-count{font-weight:700;color:var(--primary, #2563eb)}.cfo-text-answers{display:flex;flex-direction:column;gap:8px}.cfo-text-ans{font-size:13px;color:var(--tx2, #475569);font-style:italic;padding:8px 12px;background:var(--bg, #f8fafc);border-left:3px solid var(--primary-border, #bfdbfe);border-radius:0 8px 8px 0;line-height:1.6}.cfo-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:60px;color:var(--tx3, #94a3b8)}.cfo-spin{animation:cfo-rotate .7s linear infinite}.cfo-spin-slow{animation:cfo-rotate 1s linear infinite}@keyframes cfo-rotate{to{transform:rotate(360deg)}}.cfo-empty{text-align:center;padding:56px 20px;border:2px dashed var(--border, #e2e8f0);border-radius:16px}.cfo-empty svg{color:var(--tx3, #94a3b8);margin-bottom:14px}.cfo-empty p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:16px}.cfo-error{display:flex;align-items:center;gap:8px;padding:16px;background:#fee2e2;border-radius:10px;font-size:13.5px;color:#b91c1c}@media(max-width:768px){.cfo-field-row{grid-template-columns:1fr}.cfo-calls-table th:nth-child(3),.cfo-calls-table td:nth-child(3){display:none}.cfo-tabs{overflow-x:auto}.cfo-modal.xl{max-width:100%;margin:0;border-radius:20px 20px 0 0;max-height:96vh;align-self:flex-end}}@media(max-width:480px){.cfo-stats-grid{grid-template-columns:1fr 1fr}.cfo-yn-row{flex-direction:column}}.cfr-toast-wrap{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.cfr-toast{display:flex;align-items:center;gap:12px;padding:13px 18px;background:var(--bg-card, #fff);border-radius:10px;box-shadow:0 8px 20px #00000021;min-width:300px;max-width:400px;border-left:4px solid var(--primary, #2563eb);animation:cfr-slide-in .28s ease}.cfr-toast-success{border-left-color:var(--success, #16a34a)}.cfr-toast-error{border-left-color:var(--danger, #dc2626)}.cfr-toast-warning{border-left-color:var(--warning, #d97706)}.cfr-toast-icon{display:flex;flex-shrink:0}.cfr-toast-success .cfr-toast-icon{color:var(--success, #16a34a)}.cfr-toast-error .cfr-toast-icon{color:var(--danger, #dc2626)}.cfr-toast-warning .cfr-toast-icon{color:var(--warning, #d97706)}.cfr-toast-info .cfr-toast-icon{color:var(--primary, #2563eb)}.cfr-toast-msg{flex:1;font-size:13.5px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.cfr-toast-x{background:none;border:none;color:var(--tx3, #94a3b8);font-size:19px;cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s,color .15s}.cfr-toast-x:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes cfr-slide-in{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.cfr-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.cfr-page-title{font-size:23px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:10px}.cfr-page-title svg{color:var(--primary, #2563eb)}.cfr-page-sub{font-size:13px;color:var(--tx3, #64748b);margin-top:4px}.cfr-page-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.cfr-tabs{display:flex;gap:4px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:4px;margin-bottom:24px;flex-wrap:wrap}.cfr-tab{display:flex;align-items:center;gap:7px;padding:9px 16px;border:none;cursor:pointer;border-radius:9px;font-size:13px;font-weight:600;color:var(--tx2, #475569);background:transparent;transition:all .2s;font-family:inherit}.cfr-tab:hover{background:var(--bg-card, #fff);color:var(--tx1, #0f172a)}.cfr-tab.active{background:var(--bg-card, #fff);color:var(--primary, #2563eb);box-shadow:0 2px 6px #00000012}.cfr-tab svg{flex-shrink:0}.cfr-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}.cfr-stat{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:18px 16px;display:flex;align-items:center;gap:12px;transition:transform .25s,box-shadow .25s;box-shadow:0 2px 6px #0000000a}.cfr-stat:hover{transform:translateY(-3px);box-shadow:0 10px 22px -6px #0000001c}.cfr-stat-primary{border-left:4px solid var(--primary, #2563eb)}.cfr-stat-success{border-left:4px solid var(--success, #16a34a)}.cfr-stat-warn{border-left:4px solid var(--warning, #d97706)}.cfr-stat-terminal{border-left:4px solid #7c3aed}.cfr-stat-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cfr-stat-primary .cfr-stat-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.cfr-stat-success .cfr-stat-icon{background:#dcfce7;color:#16a34a}.cfr-stat-warn .cfr-stat-icon{background:#fef3c7;color:#d97706}.cfr-stat-terminal .cfr-stat-icon{background:#ede9fe;color:#7c3aed}.cfr-stat-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--tx3, #64748b);margin-bottom:4px}.cfr-stat-val{font-size:26px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.1}.cfr-table-wrap{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:16px;box-shadow:0 3px 10px #0000000a;overflow:hidden}.cfr-toolbar{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border, #e2e8f0);flex-wrap:wrap}.cfr-search-box{display:flex;align-items:center;gap:8px;background:var(--bg, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;padding:0 13px;flex:1;min-width:200px;transition:border-color .2s,box-shadow .2s}.cfr-search-box:focus-within{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cfr-search-box svg{color:var(--tx3, #94a3b8);flex-shrink:0}.cfr-search{flex:1;border:none;background:transparent;padding:10px 0;font-size:13.5px;color:var(--tx1, #0f172a);outline:none;font-family:inherit}.cfr-search::placeholder{color:var(--tx3, #94a3b8)}.cfr-filter-btns{display:flex;gap:4px}.cfr-filter-btn{padding:7px 13px;border-radius:7px;font-size:12.5px;font-weight:500;background:transparent;border:1.5px solid var(--border, #e2e8f0);color:var(--tx2, #475569);cursor:pointer;transition:all .17s;font-family:inherit}.cfr-filter-btn:hover{background:var(--bg-hover, #f1f5f9)}.cfr-filter-btn.active{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-color:var(--primary-border, #bfdbfe)}.cfr-count{font-size:12px;color:var(--tx3, #64748b);white-space:nowrap;margin-left:auto}.cfr-table{width:100%;border-collapse:separate;border-spacing:0}.cfr-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3, #64748b);padding:14px 16px;text-align:left;background:var(--bg, #f8fafc);border-bottom:2px solid var(--border, #e2e8f0);-webkit-user-select:none;user-select:none;white-space:nowrap}.cfr-table td{padding:13px 16px;font-size:13.5px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #fff);transition:background .15s}.cfr-table tr:last-child td{border-bottom:none}.cfr-table tr:hover td{background:var(--bg, #f8fafc)}.cfr-table tr.cfr-dragging td{background:var(--primary-light, #dbeafe);opacity:.5}.cfr-table tr.cfr-row-inactive td{opacity:.55}.cfr-label-cell{font-weight:500;color:var(--tx1, #0f172a)}.cfr-drag-handle{color:var(--tx3, #94a3b8);cursor:grab;width:32px}.cfr-sort-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3, #64748b);font-family:inherit;transition:color .15s}.cfr-sort-btn:hover,.cfr-sort-btn.active{color:var(--primary, #2563eb)}.cfr-sort-btn.active.asc svg{transform:rotate(180deg)}.cfr-code{font-family:SF Mono,Fira Code,monospace;font-size:11.5px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:3px 8px;border-radius:5px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block;white-space:nowrap}.cfr-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid transparent}.cfr-pill.active{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.cfr-pill.inactive{background:#f1f5f9;color:#475569;border-color:#e2e8f0}.cfr-term{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid transparent}.cfr-term.terminal{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.cfr-term.open{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}.cfr-actions{display:flex;gap:6px;justify-content:flex-end}.cfr-act-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .18s}.cfr-act-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-1px);box-shadow:0 3px 8px #2563eb2e}.cfr-act-btn.edit:hover:not(:disabled){color:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.cfr-act-btn.toggle:hover:not(:disabled){color:var(--success, #16a34a);border-color:var(--success, #16a34a);background:#dcfce7}.cfr-act-btn.delete:hover:not(:disabled){color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);background:#fee2e2;box-shadow:0 3px 8px #dc26262e}.cfr-act-btn:disabled{opacity:.45;cursor:not-allowed}.cfr-pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-top:1px solid var(--border, #e2e8f0);flex-wrap:wrap;gap:10px}.cfr-pag-info{font-size:12.5px;color:var(--tx3, #64748b)}.cfr-pag-btn{width:34px;height:34px;border-radius:7px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.cfr-pag-btn:hover:not(:disabled){background:var(--bg, #f8fafc);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.cfr-pag-btn:disabled{opacity:.38;cursor:not-allowed}.cfr-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:60px 20px;color:var(--tx3, #94a3b8);font-size:14px;font-weight:500}.cfr-spin{animation:cfr-rotate .7s linear infinite}.cfr-spin-slow{animation:cfr-rotate 1s linear infinite}@keyframes cfr-rotate{to{transform:rotate(360deg)}}.cfr-empty{text-align:center;padding:56px 20px;background:var(--bg-card, #fff);border-radius:16px;border:2px dashed var(--border, #e2e8f0)}.cfr-empty svg{color:var(--tx3, #94a3b8);margin-bottom:14px}.cfr-empty p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:16px}.cfr-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:9px;border:none;cursor:pointer;transition:all .18s;white-space:nowrap;line-height:1;font-family:inherit}.cfr-btn.sm{font-size:12px;padding:8px 14px}.cfr-btn.xs{font-size:11px;padding:5px 10px;border-radius:6px}.cfr-btn.primary{background:var(--primary, #2563eb);color:#fff}.cfr-btn.primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb47}.cfr-btn.ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.cfr-btn.ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--tx2, #475569)}.cfr-btn.danger{background:var(--danger, #dc2626);color:#fff}.cfr-btn.danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc262647}.cfr-btn:disabled{opacity:.48;cursor:not-allowed}.cfr-overlay{position:fixed;inset:0;background:#00000075;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:cfr-fade .2s ease}@keyframes cfr-fade{0%{opacity:0}to{opacity:1}}.cfr-modal{background:var(--bg-card, #fff);border-radius:20px;border:1px solid var(--border, #e2e8f0);box-shadow:0 28px 56px -16px #00000042;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;animation:cfr-pop .28s cubic-bezier(.34,1.56,.64,1)}.cfr-modal.sm{max-width:400px}@keyframes cfr-pop{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.cfr-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:22px 26px 10px}.cfr-modal-title{font-size:17px;font-weight:700;color:var(--tx1, #0f172a)}.cfr-modal-x{width:30px;height:30px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cfr-modal-x:hover:not(:disabled){background:#fee2e2;color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.cfr-modal-x:disabled{opacity:.45;cursor:not-allowed}.cfr-modal-body{padding:16px 26px}.cfr-modal-ftr{padding:16px 26px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:10px}.cfr-confirm-msg{font-size:14px;color:var(--tx2, #475569);line-height:1.6}.cfr-field{display:flex;flex-direction:column;gap:5px;margin-bottom:18px}.cfr-label{font-size:12.5px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:7px}.cfr-req{color:var(--danger, #dc2626);font-size:14px}.cfr-auto{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:10px;border:1px solid #bfdbfe}.cfr-hint{font-size:11px;color:var(--tx3, #64748b);line-height:1.5}.cfr-err{font-size:11px;color:var(--danger, #dc2626)}.cfr-input{padding:10px 13px;background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13.5px;outline:none;width:100%;transition:border-color .2s,box-shadow .2s;font-family:inherit}.cfr-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cfr-input.has-error{border-color:var(--danger, #dc2626);background:#fff5f5}.cfr-input:disabled{opacity:.55;cursor:not-allowed}.cfr-textarea{padding:10px 13px;background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;color:var(--tx1, #0f172a);font-size:13.5px;outline:none;width:100%;resize:vertical;transition:border-color .2s,box-shadow .2s;font-family:inherit;line-height:1.6}.cfr-textarea:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.cfr-textarea.has-error{border-color:var(--danger, #dc2626);background:#fff5f5}.cfr-check-wrap{display:flex;align-items:center;gap:10px;padding:10px 13px;background:var(--bg, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:9px;cursor:pointer;transition:border-color .2s}.cfr-check-wrap:hover{border-color:var(--primary, #2563eb)}.cfr-check-wrap input[type=checkbox]{accent-color:var(--primary, #2563eb);width:16px;height:16px}.cfr-check-wrap span{font-size:13px;color:var(--tx2, #475569)}@media(max-width:768px){.cfr-stats-grid{grid-template-columns:repeat(2,1fr)}.cfr-tabs{overflow-x:auto}.cfr-table th:nth-child(4),.cfr-table td:nth-child(4){display:none}}@media(max-width:480px){.cfr-stats-grid{grid-template-columns:1fr 1fr}.cfr-page-hdr{flex-direction:column}}.visitor-card-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}.visitor-card-toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card, #fff);border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:320px;max-width:400px;animation:visitor-card-toast-in .3s ease;border-left:4px solid var(--primary, #2563eb)}.visitor-card-toast-success{border-left-color:var(--success, #16a34a)}.visitor-card-toast-error{border-left-color:var(--danger, #dc2626)}.visitor-card-toast-warning{border-left-color:var(--warning, #d97706)}.visitor-card-toast-info{border-left-color:var(--primary, #2563eb)}.visitor-card-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.visitor-card-toast-success .visitor-card-toast-icon{color:var(--success, #16a34a)}.visitor-card-toast-error .visitor-card-toast-icon{color:var(--danger, #dc2626)}.visitor-card-toast-warning .visitor-card-toast-icon{color:var(--warning, #d97706)}.visitor-card-toast-info .visitor-card-toast-icon{color:var(--primary, #2563eb)}.visitor-card-toast-message{flex:1;font-size:14px;font-weight:500;color:var(--tx1, #0f172a);line-height:1.5}.visitor-card-toast-close{background:none;border:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:20px;padding:0;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s}.visitor-card-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes visitor-card-toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.visitor-card-page{max-width:1400px;margin:0 auto;padding:24px 20px;font-family:system-ui,-apple-system,sans-serif}.visitor-card-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.visitor-card-page-title{font-size:24px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:12px}.visitor-card-page-subtitle{font-size:14px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.visitor-card-page-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.visitor-card-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}.visitor-card-stats-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.visitor-card-stats-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001f}.visitor-card-stats-primary{border-left:4px solid var(--primary, #2563eb)}.visitor-card-stats-success{border-left:4px solid var(--success, #16a34a)}.visitor-card-stats-warning{border-left:4px solid var(--warning, #d97706)}.visitor-card-stats-secondary{border-left:4px solid var(--tx3, #64748b)}.visitor-card-stats-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center}.visitor-card-stats-primary .visitor-card-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.visitor-card-stats-success .visitor-card-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.visitor-card-stats-warning .visitor-card-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.visitor-card-stats-secondary .visitor-card-stats-icon{background:var(--bg, #f1f5f9);color:var(--tx3, #64748b)}.visitor-card-stats-content{flex:1}.visitor-card-stats-title{font-size:13px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.visitor-card-stats-value{font-size:30px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.visitor-card-filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:var(--bg-card, #fff);padding:16px 20px;border-radius:12px;border:1px solid var(--border, #e2e8f0);box-shadow:0 2px 6px #00000005}.visitor-card-search-wrapper{position:relative;flex:1;min-width:280px}.visitor-card-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.visitor-card-search-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s}.visitor-card-search-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.visitor-card-search-input::placeholder{color:var(--tx3, #94a3b8)}.visitor-card-filter-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.visitor-card-filter-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s}.visitor-card-filter-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.visitor-card-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a;transition:all .2s}.visitor-card-card:hover{box-shadow:0 8px 24px #00000014}.visitor-card-table-responsive{overflow-x:auto;border-radius:12px;margin-bottom:16px}.visitor-card-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.visitor-card-lookup-table th{font-size:12px;font-weight:600;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.5px;padding:16px;text-align:left;background:var(--bg, #f8fafc);white-space:nowrap;border-bottom:2px solid var(--border, #e2e8f0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.visitor-card-lookup-table th:hover{background:var(--bg-hover, #e2e8f0);color:var(--tx1, #0f172a)}.visitor-card-lookup-table td{padding:16px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #fff);transition:background-color .2s}.visitor-card-lookup-table tr:hover td{background:var(--bg-hover, #f1f5f9)}.visitor-card-lookup-table .visitor-card-row-inuse td{background:#fff9f9}.visitor-card-lookup-table .visitor-card-row-inuse:hover td{background:#fff5f5}.visitor-card-sort-icon{margin-left:8px;color:var(--tx3, #94a3b8);font-size:14px;display:inline-block;transition:transform .2s}.visitor-card-sort-icon.asc{transform:rotate(0)}.visitor-card-sort-icon.desc{transform:rotate(180deg)}.visitor-card-number-cell{font-family:SF Mono,Fira Code,monospace;font-weight:700;font-size:14px}.visitor-card-number-cell:not(.empty){color:var(--primary, #2563eb)}.visitor-card-row-inuse .visitor-card-number-cell{color:var(--danger, #dc2626)}.visitor-card-label-cell{font-weight:500;color:var(--tx1, #0f172a)}.visitor-card-label-cell .empty{color:var(--tx3, #94a3b8);font-style:italic}.visitor-card-notes-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.visitor-card-notes-cell .empty{color:var(--tx3, #94a3b8);font-style:italic}.visitor-card-status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;width:fit-content}.visitor-card-status-badge .status-dot{width:6px;height:6px;border-radius:50%;display:inline-block}.visitor-card-status-badge.available{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.visitor-card-status-badge.available .status-dot{background:var(--success, #16a34a)}.visitor-card-status-badge.in-use{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626)}.visitor-card-status-badge.in-use .status-dot{background:var(--danger, #dc2626)}.visitor-card-status-badge.inactive{background:var(--bg, #f1f5f9);color:var(--tx3, #64748b)}.visitor-card-holder-info{display:flex;flex-direction:column;gap:2px}.visitor-card-holder-info .holder-name{font-size:13px;font-weight:600;color:var(--tx1, #0f172a)}.visitor-card-holder-info .holder-pass{font-size:11px;color:var(--tx3, #64748b)}.visitor-card-sort-order{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:6px;font-weight:600;color:var(--tx2, #475569);padding:0 8px}.visitor-card-action-buttons{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.visitor-card-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.visitor-card-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 8px #2563eb33}.visitor-card-action-btn.visitor-card-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.visitor-card-action-btn.visitor-card-locked{background:var(--bg, #f8fafc);color:var(--tx3, #94a3b8);cursor:not-allowed}.visitor-card-action-btn:disabled{opacity:.5;cursor:not-allowed}.visitor-card-status-toggle{display:flex;align-items:center;gap:12px}.visitor-card-status-label{font-size:13px;font-weight:500}.visitor-card-status-label.visitor-card-active{color:var(--success, #16a34a)}.visitor-card-status-label.visitor-card-inactive{color:var(--danger, #dc2626)}.visitor-card-inuse-hint{font-size:10px;color:var(--danger, #dc2626);margin-left:8px}.visitor-card-modern-switch{position:relative;display:inline-block;cursor:pointer}.visitor-card-modern-switch.visitor-card-small input+.visitor-card-switch-slider{width:40px;height:22px}.visitor-card-modern-switch.visitor-card-small input+.visitor-card-switch-slider .visitor-card-switch-handle{width:18px;height:18px}.visitor-card-modern-switch input{opacity:0;width:0;height:0;position:absolute}.visitor-card-modern-switch .visitor-card-switch-slider{position:relative;display:block;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;transition:all .3s cubic-bezier(.4,0,.2,1)}.visitor-card-modern-switch input:checked+.visitor-card-switch-slider{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.visitor-card-modern-switch input:disabled+.visitor-card-switch-slider{opacity:.5;cursor:not-allowed}.visitor-card-modern-switch .visitor-card-switch-handle{position:absolute;top:2px;left:2px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.visitor-card-modern-switch input:checked+.visitor-card-switch-slider .visitor-card-switch-handle{transform:translate(18px)}.visitor-card-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:20px;flex-wrap:wrap;gap:16px}.visitor-card-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.visitor-card-pagination-buttons{display:flex;gap:6px}.visitor-card-pagination-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.visitor-card-pagination-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.visitor-card-pagination-btn.visitor-card-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.visitor-card-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.visitor-card-help-note{margin-top:20px;padding:14px 18px;border-radius:12px;background:var(--primary-light, #eff6ff);border:1px solid var(--primary-border, #bfdbfe);font-size:13px;color:var(--primary-dark, #1e40af);display:flex;align-items:flex-start;gap:12px}.visitor-card-help-note svg{flex-shrink:0;margin-top:2px}.visitor-card-help-note strong{font-weight:700}.visitor-card-empty-state{text-align:center;padding:60px 20px;background:var(--bg-card, #fff);border-radius:20px;border:2px dashed var(--border, #e2e8f0)}.visitor-card-empty-icon{color:var(--tx3, #94a3b8);margin-bottom:20px;width:64px;height:64px}.visitor-card-empty-state h3{font-size:18px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:8px}.visitor-card-empty-state p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:24px}.visitor-card-skeleton-table{background:var(--bg-card, #fff);border-radius:16px;padding:24px}.visitor-card-skeleton-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border, #e2e8f0)}.visitor-card-skeleton-cell{height:20px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:visitor-card-shimmer 1.5s infinite;border-radius:4px}@keyframes visitor-card-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.visitor-card-modal-bg{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:visitor-card-modal-fade .2s ease}@keyframes visitor-card-modal-fade{0%{opacity:0}to{opacity:1}}.visitor-card-modal{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:24px;box-shadow:0 30px 60px -20px #0000004d;width:100%;max-height:90vh;overflow-y:auto;animation:visitor-card-modal-scale .3s ease}@keyframes visitor-card-modal-scale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.visitor-card-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 8px}.visitor-card-modal-title{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:8px}.visitor-card-modal-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.visitor-card-modal-close-btn:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.visitor-card-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.visitor-card-modal-body{padding:20px 28px}.visitor-card-modal-foot{padding:20px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:12px}.visitor-card-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.visitor-card-form-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px}.visitor-card-required{color:var(--danger, #dc2626);margin-left:2px;font-size:14px}.visitor-card-auto-badge{font-size:10px;font-weight:500;padding:2px 6px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:12px;border:1px solid var(--primary-border, #bfdbfe);margin-left:8px}.visitor-card-form-hint{font-size:11px;color:var(--tx3, #64748b);margin-top:4px;line-height:1.5}.visitor-card-input,.visitor-card-input:is(select,textarea){background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:10px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit}.visitor-card-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.visitor-card-input.visitor-card-error{border-color:var(--danger, #dc2626);background:var(--danger-light, #fee2e2)}textarea.visitor-card-input{resize:vertical;min-height:80px}.visitor-card-error-message{color:var(--danger, #dc2626);font-size:11px;margin-top:4px;display:block}.visitor-card-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.visitor-card-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.visitor-card-bulk-hint{font-size:12px;color:var(--tx3, #64748b);margin-bottom:16px;line-height:1.5}.visitor-card-bulk-preview{margin-top:16px;padding:12px;background:var(--primary-light, #eff6ff);border-radius:8px;font-size:12px;color:var(--primary-dark, #1e40af);text-align:center}.visitor-card-bulk-preview strong{font-family:monospace;font-weight:700;color:var(--primary, #2563eb)}.visitor-card-confirm-icon{text-align:center;margin-bottom:16px}.visitor-card-confirm-message{font-size:14px;color:var(--tx2, #475569);text-align:center;line-height:1.6}.visitor-card-text-success{color:var(--success, #16a34a)}.visitor-card-text-danger{color:var(--danger, #dc2626)}.visitor-card-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;font-family:inherit}.visitor-card-btn-sm{font-size:12px;padding:8px 14px}.visitor-card-btn-primary{background:var(--primary, #2563eb);color:#fff}.visitor-card-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.visitor-card-btn-primary.visitor-card-btn-bulk{background:#7c3aed}.visitor-card-btn-primary.visitor-card-btn-bulk:hover:not(:disabled){background:#6d28d9}.visitor-card-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.visitor-card-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx2, #475569)}.visitor-card-btn-danger{background:var(--danger, #dc2626);color:#fff}.visitor-card-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.visitor-card-btn:disabled{opacity:.5;cursor:not-allowed}.visitor-card-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:visitor-card-spin .6s linear infinite;margin-right:6px}@keyframes visitor-card-spin{to{transform:rotate(360deg)}}.visitor-card-spin{animation:visitor-card-spin 1s linear infinite}@media(max-width:1024px){.visitor-card-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.visitor-card-page-hdr{flex-direction:column}.visitor-card-page-actions{width:100%;justify-content:flex-start}.visitor-card-filters-bar{flex-direction:column;align-items:stretch}.visitor-card-search-wrapper,.visitor-card-filter-group,.visitor-card-filter-select{width:100%}.visitor-card-stats-grid{grid-template-columns:1fr;gap:16px}.visitor-card-grid-2,.visitor-card-grid-4{grid-template-columns:1fr}.visitor-card-pagination{flex-direction:column;align-items:stretch}.visitor-card-pagination-buttons{justify-content:center}.visitor-card-modal-hdr,.visitor-card-modal-body,.visitor-card-modal-foot{padding:16px 20px}.visitor-card-action-buttons{flex-wrap:wrap}}@media print{.visitor-card-page-actions,.visitor-card-filters-bar,.visitor-card-action-buttons,.visitor-card-status-toggle,.visitor-card-toast-container,.visitor-card-modal-bg{display:none!important}.visitor-card-card{box-shadow:none;border:1px solid #000}}.visitor-card-lookup-table .visitor-card-row-warning td{background:#fffbeb}.visitor-card-lookup-table .visitor-card-row-warning:hover td{background:#fef3c7}.visitor-card-action-btn[title*="Assign QR"]:not(:disabled){animation:qr-pulse 2s ease-in-out infinite}@keyframes qr-pulse{0%,to{box-shadow:0 0 #d9770600}50%{box-shadow:0 0 0 4px #d9770633}}.view-card-info{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border, #e5e7eb)}.view-card-field{display:flex;align-items:flex-start;gap:12px}.view-card-field label{width:100px;font-size:12px;font-weight:600;color:var(--tx3, #6b7280);text-transform:uppercase;letter-spacing:.5px;padding-top:2px}.view-card-value{flex:1;font-size:14px;color:var(--tx1, #1f2937);word-break:break-word}.view-card-qr-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border, #e5e7eb)}.view-card-qr-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--tx2, #4b5563);margin-bottom:12px}.view-card-qr-content{display:flex;flex-direction:column;align-items:center;gap:12px}.view-card-qr-preview{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px;background:#fff;border-radius:12px;border:1px solid var(--border, #e5e7eb)}.view-card-qr-preview img{width:180px;height:180px;object-fit:contain}.view-card-qr-actions{display:flex;gap:8px}.view-card-qr-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.view-card-qr-badge.configured{background:var(--success-light, #f0fdf4);color:var(--success, #22c55e);border:1px solid var(--success-border, #bbf7d0)}.view-card-qr-badge.missing{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border:1px solid var(--warning-border, #fde68a)}.view-card-qr-empty{text-align:center;padding:20px;background:var(--bg, #f8fafc);border-radius:12px;color:var(--tx3, #6b7280)}.view-card-qr-empty svg{margin-bottom:8px;color:var(--warning, #d97706)}.view-card-qr-empty p{font-size:13px;margin:0}.view-card-usage{margin-top:16px;padding:12px;background:var(--primary-light, #eff6ff);border-radius:10px;border:1px solid var(--primary-border, #bfdbfe)}.view-card-usage-header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--primary, #3b82f6);margin-bottom:8px}.view-card-usage-details{padding-left:22px}.view-card-usage-details .usage-name{font-size:14px;font-weight:600;color:var(--tx1, #1f2937)}.view-card-usage-details .usage-pass{font-size:12px;color:var(--tx3, #6b7280)}.qr-scan-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:20px;padding:12px 16px;background:var(--primary-light, #eff6ff);border-radius:12px;border:1px solid var(--primary-border, #bfdbfe)}.qr-scan-card-info{display:flex;align-items:center;gap:12px}.qr-scan-card-info svg{color:var(--primary, #3b82f6)}.qr-scan-card-info strong{font-size:14px;color:var(--tx1, #1f2937);display:block}.qr-scan-card-info span{font-size:12px;color:var(--tx3, #6b7280)}.qr-scan-keep-option{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--success-light, #f0fdf4);border-radius:20px;font-size:12px;color:var(--success, #22c55e)}.qr-input-wrapper{width:100%}.qr-input-row{display:flex;gap:8px;align-items:center}.qr-input-row .visitor-card-input{flex:1}.qr-code-preview{margin-top:16px;padding:16px;background:var(--bg, #f8fafc);border-radius:12px;border:1px solid var(--border, #e5e7eb)}.qr-preview-header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--tx2, #4b5563);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border, #e5e7eb)}.qr-preview-content{display:flex;flex-direction:column;align-items:center;gap:12px}.qr-preview-content img{width:160px;height:160px;object-fit:contain;background:#fff;padding:12px;border-radius:12px;border:1px solid var(--border, #e5e7eb)}.qr-preview-value{font-family:monospace;font-size:12px;color:var(--tx3, #6b7280);word-break:break-all;text-align:center;max-width:100%;padding:8px;background:#fff;border-radius:8px;border:1px solid var(--border, #e5e7eb)}.qr-keep-warning{display:flex;align-items:center;gap:10px;margin-top:16px;padding:12px 16px;background:var(--success-light, #f0fdf4);border-radius:10px;font-size:13px;color:var(--success, #22c55e);border:1px solid var(--success-border, #bbf7d0)}.qr-replace-warning{display:flex;align-items:center;gap:10px;margin-top:16px;padding:12px 16px;background:var(--warning-light, #fef3c7);border-radius:10px;font-size:13px;color:var(--warning, #d97706);border:1px solid var(--warning-border, #fde68a)}.qr-assign-card-info{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:12px 16px;background:var(--primary-light, #eff6ff);border-radius:12px;border:1px solid var(--primary-border, #bfdbfe)}.qr-assign-card-info svg{color:var(--primary, #3b82f6)}.qr-assign-card-info strong{font-size:14px;color:var(--tx1, #1f2937);display:block}.qr-assign-card-info span{font-size:12px;color:var(--tx3, #6b7280)}.visitor-card-existing-qr-info{margin-top:16px;padding:12px 16px;background:var(--success-light, #f0fdf4);border-radius:10px;border:1px solid var(--success-border, #bbf7d0)}.existing-qr-header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--success, #22c55e);margin-bottom:8px}.existing-qr-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;background:#fff;margin-bottom:8px}.existing-qr-status.configured{color:var(--success, #22c55e)}.existing-qr-note{font-size:11px;color:var(--tx3, #6b7280)}.visitor-card-info-banner{padding:12px 16px;border-radius:10px;margin-bottom:16px;background:var(--warning-light, #fef3c7);border:1px solid var(--warning, #d97706);font-size:13px;color:var(--warning-dark, #92400e);display:flex;align-items:center;gap:10px}.visitor-card-qr-cell{display:flex;flex-direction:column;gap:4px}.visitor-card-action-btn.visitor-card-qr-assign{color:var(--warning, #d97706);border-color:var(--warning, #d97706)}.visitor-card-action-btn.visitor-card-qr-assign:hover:not(:disabled){background:var(--warning-light, #fef3c7);color:var(--warning-dark, #92400e);border-color:var(--warning, #d97706)}@media(max-width:768px){.view-card-field{flex-direction:column;gap:4px}.view-card-field label{width:auto}.qr-scan-header{flex-direction:column;align-items:flex-start}.qr-preview-content img{width:120px;height:120px}.qr-preview-value{font-size:10px}.view-card-qr-preview img{width:140px;height:140px}}.sec-lookup-page *,.sec-lookup-page *:before,.sec-lookup-page *:after{box-sizing:border-box;margin:0;padding:0}.sec-lookup-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap}.sec-lookup-page-title-row{display:flex;align-items:center;gap:14px}.sec-lookup-page-icon-wrap{width:48px;height:48px;border-radius:14px;background:var(--primary-light, #dbeafe);display:flex;align-items:center;justify-content:center;color:var(--primary, #2563eb);flex-shrink:0;box-shadow:0 4px 12px #2563eb26}.sec-lookup-page-title{font-size:22px;font-weight:700;color:var(--tx1, #0f172a);line-height:1.2}.sec-lookup-page-subtitle{font-size:13px;color:var(--tx3, #64748b);margin-top:3px;line-height:1.5}.sec-lookup-page-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.sec-lookup-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:28px}.sec-lookup-stats-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:18px;padding:22px 20px;display:flex;align-items:center;gap:16px;transition:transform .25s ease,box-shadow .25s ease;box-shadow:0 2px 10px #0000000a;cursor:default}.sec-lookup-stats-card:hover{transform:translateY(-4px);box-shadow:0 14px 28px -8px #0000001f}.sec-lookup-stats-card.stat-primary{border-left:4px solid var(--primary, #2563eb)}.sec-lookup-stats-card.stat-success{border-left:4px solid var(--success, #16a34a)}.sec-lookup-stats-card.stat-warning{border-left:4px solid var(--warning, #d97706)}.sec-lookup-stats-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-primary .sec-lookup-stats-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.stat-success .sec-lookup-stats-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.stat-warning .sec-lookup-stats-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.sec-lookup-stats-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--tx3, #64748b);margin-bottom:6px}.sec-lookup-stats-value{font-size:32px;font-weight:800;color:var(--tx1, #0f172a);line-height:1}.sec-lookup-toolbar{display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:space-between;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:14px 20px;margin-bottom:22px;box-shadow:0 2px 6px #00000005}.sec-lookup-search-wrap{position:relative;flex:1;min-width:260px}.sec-lookup-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.sec-lookup-search{width:100%;padding:11px 16px 11px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s;font-family:inherit}.sec-lookup-search:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe);background:var(--bg-card, #fff)}.sec-lookup-search::placeholder{color:var(--tx3, #94a3b8)}.sec-lookup-filter-group{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.sec-lookup-select{padding:10px 14px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:150px;transition:all .2s;font-family:inherit}.sec-lookup-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.sec-lookup-results-count{font-size:12px;color:var(--tx3, #64748b);background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:20px;padding:4px 12px;white-space:nowrap;font-weight:500}.sec-lookup-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:18px;padding:0;box-shadow:0 4px 16px #0000000d;overflow:hidden;transition:box-shadow .2s}.sec-lookup-card:hover{box-shadow:0 8px 28px #00000017}.sec-lookup-table-wrap{overflow-x:auto}.sec-lookup-table{width:100%;border-collapse:separate;border-spacing:0}.sec-lookup-table thead tr{background:var(--bg, #f8fafc)}.sec-lookup-table th{font-size:11px;font-weight:700;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.6px;padding:14px 18px;text-align:left;border-bottom:2px solid var(--border, #e2e8f0);white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:pointer;transition:background .18s,color .18s}.sec-lookup-table th:first-child{cursor:default}.sec-lookup-table th:hover:not(:first-child){background:var(--bg-hover, #e2e8f0);color:var(--tx1, #0f172a)}.sec-lookup-table td{padding:15px 18px;font-size:14px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #fff);transition:background .15s}.sec-lookup-table tbody tr:last-child td{border-bottom:none}.sec-lookup-table tbody tr:hover td{background:var(--bg-hover, #f8fafc)}.sec-lookup-table tbody tr.sec-lookup-row-dragging td{opacity:.45;background:var(--primary-light, #dbeafe)!important}.sec-lookup-table tbody tr.sec-lookup-row-drop-target td{background:var(--success-light, #dcfce7)!important}.sec-lookup-col-drag{width:40px}.sec-lookup-col-code,.sec-lookup-col-badge{width:160px}.sec-lookup-col-label{min-width:200px}.sec-lookup-col-order{width:90px;text-align:center}.sec-lookup-col-status{width:140px}.sec-lookup-col-updated{width:130px}.sec-lookup-col-actions{width:100px}.sec-lookup-drag-handle{color:var(--tx3, #cbd5e1);cursor:grab;transition:color .2s,transform .15s;display:flex;align-items:center;justify-content:center;padding:4px}.sec-lookup-drag-handle:hover{color:var(--primary, #2563eb);transform:scale(1.2)}.sec-lookup-drag-hint{display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--bg, #f8fafc);border-top:1px dashed var(--border, #e2e8f0);color:var(--tx3, #94a3b8);font-size:12px}.sec-lookup-drag-hint svg{color:var(--primary, #2563eb);flex-shrink:0}.sec-lookup-code-badge{font-family:SF Mono,Fira Code,JetBrains Mono,monospace;font-size:11.5px;font-weight:600;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:4px 9px;border-radius:7px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block;white-space:nowrap;line-height:1.5;letter-spacing:.3px}.sec-lookup-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.35px;border:1px solid transparent;white-space:nowrap;line-height:1.4}.sec-badge-blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.sec-badge-green{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.sec-badge-purple{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.sec-badge-amber{background:#fef3c7;color:#b45309;border-color:#fde68a}.sec-badge-teal{background:#ccfbf1;color:#0f766e;border-color:#99f6e4}.sec-badge-red{background:#fee2e2;color:#dc2626;border-color:#fecaca}.sec-badge-orange{background:#ffedd5;color:#c2410c;border-color:#fed7aa}.sec-badge-gray{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.sec-badge-pink{background:#fce7f3;color:#be185d;border-color:#fbcfe8}.sec-badge-gold{background:#fef9c3;color:#854d0e;border-color:#fef08a}.sec-badge-sky{background:#e0f2fe;color:#0369a1;border-color:#bae6fd}.sec-badge-indigo{background:#e0e7ff;color:#4338ca;border-color:#c7d2fe}.sec-badge-rose{background:#ffe4e6;color:#be123c;border-color:#fecdd3}.sec-badge-lime{background:#ecfccb;color:#4d7c0f;border-color:#d9f99d}.sec-lookup-order-pill{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:30px;background:var(--bg, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:8px;font-weight:700;font-size:13px;color:var(--tx2, #475569);padding:0 10px}.sec-lookup-label-cell{font-weight:500;color:var(--tx1, #0f172a);line-height:1.4}.sec-lookup-label-cell small{display:block;font-size:11px;color:var(--tx3, #94a3b8);font-weight:400;margin-top:2px}.sec-lookup-date-cell{font-size:12px;color:var(--tx3, #64748b);background:var(--bg, #f8fafc);padding:4px 9px;border-radius:7px;display:inline-block;white-space:nowrap;border:1px solid var(--border, #e2e8f0)}.sec-lookup-status-wrap{display:flex;align-items:center;gap:10px}.sec-lookup-status-label{font-size:12px;font-weight:600;white-space:nowrap}.sec-lookup-status-label.is-active{color:var(--success, #16a34a)}.sec-lookup-status-label.is-inactive{color:var(--danger, #dc2626)}.sec-lookup-switch{position:relative;display:inline-block;cursor:pointer}.sec-lookup-switch input{opacity:0;width:0;height:0;position:absolute}.sec-lookup-switch-track{display:block;width:42px;height:24px;background:var(--bg-input, #e2e8f0);border:2px solid var(--border, #cbd5e1);border-radius:30px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.sec-lookup-switch input:checked+.sec-lookup-switch-track{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb)}.sec-lookup-switch-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:0 1px 4px #00000040;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sec-lookup-switch input:checked+.sec-lookup-switch-track .sec-lookup-switch-thumb{transform:translate(18px)}.sec-lookup-sort-icon{display:inline-flex;align-items:center;margin-left:6px;color:var(--tx3, #94a3b8);vertical-align:middle;transition:color .15s}.sec-lookup-sort-icon.asc{color:var(--primary, #2563eb)}.sec-lookup-sort-icon.desc{color:var(--primary, #2563eb);transform:rotate(180deg)}.sec-lookup-action-btns{display:flex;gap:8px;align-items:center}.sec-lookup-action-btn{width:34px;height:34px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx3, #64748b);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.sec-lookup-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-2px);box-shadow:0 4px 10px #2563eb2e}.sec-lookup-action-btn.is-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);box-shadow:0 4px 10px #dc26262e}.sec-lookup-action-btn:disabled{opacity:.4;cursor:not-allowed}.sec-lookup-pagination{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;flex-wrap:wrap;gap:14px;border-top:1px solid var(--border, #e2e8f0)}.sec-lookup-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.sec-lookup-pagination-btns{display:flex;gap:6px;flex-wrap:wrap}.sec-lookup-pag-btn{min-width:36px;height:36px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;padding:0 10px;transition:all .2s}.sec-lookup-pag-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb);transform:translateY(-1px)}.sec-lookup-pag-btn.is-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.sec-lookup-pag-btn:disabled{opacity:.35;cursor:not-allowed}.sec-lookup-empty{text-align:center;padding:72px 20px;background:var(--bg-card, #fff);border:2px dashed var(--border, #e2e8f0);border-radius:20px}.sec-lookup-empty-icon{width:80px;height:80px;border-radius:20px;background:var(--primary-light, #dbeafe);display:flex;align-items:center;justify-content:center;color:var(--primary, #2563eb);margin:0 auto 20px;box-shadow:0 8px 24px #2563eb26}.sec-lookup-empty h3{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);margin-bottom:8px}.sec-lookup-empty p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:28px;max-width:360px;margin-left:auto;margin-right:auto;line-height:1.6}.sec-lookup-skeleton{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:18px;overflow:hidden;padding:0}.sec-lookup-skeleton-thead{background:var(--bg, #f8fafc);padding:14px 20px;border-bottom:2px solid var(--border, #e2e8f0);display:flex;gap:20px}.sec-lookup-skeleton-row{display:flex;gap:20px;padding:16px 20px;border-bottom:1px solid var(--border, #e2e8f0);align-items:center}.sec-lookup-skeleton-row:last-child{border-bottom:none}.sec-lookup-skel-cell{height:18px;border-radius:6px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:sec-lookup-shimmer 1.6s infinite}@keyframes sec-lookup-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sec-lookup-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;font-family:inherit;letter-spacing:.1px}.sec-lookup-btn-sm{font-size:12px;padding:8px 14px;gap:6px}.sec-lookup-btn-primary{background:var(--primary, #2563eb);color:#fff;box-shadow:0 2px 8px #2563eb33}.sec-lookup-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-2px);box-shadow:0 6px 16px #2563eb52}.sec-lookup-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.sec-lookup-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a);border-color:var(--tx3, #94a3b8)}.sec-lookup-btn-danger{background:var(--danger, #dc2626);color:#fff}.sec-lookup-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 6px 16px #dc26264d}.sec-lookup-btn:disabled{opacity:.48;cursor:not-allowed}.sec-lookup-btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:sec-lookup-spin .65s linear infinite}.sec-lookup-spin{animation:sec-lookup-spin 1s linear infinite}@keyframes sec-lookup-spin{to{transform:rotate(360deg)}}.sec-lookup-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.sec-lookup-toast{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;background:var(--bg-card, #fff);border-radius:12px;box-shadow:0 10px 24px -4px #0000002e,0 0 0 1px #0000000a;min-width:300px;max-width:420px;animation:sec-lookup-toast-in .3s cubic-bezier(.22,1,.36,1);pointer-events:all;border-left:4px solid var(--primary, #2563eb);position:relative}.sec-lookup-toast.toast-success{border-left-color:var(--success, #16a34a)}.sec-lookup-toast.toast-error{border-left-color:var(--danger, #dc2626)}.sec-lookup-toast.toast-warning{border-left-color:var(--warning, #d97706)}.sec-lookup-toast-icon{flex-shrink:0;margin-top:1px}.sec-lookup-toast.toast-success .sec-lookup-toast-icon{color:var(--success, #16a34a)}.sec-lookup-toast.toast-error .sec-lookup-toast-icon{color:var(--danger, #dc2626)}.sec-lookup-toast.toast-warning .sec-lookup-toast-icon{color:var(--warning, #d97706)}.sec-lookup-toast.toast-info .sec-lookup-toast-icon{color:var(--primary, #2563eb)}.sec-lookup-toast-body{flex:1}.sec-lookup-toast-title{font-size:13px;font-weight:700;color:var(--tx1, #0f172a);margin-bottom:2px}.sec-lookup-toast-msg{font-size:13px;color:var(--tx2, #475569);line-height:1.5}.sec-lookup-toast-close{width:24px;height:24px;border-radius:50%;border:none;background:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;margin-top:-2px}.sec-lookup-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes sec-lookup-toast-in{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.sec-lookup-modal-overlay{position:fixed;inset:0;z-index:1100;background:#0f172a8c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:20px;animation:sec-lookup-overlay-in .2s ease}@keyframes sec-lookup-overlay-in{0%{opacity:0}to{opacity:1}}.sec-lookup-modal{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:24px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:0 30px 60px -20px #00000052,0 0 0 1px #0000000a;animation:sec-lookup-modal-in .3s cubic-bezier(.22,1,.36,1)}.sec-lookup-modal.is-sm{max-width:440px}@keyframes sec-lookup-modal-in{0%{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.sec-lookup-modal-head{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 0}.sec-lookup-modal-title{font-size:17px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:10px}.sec-lookup-modal-title-icon{width:36px;height:36px;border-radius:10px;background:var(--primary-light, #dbeafe);display:flex;align-items:center;justify-content:center;color:var(--primary, #2563eb);flex-shrink:0}.sec-lookup-modal-close{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;line-height:1}.sec-lookup-modal-close:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.sec-lookup-modal-close:disabled{opacity:.45;cursor:not-allowed}.sec-lookup-modal-body{padding:22px 28px}.sec-lookup-modal-foot{padding:18px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:10px}.sec-lookup-field{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.sec-lookup-field:last-child{margin-bottom:0}.sec-lookup-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:8px;line-height:1}.sec-lookup-required{color:var(--danger, #dc2626);font-size:15px}.sec-lookup-auto-tag{font-size:10px;font-weight:500;padding:2px 7px;border-radius:12px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border:1px solid var(--primary-border, #bfdbfe)}.sec-lookup-input,.sec-lookup-textarea{background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:11px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit;line-height:1.5}.sec-lookup-input:focus,.sec-lookup-textarea:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe);background:var(--bg-card, #fff)}.sec-lookup-input.has-error,.sec-lookup-textarea.has-error{border-color:var(--danger, #dc2626);background:#fff8f8;box-shadow:0 0 0 3px var(--danger-light, #fee2e2)}.sec-lookup-input:disabled{opacity:.6;cursor:not-allowed;background:var(--bg, #f8fafc)}.sec-lookup-textarea{resize:vertical;min-height:88px}.sec-lookup-hint{font-size:11.5px;color:var(--tx3, #64748b);line-height:1.5}.sec-lookup-field-error{font-size:11.5px;color:var(--danger, #dc2626);display:flex;align-items:center;gap:4px}.sec-lookup-code-display{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px}.sec-lookup-code-display .sec-lookup-code-badge{font-size:13px}.sec-lookup-code-display span{font-size:11px;color:var(--tx3, #94a3b8)}.sec-lookup-field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.sec-lookup-confirm-icon{width:72px;height:72px;border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}.sec-lookup-confirm-icon.is-danger{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626)}.sec-lookup-confirm-icon.is-success{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.sec-lookup-confirm-icon.is-warning{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.sec-lookup-confirm-body{text-align:center}.sec-lookup-confirm-title{font-size:16px;font-weight:700;color:var(--tx1, #0f172a);margin-bottom:8px}.sec-lookup-confirm-msg{font-size:14px;color:var(--tx2, #475569);line-height:1.65;max-width:340px;margin:0 auto}.sec-lookup-confirm-warn{margin-top:14px;font-size:12px;color:var(--warning, #d97706);background:var(--warning-light, #fef3c7);border:1px solid #fde68a;border-radius:8px;padding:8px 12px;display:flex;align-items:center;gap:6px;text-align:left}@media(max-width:1024px){.sec-lookup-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sec-lookup-page-hdr{flex-direction:column}.sec-lookup-page-actions{width:100%}.sec-lookup-toolbar{flex-direction:column;align-items:stretch}.sec-lookup-search-wrap,.sec-lookup-select{width:100%}.sec-lookup-stats-grid{grid-template-columns:1fr;gap:14px}.sec-lookup-field-row{grid-template-columns:1fr}.sec-lookup-pagination{flex-direction:column;align-items:stretch}.sec-lookup-pagination-btns{justify-content:center;flex-wrap:wrap}.sec-lookup-modal-head,.sec-lookup-modal-body,.sec-lookup-modal-foot{padding-left:20px;padding-right:20px}.sec-lookup-table th,.sec-lookup-table td{padding:12px}}@media print{.sec-lookup-page-actions,.sec-lookup-toolbar,.sec-lookup-action-btns,.sec-lookup-status-wrap,.sec-lookup-drag-handle,.sec-lookup-drag-hint,.sec-lookup-pagination,.sec-lookup-toast-container,.sec-lookup-modal-overlay{display:none!important}.sec-lookup-card{box-shadow:none;border:1px solid #000}}.dms-page *,.dms-page *:before,.dms-page *:after{box-sizing:border-box}.dms-page{display:flex;flex-direction:column;gap:0;min-height:100%}.dms-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap}.dms-page-title-row{display:flex;align-items:center;gap:14px}.dms-page-icon{width:52px;height:52px;border-radius:16px;background:var(--primary-light, #dbeafe);display:flex;align-items:center;justify-content:center;color:var(--primary, #2563eb);box-shadow:0 4px 14px #2563eb2e;flex-shrink:0}.dms-page-title{font-size:22px;font-weight:800;color:var(--tx1, #0f172a);line-height:1.2}.dms-page-sub{font-size:13px;color:var(--tx3, #64748b);margin-top:3px;line-height:1.5}.dms-page-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.dms-tabs{display:flex;gap:4px;border-bottom:2px solid var(--border, #e2e8f0);margin-bottom:28px;flex-wrap:wrap}.dms-tab{display:flex;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:600;color:var(--tx3, #64748b);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;border-radius:8px 8px 0 0;white-space:nowrap;font-family:inherit}.dms-tab:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}.dms-tab.is-active{color:var(--primary, #2563eb);border-bottom-color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe)}.dms-tab-badge{min-width:20px;height:20px;border-radius:10px;background:var(--danger, #dc2626);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px}.dms-tab.is-active .dms-tab-badge{background:var(--primary, #2563eb)}.dms-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px}.dms-stat-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:18px;padding:20px 18px;display:flex;align-items:center;gap:14px;transition:transform .22s,box-shadow .22s;box-shadow:0 2px 8px #0000000a;cursor:default}.dms-stat-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px -6px #0000001f}.dms-stat-card.stat-primary{border-left:4px solid var(--primary, #2563eb)}.dms-stat-card.stat-warning{border-left:4px solid var(--warning, #d97706)}.dms-stat-card.stat-danger{border-left:4px solid var(--danger, #dc2626)}.dms-stat-card.stat-success{border-left:4px solid var(--success, #16a34a)}.dms-stat-card.stat-purple{border-left:4px solid #7c3aed}.dms-stat-card.stat-teal{border-left:4px solid #0f766e}.dms-stat-card.stat-sky{border-left:4px solid #0369a1}.dms-stat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-primary .dms-stat-icon{background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb)}.stat-warning .dms-stat-icon{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706)}.stat-danger .dms-stat-icon{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626)}.stat-success .dms-stat-icon{background:var(--success-light, #dcfce7);color:var(--success, #16a34a)}.stat-purple .dms-stat-icon{background:#ede9fe;color:#7c3aed}.stat-teal .dms-stat-icon{background:#ccfbf1;color:#0f766e}.stat-sky .dms-stat-icon{background:#e0f2fe;color:#0369a1}.dms-stat-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3, #64748b);margin-bottom:4px}.dms-stat-value{font-size:30px;font-weight:800;color:var(--tx1, #0f172a);line-height:1}.dms-stat-sub{font-size:11px;color:var(--tx3, #94a3b8);margin-top:3px}.dms-toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;justify-content:space-between;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;padding:14px 18px;margin-bottom:20px;box-shadow:0 2px 6px #00000005}.dms-search-wrap{position:relative;flex:1;min-width:240px}.dms-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--tx3, #94a3b8);pointer-events:none}.dms-search{width:100%;padding:11px 16px 11px 44px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;outline:none;transition:all .2s;font-family:inherit}.dms-search:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe);background:#fff}.dms-search::placeholder{color:var(--tx3, #94a3b8)}.dms-filter-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.dms-select{padding:9px 12px;background:var(--bg-input, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:all .2s;font-family:inherit}.dms-select:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px var(--primary-light, #dbeafe)}.dms-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:18px;overflow:hidden;box-shadow:0 4px 16px #0000000d}.dms-table-wrap{overflow-x:auto}.dms-table{width:100%;border-collapse:separate;border-spacing:0}.dms-table thead tr{background:var(--bg, #f8fafc)}.dms-table th{font-size:11px;font-weight:700;color:var(--tx3, #64748b);text-transform:uppercase;letter-spacing:.6px;padding:14px 16px;text-align:left;border-bottom:2px solid var(--border, #e2e8f0);white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:pointer;transition:background .15s,color .15s}.dms-table th:first-child{cursor:default}.dms-table th:hover:not(:first-child){background:var(--bg-hover, #e2e8f0);color:var(--tx1, #0f172a)}.dms-table td{padding:14px 16px;font-size:13.5px;color:var(--tx2, #475569);border-bottom:1px solid var(--border, #e2e8f0);vertical-align:middle;background:var(--bg-card, #fff);transition:background .12s}.dms-table tbody tr:last-child td{border-bottom:none}.dms-table tbody tr:hover td{background:var(--bg-hover, #f8fafc)}.dms-table tbody tr.is-urgent td{border-left:3px solid var(--danger, #dc2626)}.dms-table tbody tr.is-confidential td{border-left:3px solid #7c3aed}.dms-ref-badge{font-family:SF Mono,Fira Code,monospace;font-size:12px;font-weight:700;color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe);padding:4px 9px;border-radius:7px;border:1px solid var(--primary-border, #bfdbfe);display:inline-block;white-space:nowrap;letter-spacing:.3px}.dms-ref-badge.is-outgoing{color:#0f766e;background:#ccfbf1;border-color:#99f6e4}.dms-ref-badge.is-sig{color:#7c3aed;background:#ede9fe;border-color:#ddd6fe}.dms-status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent;white-space:nowrap}.dms-status-PENDING_MD{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.dms-status-PENDING_DEPT{background:#fef3c7;color:#b45309;border-color:#fde68a}.dms-status-PENDING_DISPATCH{background:#ffedd5;color:#c2410c;border-color:#fed7aa}.dms-status-PENDING_RECEIPT{background:#e0f2fe;color:#0369a1;border-color:#bae6fd}.dms-status-PENDING_SCREENING{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.dms-status-PENDING_MD_SIGN{background:#fce7f3;color:#be185d;border-color:#fbcfe8}.dms-status-RETURNED_REVISION{background:#fee2e2;color:#dc2626;border-color:#fecaca}.dms-status-APPROVED{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.dms-status-CLOSED{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.dms-urgency-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:12px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;border:1px solid transparent}.dms-urgency-NORMAL{background:#f3f4f6;color:#4b5563;border-color:#e5e7eb}.dms-urgency-URGENT{background:#fee2e2;color:#dc2626;border-color:#fecaca}.dms-urgency-CONFIDENTIAL{background:#ede9fe;color:#7c3aed;border-color:#ddd6fe}.dms-urgency-STRICTLY_CONF{background:#1e1b4b;color:#fff;border-color:#312e81}.dms-subject-cell{font-weight:600;color:var(--tx1, #0f172a);line-height:1.35}.dms-subject-cell small{display:block;font-size:11.5px;color:var(--tx3, #94a3b8);font-weight:400;margin-top:2px}.dms-sender-cell{font-size:13px;color:var(--tx2, #475569)}.dms-sender-cell small{display:block;font-size:11px;color:var(--tx3, #94a3b8)}.dms-date-cell{font-size:12px;color:var(--tx3, #64748b);background:var(--bg, #f8fafc);padding:3px 8px;border-radius:6px;border:1px solid var(--border, #e2e8f0);display:inline-block;white-space:nowrap}.dms-action-btns{display:flex;gap:7px;align-items:center}.dms-action-btn{width:32px;height:32px;border-radius:8px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx3, #64748b);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.dms-action-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);transform:translateY(-1px);box-shadow:0 3px 8px #2563eb2e}.dms-action-btn.is-danger:hover:not(:disabled){background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.dms-action-btn.is-success:hover:not(:disabled){background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border-color:var(--success, #16a34a)}.dms-action-btn:disabled{opacity:.4;cursor:not-allowed}.dms-pagination{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-top:1px solid var(--border, #e2e8f0);flex-wrap:wrap;gap:12px}.dms-pagination-info{font-size:13px;color:var(--tx3, #64748b)}.dms-pagination-btns{display:flex;gap:5px;flex-wrap:wrap}.dms-pag-btn{min-width:34px;height:34px;border-radius:8px;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0 8px;gap:4px;transition:all .18s}.dms-pag-btn:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.dms-pag-btn.is-active{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb)}.dms-pag-btn:disabled{opacity:.35;cursor:not-allowed}.dms-empty{text-align:center;padding:72px 20px;background:var(--bg-card, #fff);border:2px dashed var(--border, #e2e8f0);border-radius:20px}.dms-empty-icon{width:80px;height:80px;border-radius:20px;background:var(--primary-light, #dbeafe);display:flex;align-items:center;justify-content:center;color:var(--primary, #2563eb);margin:0 auto 20px;box-shadow:0 8px 20px #2563eb26}.dms-empty h3{font-size:18px;font-weight:700;color:var(--tx1, #0f172a);margin-bottom:8px}.dms-empty p{font-size:14px;color:var(--tx3, #64748b);margin-bottom:26px;max-width:380px;margin-left:auto;margin-right:auto;line-height:1.6}.dms-skeleton{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:18px;overflow:hidden}.dms-skel-row{display:flex;gap:16px;padding:16px 20px;border-bottom:1px solid var(--border, #e2e8f0);align-items:center}.dms-skel-row:last-child{border-bottom:none}.dms-skel-cell{height:16px;border-radius:6px;background:linear-gradient(90deg,var(--bg, #f1f5f9) 25%,var(--bg-hover, #e2e8f0) 50%,var(--bg, #f1f5f9) 75%);background-size:200% 100%;animation:dms-shimmer 1.6s infinite;flex-shrink:0}@keyframes dms-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.dms-drawer-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1050;animation:dms-overlay-in .2s ease}@keyframes dms-overlay-in{0%{opacity:0}to{opacity:1}}.dms-drawer{position:fixed;right:0;top:0;bottom:0;width:min(680px,98vw);background:var(--bg-card, #fff);box-shadow:-8px 0 40px #0000002e;display:flex;flex-direction:column;z-index:1060;animation:dms-drawer-in .3s cubic-bezier(.22,1,.36,1);overflow:hidden}@keyframes dms-drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.dms-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);flex-shrink:0}.dms-drawer-title{display:flex;align-items:center;gap:12px;font-size:16px;font-weight:700;color:var(--tx1, #0f172a)}.dms-drawer-close{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border, #e2e8f0);background:var(--bg-card, #fff);color:var(--tx2, #475569);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.dms-drawer-close:hover{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.dms-drawer-body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:24px}.dms-drawer-foot{padding:16px 24px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0;background:var(--bg, #f8fafc)}.dms-detail-section{display:flex;flex-direction:column;gap:14px}.dms-detail-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--tx3, #64748b);padding-bottom:8px;border-bottom:2px solid var(--border, #e2e8f0);display:flex;align-items:center;gap:8px}.dms-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.dms-detail-field{display:flex;flex-direction:column;gap:3px}.dms-detail-field.span-2{grid-column:span 2}.dms-detail-label{font-size:11px;font-weight:600;color:var(--tx3, #94a3b8);text-transform:uppercase;letter-spacing:.5px}.dms-detail-value{font-size:14px;color:var(--tx1, #0f172a);font-weight:500;line-height:1.5}.dms-detail-value.is-muted{color:var(--tx3, #94a3b8);font-weight:400;font-style:italic}.dms-routing-list{display:flex;flex-direction:column;gap:0}.dms-routing-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border, #e2e8f0);position:relative}.dms-routing-item:last-child{border-bottom:none}.dms-routing-dot{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;margin-top:2px}.dms-routing-dot.is-pending{background:var(--warning-light, #fef3c7);color:var(--warning, #d97706);border:2px solid var(--warning, #d97706)}.dms-routing-dot.is-resolved{background:var(--success-light, #dcfce7);color:var(--success, #16a34a);border:2px solid var(--success, #16a34a)}.dms-routing-content{flex:1}.dms-routing-title{font-size:13.5px;font-weight:600;color:var(--tx1, #0f172a);margin-bottom:3px}.dms-routing-meta{font-size:12px;color:var(--tx3, #64748b);margin-bottom:6px}.dms-routing-instruction{font-size:13px;color:var(--tx2, #475569);background:var(--bg, #f8fafc);border:1px solid var(--border, #e2e8f0);border-left:3px solid var(--warning, #d97706);border-radius:0 8px 8px 0;padding:8px 12px;margin-bottom:8px;line-height:1.5}.dms-routing-feedback{font-size:13px;color:var(--tx2, #475569);background:var(--success-light, #dcfce7);border:1px solid #bbf7d0;border-radius:8px;padding:8px 12px;line-height:1.5}.dms-audit-list{display:flex;flex-direction:column;gap:0}.dms-audit-item{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--border, #f1f5f9)}.dms-audit-item:last-child{border-bottom:none}.dms-audit-icon{width:32px;height:32px;border-radius:50%;background:var(--bg, #f8fafc);border:1.5px solid var(--border, #e2e8f0);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--tx3, #64748b)}.dms-audit-content{flex:1}.dms-audit-event{font-size:13px;font-weight:600;color:var(--tx1, #0f172a)}.dms-audit-note{font-size:12.5px;color:var(--tx2, #475569);margin-top:2px;line-height:1.5}.dms-audit-meta{font-size:11px;color:var(--tx3, #94a3b8);margin-top:4px}.dms-modal-overlay{position:fixed;inset:0;z-index:1100;background:#0f172a8c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:20px;animation:dms-overlay-in .2s ease}.dms-modal{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:24px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:0 30px 60px -20px #0000004d;animation:dms-modal-in .3s cubic-bezier(.22,1,.36,1)}.dms-modal.is-lg{max-width:820px}.dms-modal.is-sm{max-width:460px}@keyframes dms-modal-in{0%{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.dms-modal-head{display:flex;align-items:center;justify-content:space-between;padding:22px 28px 0}.dms-modal-title{font-size:17px;font-weight:700;color:var(--tx1, #0f172a);display:flex;align-items:center;gap:10px}.dms-modal-title-icon{width:38px;height:38px;border-radius:10px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dms-modal-close{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx2, #475569);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.dms-modal-close:hover{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border-color:var(--danger, #dc2626);transform:rotate(90deg)}.dms-modal-close:disabled{opacity:.4;cursor:not-allowed}.dms-modal-body{padding:22px 28px}.dms-modal-foot{padding:18px 28px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end;gap:10px}.dms-form-section{margin-bottom:24px}.dms-form-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--tx3, #64748b);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border, #e2e8f0);display:flex;align-items:center;gap:8px}.dms-field{display:flex;flex-direction:column;gap:5px;margin-bottom:18px}.dms-field:last-child{margin-bottom:0}.dms-field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dms-field-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.dms-label{font-size:13px;font-weight:600;color:var(--tx2, #475569);display:flex;align-items:center;gap:6px}.dms-required{color:var(--danger, #dc2626);font-size:15px}.dms-input,.dms-textarea,.dms-select-input{background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;color:var(--tx1, #0f172a);font-size:14px;padding:11px 14px;outline:none;width:100%;transition:all .2s;font-family:inherit;line-height:1.5}.dms-input:focus,.dms-textarea:focus,.dms-select-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe);background:#fff}.dms-input.has-error,.dms-textarea.has-error{border-color:var(--danger, #dc2626);box-shadow:0 0 0 3px #fee2e2}.dms-input:disabled,.dms-textarea:disabled{opacity:.6;cursor:not-allowed;background:var(--bg, #f8fafc)}.dms-textarea{resize:vertical;min-height:90px}.dms-field-error{font-size:12px;color:var(--danger, #dc2626);display:flex;align-items:center;gap:4px}.dms-field-hint{font-size:12px;color:var(--tx3, #64748b);line-height:1.5}.dms-multi-select{display:flex;flex-wrap:wrap;gap:8px;padding:10px 12px;background:var(--bg-input, #fff);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;min-height:48px;cursor:pointer;transition:all .2s}.dms-multi-select:focus-within{border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.dms-tag{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;background:var(--primary-light, #dbeafe);color:var(--primary, #2563eb);border-radius:20px;font-size:12px;font-weight:600;border:1px solid var(--primary-border, #bfdbfe)}.dms-tag-remove{width:16px;height:16px;border-radius:50%;border:none;background:#2563eb33;color:var(--primary, #2563eb);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s;padding:0}.dms-tag-remove:hover{background:var(--primary, #2563eb);color:#fff}.dms-dropzone{border:2px dashed var(--border, #e2e8f0);border-radius:14px;padding:28px 20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg, #f8fafc);display:flex;flex-direction:column;align-items:center;gap:8px}.dms-dropzone:hover,.dms-dropzone.is-over{border-color:var(--primary, #2563eb);background:var(--primary-light, #dbeafe)}.dms-dropzone-icon{color:var(--tx3, #94a3b8);margin-bottom:4px}.dms-dropzone:hover .dms-dropzone-icon{color:var(--primary, #2563eb)}.dms-dropzone-title{font-size:14px;font-weight:600;color:var(--tx1, #0f172a)}.dms-dropzone-sub{font-size:12px;color:var(--tx3, #94a3b8)}.dms-file-preview{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-card, #fff);border:1.5px solid var(--success, #16a34a);border-radius:12px;margin-top:10px}.dms-file-preview-icon{color:var(--success, #16a34a);flex-shrink:0}.dms-file-preview-name{font-size:13px;font-weight:600;color:var(--tx1, #0f172a);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dms-file-preview-size{font-size:11px;color:var(--tx3, #94a3b8);white-space:nowrap}.dms-file-remove{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--danger, #dc2626);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.dms-file-remove:hover{background:var(--danger-light, #fee2e2)}.dms-recipients-list{display:flex;flex-direction:column;gap:10px}.dms-recipient-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:12px}.dms-recipient-item.is-confirmed{border-color:var(--success, #16a34a);background:var(--success-light, #dcfce7)}.dms-recipient-info{flex:1}.dms-recipient-name{font-size:13.5px;font-weight:600;color:var(--tx1, #0f172a)}.dms-recipient-meta{font-size:12px;color:var(--tx3, #64748b);margin-top:2px}.dms-recipient-remove{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border, #e2e8f0);background:transparent;color:var(--danger, #dc2626);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.dms-recipient-remove:hover{background:var(--danger-light, #fee2e2)}.dms-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13px;font-weight:600;padding:10px 18px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;font-family:inherit}.dms-btn-sm{font-size:12px;padding:8px 14px}.dms-btn-xs{font-size:11px;padding:6px 10px;border-radius:8px}.dms-btn-primary{background:var(--primary, #2563eb);color:#fff;box-shadow:0 2px 8px #2563eb33}.dms-btn-primary:hover:not(:disabled){background:var(--primary-hover, #1d4ed8);transform:translateY(-1px);box-shadow:0 6px 16px #2563eb4d}.dms-btn-ghost{background:transparent;color:var(--tx2, #475569);border:1.5px solid var(--border, #e2e8f0)}.dms-btn-ghost:hover:not(:disabled){background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}.dms-btn-success{background:var(--success, #16a34a);color:#fff}.dms-btn-success:hover:not(:disabled){background:#15803d;transform:translateY(-1px)}.dms-btn-danger{background:var(--danger, #dc2626);color:#fff}.dms-btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.dms-btn-warning{background:var(--warning, #d97706);color:#fff}.dms-btn-warning:hover:not(:disabled){background:#b45309;transform:translateY(-1px)}.dms-btn:disabled{opacity:.45;cursor:not-allowed}.dms-btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:dms-spin .65s linear infinite}@keyframes dms-spin{to{transform:rotate(360deg)}}.dms-spin{animation:dms-spin 1s linear infinite}.dms-toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.dms-toast{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;background:var(--bg-card, #fff);border-radius:12px;box-shadow:0 10px 28px -4px #0000002e,0 0 0 1px #0000000a;min-width:300px;max-width:420px;pointer-events:all;animation:dms-toast-in .3s cubic-bezier(.22,1,.36,1);border-left:4px solid var(--primary, #2563eb)}.dms-toast.toast-success{border-left-color:var(--success, #16a34a)}.dms-toast.toast-error{border-left-color:var(--danger, #dc2626)}.dms-toast.toast-warning{border-left-color:var(--warning, #d97706)}.dms-toast-icon{flex-shrink:0;margin-top:1px}.dms-toast.toast-success .dms-toast-icon{color:var(--success, #16a34a)}.dms-toast.toast-error .dms-toast-icon{color:var(--danger, #dc2626)}.dms-toast.toast-warning .dms-toast-icon{color:var(--warning, #d97706)}.dms-toast.toast-info .dms-toast-icon{color:var(--primary, #2563eb)}.dms-toast-title{font-size:13px;font-weight:700;color:var(--tx1, #0f172a);margin-bottom:2px}.dms-toast-msg{font-size:13px;color:var(--tx2, #475569);line-height:1.5;flex:1}.dms-toast-close{width:22px;height:22px;border-radius:50%;border:none;background:none;color:var(--tx3, #94a3b8);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.dms-toast-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--tx1, #0f172a)}@keyframes dms-toast-in{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.dms-workflow-steps{display:flex;align-items:center;gap:0;overflow-x:auto;padding:16px 0}.dms-workflow-step{display:flex;align-items:center;gap:0;flex-shrink:0}.dms-workflow-step-node{display:flex;flex-direction:column;align-items:center;gap:6px;padding:0 12px}.dms-workflow-step-circle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;border:2px solid var(--border, #e2e8f0);background:var(--bg, #f8fafc);color:var(--tx3, #64748b)}.dms-workflow-step.is-done .dms-workflow-step-circle{background:var(--success, #16a34a);color:#fff;border-color:var(--success, #16a34a)}.dms-workflow-step.is-active .dms-workflow-step-circle{background:var(--primary, #2563eb);color:#fff;border-color:var(--primary, #2563eb);box-shadow:0 0 0 4px var(--primary-light, #dbeafe)}.dms-workflow-step-label{font-size:11px;font-weight:600;color:var(--tx3, #64748b);white-space:nowrap}.dms-workflow-step.is-done .dms-workflow-step-label{color:var(--success, #16a34a)}.dms-workflow-step.is-active .dms-workflow-step-label{color:var(--primary, #2563eb)}.dms-workflow-connector{width:40px;height:2px;background:var(--border, #e2e8f0);flex-shrink:0}.dms-workflow-step.is-done+.dms-workflow-step .dms-workflow-connector,.dms-workflow-connector.is-done{background:var(--success, #16a34a)}.dms-overdue-banner{background:var(--danger-light, #fee2e2);border:1px solid #fecaca;border-radius:14px;padding:16px 20px;display:flex;align-items:flex-start;gap:12px;margin-bottom:20px}.dms-overdue-banner-icon{color:var(--danger, #dc2626);flex-shrink:0;margin-top:1px}.dms-overdue-banner h4{font-size:13.5px;font-weight:700;color:var(--danger, #dc2626);margin-bottom:4px}.dms-overdue-banner p{font-size:12.5px;color:#b91c1c;line-height:1.5}@media(max-width:1024px){.dms-stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.dms-page-hdr{flex-direction:column}.dms-toolbar{flex-direction:column;align-items:stretch}.dms-search-wrap,.dms-select{width:100%}.dms-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.dms-detail-grid{grid-template-columns:1fr}.dms-detail-field.span-2{grid-column:span 1}.dms-field-row,.dms-field-row-3{grid-template-columns:1fr}.dms-modal-head,.dms-modal-body,.dms-modal-foot{padding-left:20px;padding-right:20px}.dms-drawer{width:100%}.dms-tabs{gap:2px}.dms-tab{padding:10px 12px;font-size:12px}}@media print{.dms-page-actions,.dms-toolbar,.dms-action-btns,.dms-drawer-overlay,.dms-modal-overlay,.dms-toast-container,.dms-tabs,.dms-pagination{display:none!important}.dms-card{box-shadow:none;border:1px solid #000}}:root{--eq-bg: var(--bg, #f0f2f7);--eq-card: var(--bg-card, #ffffff);--eq-border: var(--border, #e2e8f0);--eq-tx1: var(--tx1, #0f172a);--eq-tx2: var(--tx2, #475569);--eq-tx3: var(--tx3, #94a3b8);--eq-primary: #1d4ed8;--eq-primary-lt: #dbeafe;--eq-amber: #d97706;--eq-amber-lt: #fef3c7;--eq-green: #15803d;--eq-green-lt: #dcfce7;--eq-red: #dc2626;--eq-red-lt: #fee2e2;--eq-blue: #2563eb;--eq-blue-lt: #dbeafe;--eq-slate: #475569;--eq-slate-lt: #f1f5f9;--eq-radius: 14px;--eq-radius-sm: 8px;--eq-shadow: 0 2px 10px rgba(15, 23, 42, .06);--eq-shadow-lg: 0 20px 60px rgba(15, 23, 42, .18)}.eq-page{padding:0 0 40px;min-height:100vh}.eq-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:28px;padding:28px 0 0}.eq-header__left{display:flex;align-items:flex-start;gap:16px}.eq-header__icon{width:48px;height:48px;border-radius:13px;background:var(--eq-primary);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px #1d4ed859}.eq-header__title{font-size:22px;font-weight:700;color:var(--eq-tx1);letter-spacing:-.3px;margin:0 0 3px}.eq-header__sub{font-size:13px;color:var(--eq-tx3);margin:0}.eq-header__actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding-top:4px}.eq-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}.eq-stat{display:flex;align-items:center;gap:14px;background:var(--eq-card);border:1.5px solid var(--eq-border);border-radius:var(--eq-radius);padding:18px 20px;text-align:left;cursor:pointer;transition:all .22s ease;box-shadow:var(--eq-shadow);border-left:4px solid transparent}.eq-stat:hover{transform:translateY(-3px);box-shadow:0 10px 30px #0f172a1a}.eq-stat--active{border-left-color:var(--eq-primary);background:var(--eq-primary-lt)}.eq-stat--neutral .eq-stat__icon{background:#e2e8f0;color:var(--eq-slate)}.eq-stat--amber .eq-stat__icon{background:var(--eq-amber-lt);color:var(--eq-amber)}.eq-stat--green .eq-stat__icon{background:var(--eq-green-lt);color:var(--eq-green)}.eq-stat--red .eq-stat__icon{background:var(--eq-red-lt);color:var(--eq-red)}.eq-stat--neutral.eq-stat--active{border-left-color:var(--eq-slate)}.eq-stat--amber.eq-stat--active{border-left-color:var(--eq-amber);background:var(--eq-amber-lt)}.eq-stat--red.eq-stat--active{border-left-color:var(--eq-red);background:var(--eq-red-lt)}.eq-stat__icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.eq-stat__body{display:flex;flex-direction:column;gap:1px}.eq-stat__val{font-size:26px;font-weight:700;color:var(--eq-tx1);line-height:1.1}.eq-stat__label{font-size:11px;font-weight:600;color:var(--eq-tx3);text-transform:uppercase;letter-spacing:.5px}.eq-stat__sub{font-size:11px;color:var(--eq-tx3)}.eq-filters{max-height:0;overflow:hidden;transition:max-height .3s ease;margin-bottom:0}.eq-filters--open{max-height:200px;margin-bottom:16px}.eq-filters__inner{display:flex;gap:12px;flex-wrap:wrap;align-items:center;background:var(--eq-card);border:1.5px solid var(--eq-border);border-radius:var(--eq-radius);padding:16px 20px;box-shadow:var(--eq-shadow)}.eq-search-wrap{position:relative;flex:1;min-width:240px}.eq-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--eq-tx3);pointer-events:none}.eq-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--eq-tx3);cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center}.eq-search-clear:hover{color:var(--eq-tx1)}.eq-search{width:100%;padding:9px 36px;background:var(--eq-bg);border:1.5px solid var(--eq-border);border-radius:var(--eq-radius-sm);font-size:13.5px;color:var(--eq-tx1);outline:none;transition:border-color .2s,box-shadow .2s;font-family:inherit}.eq-search:focus{border-color:var(--eq-primary);box-shadow:0 0 0 3px var(--eq-primary-lt)}.eq-filter-group{position:relative;display:flex;align-items:center}.eq-filter-group__icon{position:absolute;left:10px;color:var(--eq-tx3);pointer-events:none;z-index:1}.eq-select{padding:9px 12px 9px 30px;background:var(--eq-bg);border:1.5px solid var(--eq-border);border-radius:var(--eq-radius-sm);font-size:13px;color:var(--eq-tx1);outline:none;cursor:pointer;font-family:inherit;transition:border-color .2s;min-width:150px}.eq-select:focus{border-color:var(--eq-primary)}.eq-skeleton-wrap{background:var(--eq-card);border-radius:var(--eq-radius);padding:24px;border:1px solid var(--eq-border)}.eq-skeleton-row{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid var(--eq-border)}.eq-skeleton-row:last-child{border-bottom:none}.eq-skeleton-cell{height:18px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:eq-shimmer 1.4s infinite;border-radius:5px}@keyframes eq-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.eq-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;background:var(--eq-card);border:2px dashed var(--eq-border);border-radius:var(--eq-radius);text-align:center}.eq-empty__icon{color:var(--eq-tx3);margin-bottom:20px}.eq-empty h3{font-size:17px;font-weight:600;color:var(--eq-tx1);margin:0 0 8px}.eq-empty p{font-size:13px;color:var(--eq-tx3);margin:0}.eq-empty-sm{padding:32px;text-align:center;color:var(--eq-tx3);font-size:13px}.eq-table-card{background:var(--eq-card);border:1px solid var(--eq-border);border-radius:var(--eq-radius);box-shadow:var(--eq-shadow);overflow:hidden}.eq-table-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--eq-border);background:#fafbfc}.eq-table-count{font-size:12px;font-weight:600;color:var(--eq-tx3);text-transform:uppercase;letter-spacing:.5px}.eq-table-scroll{overflow-x:auto}.eq-table{width:100%;border-collapse:separate;border-spacing:0}.eq-table thead th{font-size:11px;font-weight:700;color:var(--eq-tx3);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;background:#fafbfc;border-bottom:2px solid var(--eq-border);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .18s}.eq-table thead th:hover{color:var(--eq-tx1)}.eq-table tbody td{padding:14px 16px;font-size:13px;color:var(--eq-tx2);border-bottom:1px solid var(--eq-border);vertical-align:middle;transition:background .15s}.eq-table tbody tr:last-child td{border-bottom:none}.eq-table tbody tr:hover td{background:#f8fafc}.eq-row--followup td:first-child{border-left:3px solid var(--eq-amber)}.eq-sort-icon{display:inline-flex;vertical-align:middle;margin-left:5px;color:var(--eq-tx3);opacity:.5;transition:opacity .15s,transform .15s}.eq-sort-icon--asc{opacity:1;transform:scaleY(-1);color:var(--eq-primary)}.eq-sort-icon--desc{opacity:1;color:var(--eq-primary)}.eq-visitor{display:flex;align-items:flex-start;gap:10px;min-width:180px}.eq-visitor__avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--eq-primary) 0%,#3b82f6 100%);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:.5px}.eq-visitor__info{display:flex;flex-direction:column;gap:2px}.eq-visitor__name{font-weight:600;color:var(--eq-tx1);font-size:13px}.eq-visitor__phone,.eq-visitor__org,.eq-visitor__purpose{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--eq-tx3)}.eq-visitor__purpose{font-style:italic;color:var(--eq-primary)}.eq-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;letter-spacing:.2px}.eq-badge--amber{background:var(--eq-amber-lt);color:#92400e;border:1px solid #fde68a}.eq-badge--blue{background:var(--eq-blue-lt);color:#1e40af;border:1px solid #bfdbfe}.eq-badge--green{background:var(--eq-green-lt);color:#14532d;border:1px solid #bbf7d0}.eq-badge--slate{background:var(--eq-slate-lt);color:var(--eq-slate);border:1px solid #cbd5e1}.eq-badge--red{background:var(--eq-red-lt);color:#991b1b;border:1px solid #fecaca}.eq-pills{display:flex;flex-wrap:wrap;gap:5px;min-width:140px;max-width:220px}.eq-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--eq-primary-lt);color:var(--eq-primary);border-radius:6px;font-size:10.5px;font-weight:600;border:1px solid #bfdbfe;white-space:nowrap}.eq-none{color:var(--eq-tx3);font-size:12px}.eq-date{display:flex;flex-direction:column;gap:2px}.eq-date__main{font-size:12.5px;font-weight:600;color:var(--eq-tx1)}.eq-date__time{font-size:11px;color:var(--eq-tx3)}.eq-followup-yes{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:#92400e;background:var(--eq-amber-lt);padding:3px 8px;border-radius:6px;border:1px solid #fde68a}.eq-followup-no{font-size:12px;color:var(--eq-tx3)}.eq-resolved{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;color:var(--eq-green)}.eq-pending{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;color:var(--eq-tx3)}.eq-actions{display:flex;gap:6px;align-items:center}.eq-action-btn{width:34px;height:34px;border-radius:8px;border:1.5px solid var(--eq-border);background:var(--eq-card);color:var(--eq-tx2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.eq-action-btn:hover{background:var(--eq-primary-lt);color:var(--eq-primary);border-color:var(--eq-primary);transform:translateY(-1px)}.eq-action-btn--hist:hover{background:var(--eq-amber-lt);color:var(--eq-amber);border-color:var(--eq-amber)}.eq-pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--eq-border);background:#fafbfc;flex-wrap:wrap;gap:12px}.eq-pagination__info{font-size:12px;color:var(--eq-tx3)}.eq-pagination__btns{display:flex;gap:5px;align-items:center}.eq-pg-btn{min-width:34px;height:34px;padding:0 8px;border-radius:8px;border:1.5px solid var(--eq-border);background:var(--eq-card);color:var(--eq-tx2);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .18s;font-family:inherit}.eq-pg-btn:hover:not(:disabled){border-color:var(--eq-primary);color:var(--eq-primary);background:var(--eq-primary-lt)}.eq-pg-btn--active{background:var(--eq-primary);color:#fff;border-color:var(--eq-primary)}.eq-pg-btn:disabled{opacity:.4;cursor:not-allowed}.eq-pg-ellipsis{font-size:13px;color:var(--eq-tx3);padding:0 4px}.eq-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--eq-radius-sm);border:none;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap;line-height:1}.eq-btn--sm{font-size:12px;padding:7px 14px}.eq-btn--xs{font-size:11px;padding:5px 10px}.eq-btn--primary{background:var(--eq-primary);color:#fff}.eq-btn--primary:hover:not(:disabled){background:#1e40af;transform:translateY(-1px);box-shadow:0 4px 12px #1d4ed84d}.eq-btn--ghost{background:transparent;color:var(--eq-tx2);border:1.5px solid var(--eq-border)}.eq-btn--ghost:hover:not(:disabled){background:var(--eq-bg);border-color:var(--eq-tx2);color:var(--eq-tx1)}.eq-btn--outline{background:transparent;color:var(--eq-primary);border:1.5px solid var(--eq-primary)}.eq-btn--outline:hover:not(:disabled){background:var(--eq-primary-lt)}.eq-btn:disabled{opacity:.5;cursor:not-allowed}.eq-rotate{transform:rotate(180deg)}.eq-modal-bg{position:fixed;inset:0;background:#0f172a8c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;animation:eq-fade-in .2s ease}@keyframes eq-fade-in{0%{opacity:0}to{opacity:1}}.eq-modal{background:var(--eq-card);border-radius:20px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--eq-shadow-lg);animation:eq-modal-up .28s cubic-bezier(.34,1.56,.64,1);border:1px solid var(--eq-border)}@keyframes eq-modal-up{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.eq-modal__head{display:flex;align-items:center;justify-content:space-between;padding:22px 26px 10px}.eq-modal__title{font-size:17px;font-weight:700;color:var(--eq-tx1);display:flex;align-items:center;gap:8px}.eq-modal__close{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--eq-border);background:var(--eq-bg);color:var(--eq-tx2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.eq-modal__close:hover{background:var(--eq-red-lt);color:var(--eq-red);border-color:var(--eq-red);transform:rotate(90deg)}.eq-modal__visitor{display:flex;align-items:center;gap:8px;margin:0 26px 14px;padding:10px 14px;background:var(--eq-primary-lt);border-radius:10px;font-size:12.5px;color:var(--eq-primary);font-weight:500;flex-wrap:wrap}.eq-modal__body{padding:8px 26px 16px}.eq-modal__foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 26px 22px;border-top:1px solid var(--eq-border)}.eq-field{margin-bottom:20px}.eq-field--row{display:flex;align-items:center}.eq-field--indent{margin-left:18px;padding-left:16px;border-left:3px solid var(--eq-amber)}.eq-field--err .eq-cat-grid,.eq-field--err .eq-status-grid{border-color:var(--eq-red)}.eq-label{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--eq-tx2);margin-bottom:10px;text-transform:uppercase;letter-spacing:.4px}.eq-req{color:var(--eq-red);font-size:14px}.eq-optional{font-size:10px;font-weight:500;color:var(--eq-tx3);background:var(--eq-bg);padding:2px 6px;border-radius:4px}.eq-cat-grid{display:flex;flex-wrap:wrap;gap:8px;padding:12px;background:var(--eq-bg);border:1.5px solid var(--eq-border);border-radius:10px}.eq-cat-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;border:1.5px solid var(--eq-border);background:var(--eq-card);color:var(--eq-tx2);font-size:12px;font-weight:500;cursor:pointer;transition:all .18s;font-family:inherit}.eq-cat-btn:hover{border-color:var(--eq-primary);color:var(--eq-primary);background:var(--eq-primary-lt)}.eq-cat-btn--on{background:var(--eq-primary);color:#fff;border-color:var(--eq-primary)}.eq-status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}.eq-status-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 12px;border-radius:9px;border:1.5px solid var(--eq-border);background:var(--eq-card);color:var(--eq-tx2);font-size:12.5px;font-weight:500;cursor:pointer;transition:all .18s;font-family:inherit;position:relative}.eq-status-btn--on.eq-status-btn--amber{background:var(--eq-amber-lt);color:#92400e;border-color:var(--eq-amber)}.eq-status-btn--on.eq-status-btn--green{background:var(--eq-green-lt);color:#14532d;border-color:var(--eq-green)}.eq-status-btn--on.eq-status-btn--blue{background:var(--eq-blue-lt);color:#1e40af;border-color:var(--eq-blue)}.eq-status-btn--on.eq-status-btn--slate{background:var(--eq-slate-lt);color:var(--eq-slate);border-color:var(--eq-slate)}.eq-status-btn--on.eq-status-btn--red{background:var(--eq-red-lt);color:#991b1b;border-color:var(--eq-red)}.eq-status-btn:hover:not(.eq-status-btn--on){border-color:var(--eq-primary);color:var(--eq-primary);background:var(--eq-primary-lt)}.eq-terminal-dot{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.5;margin-left:2px}.eq-textarea{width:100%;padding:10px 14px;background:var(--eq-bg);border:1.5px solid var(--eq-border);border-radius:10px;font-size:13px;color:var(--eq-tx1);outline:none;resize:vertical;min-height:72px;font-family:inherit;transition:border-color .2s,box-shadow .2s;line-height:1.6}.eq-textarea:focus{border-color:var(--eq-primary);box-shadow:0 0 0 3px var(--eq-primary-lt)}.eq-switch-label{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:var(--eq-tx1);cursor:pointer;-webkit-user-select:none;user-select:none}.eq-switch-wrap{position:relative;display:inline-block}.eq-switch-wrap input{opacity:0;width:0;height:0;position:absolute}.eq-switch{display:block;width:44px;height:24px;background:#cbd5e1;border-radius:30px;transition:background .25s;position:relative}.eq-switch:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 3px #0003}.eq-switch-wrap input:checked+.eq-switch{background:var(--eq-primary)}.eq-switch-wrap input:checked+.eq-switch:after{transform:translate(20px)}.eq-err-msg{font-size:11px;color:var(--eq-red);margin-top:5px;display:block}.eq-drawer-bg{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;justify-content:flex-end;animation:eq-fade-in .2s ease}.eq-drawer{width:100%;max-width:480px;height:100%;background:var(--eq-card);display:flex;flex-direction:column;animation:eq-drawer-in .28s ease;border-left:1px solid var(--eq-border);box-shadow:-20px 0 60px #0f172a26}@keyframes eq-drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.eq-drawer__head{display:flex;align-items:center;justify-content:space-between;padding:22px 24px;border-bottom:1px solid var(--eq-border);font-size:15px;font-weight:700;color:var(--eq-tx1);flex-shrink:0}.eq-drawer__head>span{display:flex;align-items:center;gap:8px}.eq-drawer__body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:16px}.eq-hist-card{background:var(--eq-bg);border:1.5px solid var(--eq-border);border-radius:var(--eq-radius-sm);padding:14px 16px;display:flex;flex-direction:column;gap:8px}.eq-hist-card__top{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.eq-hist-date{font-size:11px;color:var(--eq-tx3)}.eq-hist-card__visit{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--eq-primary);font-weight:500}.eq-hist-remarks{font-size:12px;color:var(--eq-tx2);font-style:italic;margin:0;padding:6px 10px;background:var(--eq-card);border-radius:6px;border-left:3px solid var(--eq-primary);line-height:1.5}.eq-hist-card__by{font-size:11px;color:var(--eq-tx3)}.eq-hist-followup{display:flex;align-items:center;gap:5px;font-size:11px;color:#92400e;background:var(--eq-amber-lt);padding:4px 8px;border-radius:5px}.eq-toast-wrap{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.eq-toast{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--eq-card);border-radius:10px;box-shadow:0 8px 24px #0f172a2e;min-width:280px;max-width:380px;animation:eq-toast-in .3s ease;border-left:4px solid var(--eq-primary);pointer-events:all}.eq-toast--success{border-left-color:var(--eq-green)}.eq-toast--error{border-left-color:var(--eq-red)}.eq-toast--info{border-left-color:var(--eq-primary)}.eq-toast__icon{flex-shrink:0;display:flex;align-items:center}.eq-toast--success .eq-toast__icon{color:var(--eq-green)}.eq-toast--error .eq-toast__icon{color:var(--eq-red)}.eq-toast--info .eq-toast__icon{color:var(--eq-primary)}.eq-toast__msg{flex:1;font-size:13px;font-weight:500;color:var(--eq-tx1);line-height:1.45}.eq-toast__close{background:none;border:none;color:var(--eq-tx3);cursor:pointer;display:flex;align-items:center;border-radius:4px;padding:2px;transition:color .15s}.eq-toast__close:hover{color:var(--eq-tx1)}@keyframes eq-toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.eq-loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--eq-tx3)}.eq-spin{animation:eq-spin-anim .7s linear infinite}@keyframes eq-spin-anim{to{transform:rotate(360deg)}}@media(max-width:1100px){.eq-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.eq-header{flex-direction:column;padding-top:20px}.eq-header__actions{width:100%}.eq-stats{grid-template-columns:1fr 1fr;gap:10px}.eq-filters__inner{flex-direction:column;align-items:stretch}.eq-search-wrap,.eq-filter-group,.eq-select{width:100%}.eq-table thead th:nth-child(5),.eq-table tbody td:nth-child(5){display:none}.eq-drawer{max-width:100%}.eq-modal{max-width:100%;border-radius:16px 16px 0 0;margin-top:auto}.eq-modal-bg{align-items:flex-end;padding:0}}@media(max-width:480px){.eq-stats{grid-template-columns:1fr}}@media print{.eq-header__actions,.eq-filters,.eq-actions,.eq-pagination,.eq-toast-wrap,.eq-modal-bg,.eq-drawer-bg{display:none!important}}
