:root{--bg: #f5f6fa;--bg-grad: linear-gradient(160deg, #eef2ff 0%, #f5f6fa 60%, #f8fafc 100%);--surface: #ffffff;--surface-2: #f9fafb;--fg: #0f172a;--fg-soft: #334155;--muted: #64748b;--muted-2: #94a3b8;--border: #e2e8f0;--border-strong: #cbd5e1;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-soft: #dbeafe;--primary-fg: #1e3a8a;--danger: #dc2626;--danger-soft: #fee2e2;--success: #15803d;--success-soft: #dcfce7;--warning: #b45309;--warning-soft: #fef3c7;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow-md: 0 4px 12px rgba(15, 23, 42, .08);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .12);--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%}body{font-family:var(--font);background:var(--bg-grad);color:var(--fg);line-height:1.55;-webkit-font-smoothing:antialiased;font-feature-settings:"cv11","ss01"}.container{max-width:1120px;margin:0 auto;padding:2.25rem 1.5rem}.container.narrow{max-width:460px}.row{display:flex;gap:.75rem;align-items:center}.row-between{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:1.5rem}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.25rem;width:100%;max-width:420px;display:flex;flex-direction:column;gap:1rem}.auth-card h1{margin:0;font-size:1.5rem;letter-spacing:-.01em}.auth-card .auth-sub{color:var(--muted);margin:-.25rem 0 .25rem}.brand-mark{display:inline-flex;align-items:center;gap:.55rem;font-weight:700;letter-spacing:-.01em;color:var(--fg);margin-bottom:.25rem}.brand-mark svg{width:28px;height:28px}.brand-mark .brand-name{font-size:1.05rem}.site-header{background:#ffffffd9;-webkit-backdrop-filter:saturate(140%) blur(8px);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.site-header.admin{background:linear-gradient(180deg,#0b1220,#0f172a);color:#e2e8f0;border-bottom:1px solid #1e293b}.site-header.admin a,.site-header.admin button.link-button{color:#cbd5e1}.site-header.admin a:hover,.site-header.admin button.link-button:hover{color:#fff}.brand{font-weight:700;text-decoration:none;color:inherit;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:.5rem}.brand svg{width:22px;height:22px}.site-header nav{display:flex;gap:1.25rem;align-items:center}.site-header nav a{color:var(--fg-soft);text-decoration:none;font-size:.92rem;padding:.35rem .6rem;border-radius:var(--radius-sm)}.site-header nav a:hover{background:#0f172a0a}.site-header.admin nav a:hover{background:#ffffff0f}.site-header.admin nav a.active{background:#ffffff1a;color:#fff}.link-button.danger,.nav-logout{color:var(--danger)!important}.site-header.admin .nav-logout{color:#fca5a5!important}.site-header.admin .nav-logout:hover{color:#fecaca!important;background:#dc262626}@media (max-width: 720px){.site-header{flex-direction:column;align-items:stretch;gap:.5rem;padding:.6rem .85rem}.brand .brand-name,.brand span{font-size:.95rem}.site-header nav{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;gap:.4rem;padding-bottom:4px;margin:0 -.25rem;padding-left:.25rem;padding-right:.25rem;scrollbar-width:none;-webkit-overflow-scrolling:touch;align-items:center;justify-content:flex-start}.site-header nav::-webkit-scrollbar{display:none}.site-header nav a,.site-header nav button.link-button{flex:0 0 auto;padding:.45rem .85rem;font-size:.86rem;font-weight:500;border-radius:999px;background:var(--surface-2);color:var(--fg-soft);white-space:nowrap;text-decoration:none;border:1px solid var(--border)}.site-header nav a.active{background:var(--primary);border-color:var(--primary);color:#fff}.site-header.admin nav a,.site-header.admin nav button.link-button{background:#ffffff14;color:#e2e8f0;border-color:#ffffff1f}.site-header.admin nav a.active{background:#ffffff2e;border-color:#ffffff4d;color:#fff}.site-header nav .nav-logout{background:var(--danger-soft);border-color:#fecaca}.site-header.admin nav .nav-logout{background:#dc262626;border-color:#dc262659}}.site-footer{text-align:center;padding:2.5rem 1rem;color:var(--muted);font-size:.85rem}h1{margin-top:0;letter-spacing:-.015em;font-weight:700}h1.page-title{font-size:1.6rem;margin-bottom:.25rem}.page-sub{color:var(--muted);margin-top:0;margin-bottom:1.5rem}.muted{color:var(--muted);font-size:.9rem}.req{color:var(--danger)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.35rem 1.5rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem}label{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;font-weight:500;color:var(--fg-soft)}label.checkbox{flex-direction:row;align-items:center;gap:.55rem;font-weight:500}input[type=text],input[type=email],input[type=tel],input[type=password]{padding:.65rem .8rem;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font:inherit;color:var(--fg);background:#fff;transition:border-color .15s ease,box-shadow .15s ease;width:100%}input:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb2e}input::placeholder{color:var(--muted-2)}select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding:.65rem 2.4rem .65rem .8rem;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background-color:#fff;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2.5 4.5l3.5 3.5 3.5-3.5' stroke='%2364748b' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right .85rem center;background-size:12px 12px;font:inherit;color:var(--fg);cursor:pointer;width:100%;transition:border-color .15s,box-shadow .15s}select:hover{border-color:var(--muted-2)}select[disabled]{background-color:var(--surface-2);color:var(--muted);cursor:not-allowed}.search-input{width:260px;max-width:100%;flex:1 1 200px}.password-input{position:relative;width:100%}.password-input input{width:100%;padding-right:2.6rem}.password-toggle{position:absolute;right:.35rem;top:50%;transform:translateY(-50%);width:32px;height:32px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:background .12s,color .12s,border-color .12s}.password-toggle:hover{background:var(--surface-2);border-color:var(--border);color:var(--fg)}.password-toggle:active{transform:translateY(-50%) scale(.94)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1.05rem;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:#fff;font:inherit;font-weight:500;cursor:pointer;text-decoration:none;color:var(--fg);transition:background .12s ease,border-color .12s ease,transform .04s ease}.btn:hover{background:var(--surface-2);border-color:var(--muted-2)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 1px #fff3 inset,var(--shadow-sm)}.btn.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn.full{width:100%}.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none}.btn.ghost{background:transparent;border-color:transparent;color:var(--primary)}.btn.ghost:hover{background:var(--primary-soft)}.link-button{background:none;border:none;cursor:pointer;color:var(--primary);font:inherit;padding:0}.link-button:hover{text-decoration:underline}.link-button.danger{color:var(--danger)}.notice{padding:.7rem .9rem;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:.9rem;display:flex;align-items:flex-start;gap:.55rem}.notice.error{background:var(--danger-soft);border-color:#fecaca;color:#991b1b}.notice.success{background:var(--success-soft);border-color:#bbf7d0;color:#166534}.notice.info{background:var(--primary-soft);border-color:#bfdbfe;color:var(--primary-fg)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.stat{padding:1.25rem 1.35rem;gap:.4rem;position:relative;overflow:hidden}.stat .stat-label{color:var(--muted);font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.stat .stat-value{font-size:2.1rem;font-weight:700;letter-spacing:-.02em;color:var(--fg)}.stat .stat-icon{position:absolute;top:1.1rem;right:1.1rem;width:38px;height:38px;border-radius:10px;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center}.stat .stat-icon svg{width:20px;height:20px}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.92rem}.data-table th,.data-table td{text-align:left;padding:.75rem .85rem;border-bottom:1px solid var(--border)}.data-table th{background:var(--surface-2);font-size:.78rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.data-table tbody tr:hover{background:var(--surface-2)}.data-table tbody tr:last-child td{border-bottom:none}.data-table .actions{display:flex;gap:.6rem;align-items:center}.data-table .actions a,.data-table .actions button{font-size:.88rem;color:var(--primary);text-decoration:none;background:none;border:none;padding:0;cursor:pointer;font:inherit;font-weight:500}.data-table .actions a:hover,.data-table .actions button:hover{text-decoration:underline}.data-table .actions button.danger{color:var(--danger)}.badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge.active{background:var(--success-soft);color:var(--success)}.badge.disabled{background:#f1f5f9;color:var(--muted)}.empty-state{text-align:center;color:var(--muted);padding:3rem 1rem}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.device-card{display:flex;flex-direction:column;gap:.85rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem;box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease}.device-card:hover{transform:translateY(-2px);border-color:var(--border-strong);box-shadow:var(--shadow-md)}.device-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.device-id{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:600;font-size:1.02rem;letter-spacing:-.01em}.device-asset{font-size:.85rem;margin-top:.1rem}.device-card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem}.device-stat{background:var(--surface-2);border-radius:8px;padding:.6rem .7rem}.device-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:500}.device-stat-value{font-size:1.15rem;font-weight:600;margin-top:2px;color:var(--fg)}.device-card-foot{display:flex;justify-content:space-between;gap:.5rem;font-size:.78rem;padding-top:.4rem;border-top:1px dashed var(--border)}.agg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.chart-wrap{position:relative;width:100%}.chart-svg{display:block;width:100%;height:220px;font-family:var(--font)}.chart-empty{padding:2rem 1rem;text-align:center;color:var(--muted);font-size:.9rem}.chart-tooltip{position:absolute;top:0;transform:translate(-50%);background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:var(--shadow-md);padding:.45rem .65rem;font-size:.78rem;pointer-events:none;white-space:nowrap;z-index:1}.chart-tooltip-time{color:var(--muted)}.chart-tooltip-value{font-weight:600;font-size:.92rem;margin-top:1px}.chart-tabs{display:inline-flex;border:1px solid var(--border);border-radius:999px;padding:3px;background:var(--surface-2);gap:2px}.chart-tabs button{border:none;background:transparent;padding:.35rem .85rem;font:inherit;font-size:.82rem;border-radius:999px;cursor:pointer;color:var(--muted);transition:background .15s,color .15s}.chart-tabs button.active{background:var(--surface);color:var(--fg);box-shadow:var(--shadow-sm)}.pagination{display:flex;gap:.25rem;align-items:center;flex-wrap:wrap;padding:.85rem 1rem;border-top:1px solid var(--border);background:var(--surface-2)}.page-btn{border:1px solid var(--border);background:#fff;color:var(--fg-soft);padding:.35rem .65rem;border-radius:6px;font:inherit;font-size:.85rem;cursor:pointer;min-width:32px;transition:background .12s,border-color .12s,color .12s}.page-btn:hover:not([disabled]){background:var(--surface-2);border-color:var(--muted-2);color:var(--fg)}.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.page-btn[disabled]{opacity:.45;cursor:not-allowed}.page-ellipsis{color:var(--muted);padding:0 .4rem}.iframe-shell{padding:0;overflow:hidden;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.iframe-track{display:block;width:100%;height:560px;border:0}@media (max-width: 720px){.iframe-track{height:420px}}@media (max-width: 480px){.iframe-track{height:360px}}.iframe-loading{padding:1.25rem 1.4rem;color:var(--muted)}.iframe-fallback{padding:1.25rem 1.4rem;display:flex;gap:.85rem;align-items:flex-start;background:linear-gradient(180deg,#fff 0%,var(--surface-2) 100%)}.iframe-fallback-icon{width:38px;height:38px;border-radius:10px;background:var(--surface-2);color:var(--muted);display:grid;place-items:center;flex-shrink:0}.iframe-mode-note{background:var(--warning-soft);color:var(--warning);border-bottom:1px solid #fde68a;padding:.6rem .95rem;font-size:.82rem;line-height:1.45}.iframe-toolbar{display:flex;justify-content:space-between;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.7rem 1rem;border-bottom:1px solid var(--border);background:var(--surface-2)}.iframe-toolbar-left{display:flex;align-items:center;gap:.6rem}.iframe-fallback code{background:var(--surface-2);padding:.05rem .35rem;border-radius:4px;font-size:.85em}.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0;position:relative}.status-dot.live{background:var(--success);box-shadow:0 0 0 3px #15803d1f}.status-dot.live:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;border:2px solid var(--success);opacity:.5;animation:statusPulse 1.8s ease-out infinite}.status-dot.stale{background:var(--muted-2)}@keyframes statusPulse{0%{transform:scale(.8);opacity:.6}to{transform:scale(1.9);opacity:0}}.device-id-cell{display:flex;align-items:center;gap:.7rem}.device-id-mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:600;letter-spacing:-.01em;color:var(--fg)}.device-sub{font-size:.78rem;margin-top:1px}.user-cell{display:flex;align-items:center;gap:.65rem}.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:.78rem;font-weight:600;letter-spacing:.02em;flex-shrink:0;text-transform:uppercase;box-shadow:0 1px #ffffff40 inset,0 1px 2px #0f172a14}.user-name{font-weight:500;font-size:.9rem;line-height:1.25}.user-email{font-size:.75rem;line-height:1.2;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar-stack{display:inline-flex;flex-direction:row}.avatar-stack .avatar{border:2px solid var(--surface);margin-left:-10px}.avatar-stack .avatar:first-child{margin-left:0}.avatar.avatar-sm{width:28px;height:28px;font-size:.7rem}.avatar-more{background:var(--surface-2)!important;color:var(--muted)!important;font-weight:600}.assignment-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.assignment-list li{display:flex;align-items:center;justify-content:space-between;padding:.55rem .7rem;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.chip-unassigned{display:inline-block;padding:.25rem .65rem;border-radius:999px;background:var(--surface-2);color:var(--muted);font-size:.75rem;font-weight:500;border:1px dashed var(--border-strong)}.row-actions{display:inline-flex;gap:.3rem;align-items:center}.icon-btn{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--muted);cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease,transform .04s;text-decoration:none}.icon-btn:hover{background:var(--surface-2);border-color:var(--border);color:var(--primary)}.icon-btn:active{transform:scale(.94)}.icon-btn.danger:hover{color:var(--danger);border-color:#fecaca;background:var(--danger-soft)}.icon-btn[disabled]{opacity:.4;cursor:not-allowed}.devices-table th,.devices-table td{padding:.75rem .95rem}.devices-table .device-sub{white-space:normal}@media (max-width: 600px){.row-actions{gap:.15rem}.icon-btn{width:30px;height:30px}.avatar{width:30px;height:30px;font-size:.72rem}}dialog{border:none;border-radius:var(--radius-lg);padding:0;width:calc(100% - 2rem);max-width:460px;box-shadow:var(--shadow-lg);background:var(--surface);color:var(--fg)}dialog::backdrop{background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease both}dialog .card{margin:0;border:none;box-shadow:none;padding:1.5rem}dialog menu{display:flex;justify-content:flex-end;gap:.5rem;padding:0;margin:0;flex-wrap:wrap}@media (max-width: 480px){dialog{border-radius:var(--radius)}dialog .card{padding:1.1rem}dialog menu{flex-direction:column-reverse}dialog menu .btn{width:100%}}.divider{height:1px;background:var(--border);margin:.25rem 0}.inline-link{color:var(--primary);text-decoration:none;font-weight:500}.inline-link:hover{text-decoration:underline}.captcha-slot{display:flex;justify-content:center;min-height:0}.captcha-slot:empty{display:none}.captcha-box{display:flex;flex-direction:column;gap:.55rem}.captcha-image-row{display:flex;align-items:center;gap:.5rem}.captcha-image{display:block;width:200px;height:64px;border-radius:6px;background:#fff;border:1px solid var(--border);-webkit-user-select:none;user-select:none}.captcha-placeholder{display:grid;place-items:center;font-size:.8rem;color:var(--muted-2)}.captcha-refresh{background:transparent;border:1px solid transparent;width:32px;height:32px;border-radius:6px;display:grid;place-items:center;cursor:pointer;color:var(--muted);transition:background .12s,color .12s,border-color .12s}.captcha-refresh:hover{background:var(--surface-2);border-color:var(--border);color:var(--primary)}.captcha-help{margin:0;font-size:.82rem;color:var(--muted);font-weight:400}.captcha-input{padding:.55rem .7rem;background:#fff;font-size:.95rem}.spin{width:14px;height:14px;border-radius:50%;border:2px solid currentColor;border-right-color:transparent;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:none}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-18px)}to{opacity:1;transform:none}}@keyframes fadeInRight{0%{opacity:0;transform:translate(18px)}to{opacity:1;transform:none}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.55}}@keyframes splashPulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}@keyframes barIndet{0%{left:-40%;width:40%}50%{width:50%}to{left:100%;width:40%}}.anim-in{animation:fadeInUp .55s cubic-bezier(.2,.7,.2,1) both}.anim-in-down{animation:fadeInDown .5s cubic-bezier(.2,.7,.2,1) both}.anim-in-left{animation:fadeInLeft .6s cubic-bezier(.2,.7,.2,1) both}.anim-in-right{animation:fadeInRight .6s cubic-bezier(.2,.7,.2,1) both}.anim-fade{animation:fadeIn .4s ease both}.anim-scale{animation:scaleIn .45s cubic-bezier(.2,.7,.2,1) both}.anim-d1{animation-delay:60ms}.anim-d2{animation-delay:.12s}.anim-d3{animation-delay:.18s}.anim-d4{animation-delay:.24s}.anim-d5{animation-delay:.3s}.anim-d6{animation-delay:.36s}.anim-d7{animation-delay:.42s}.anim-d8{animation-delay:.48s}.stagger>*{animation:fadeInUp .55s cubic-bezier(.2,.7,.2,1) both}.stagger>*:nth-child(1){animation-delay:40ms}.stagger>*:nth-child(2){animation-delay:90ms}.stagger>*:nth-child(3){animation-delay:.14s}.stagger>*:nth-child(4){animation-delay:.19s}.stagger>*:nth-child(5){animation-delay:.24s}.stagger>*:nth-child(6){animation-delay:.29s}.stagger>*:nth-child(7){animation-delay:.34s}.stagger>*:nth-child(8){animation-delay:.39s}.stagger>*:nth-child(9){animation-delay:.44s}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:grid;place-items:center;background:linear-gradient(160deg,#1e3a8a,#1d4ed8 60%,#2563eb);color:#fff}.splash.is-out{animation:fadeOut .35s ease forwards;pointer-events:none}.splash-inner{display:flex;flex-direction:column;align-items:center;gap:1rem;animation:scaleIn .5s cubic-bezier(.2,.7,.2,1) both}.splash-mark{width:72px;height:72px;background:#ffffff29;border-radius:18px;display:grid;place-items:center;box-shadow:0 12px 40px #0000002e,inset 0 1px #ffffff40;animation:splashPulse 2.2s ease-in-out infinite}.splash-mark svg{width:40px;height:40px}.splash-name{font-size:1.05rem;font-weight:600;letter-spacing:.03em;opacity:.95}.splash-bar{width:160px;height:3px;border-radius:999px;background:#ffffff2e;position:relative;overflow:hidden}.splash-bar:after{content:"";position:absolute;top:0;bottom:0;left:-40%;width:40%;border-radius:999px;background:#ffffffd9;animation:barIndet 1.3s ease-in-out infinite}.top-progress{position:fixed;top:0;left:0;right:0;height:2.5px;z-index:9000;background:transparent;pointer-events:none;opacity:0;transition:opacity .15s ease}.top-progress.is-active{opacity:1}.top-progress:after{content:"";position:absolute;top:0;bottom:0;background:linear-gradient(90deg,var(--primary),#60a5fa);border-radius:0 2px 2px 0;box-shadow:0 0 8px #2563eb80;animation:barIndet 1s ease-in-out infinite}.page-fade{animation:fadeIn .35s ease both}.skeleton{background:linear-gradient(90deg,#eef2f7 25%,#f7f9fc,#eef2f7 75%);background-size:200% 100%;animation:shimmer 1.4s linear infinite;border-radius:6px;display:inline-block}.sk-line{height:.85rem;width:100%}.sk-line.short{width:40%}.sk-line.mid{width:65%}.sk-title{height:1.4rem;width:50%}.sk-circle{width:38px;height:38px;border-radius:50%}.sk-rect{height:2.2rem;width:100%;border-radius:8px}.sk-row td{padding:.85rem}.sk-row .skeleton{display:block}.login-split{min-height:100vh;display:grid;grid-template-columns:1fr;background:var(--bg-grad)}@media (min-width: 980px){.login-split{grid-template-columns:1.1fr 1fr}}.login-form-pane{display:grid;place-items:center;padding:2.5rem 1.5rem}.login-form-pane .auth-card{animation:fadeInUp .55s cubic-bezier(.2,.7,.2,1) both;box-shadow:var(--shadow-md)}.login-hero-pane{display:none;position:relative;overflow:hidden;background:#0f172a;color:#fff}@media (min-width: 980px){.login-hero-pane{display:block}}.login-hero-img{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;transform:scale(1.04);animation:heroKenBurns 18s ease-in-out infinite alternate,fadeIn .8s ease both;filter:saturate(.85) brightness(.55)}@keyframes heroKenBurns{0%{transform:scale(1.04)}to{transform:scale(1.12) translate(-2%,-1%)}}.login-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0f172a00,#0f172a8c 60%,#0f172ad9),radial-gradient(60% 50% at 30% 30%,#3b82f64d,#3b82f600)}.login-hero-content{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:space-between;height:100%;padding:2.5rem 3rem}.login-hero-content .brand-mark{color:#fff;animation:fadeInDown .5s ease both}.login-hero-content .brand-mark .brand-name{font-size:1.1rem}.login-hero-body{max-width:28rem}.login-hero-body h2{font-size:2rem;line-height:1.2;margin:0 0 .75rem;letter-spacing:-.02em;font-weight:700;animation:fadeInUp .6s cubic-bezier(.2,.7,.2,1) both;animation-delay:.15s}.login-hero-body p{font-size:1rem;line-height:1.6;color:#cbd5e1;margin:0;animation:fadeInUp .6s cubic-bezier(.2,.7,.2,1) both;animation-delay:.28s}.login-hero-bullets{list-style:none;padding:0;margin:1.5rem 0 0;display:flex;flex-direction:column;gap:.55rem;animation:fadeInUp .6s cubic-bezier(.2,.7,.2,1) both;animation-delay:.42s}.login-hero-bullets li{display:flex;align-items:center;gap:.55rem;color:#e2e8f0;font-size:.92rem}.login-hero-bullets svg{width:16px;height:16px;color:#93c5fd;flex-shrink:0}.login-hero-foot{font-size:.78rem;color:#94a3b8;animation:fadeIn .8s ease both;animation-delay:.6s}.card{overflow-x:auto}@media (max-width: 720px){.container{padding:1.25rem .85rem}.site-header{padding:.6rem .85rem}.brand .brand-name,.brand span{font-size:.95rem}.row-between{flex-direction:column;align-items:stretch}.row-between>*{width:100%}.row{flex-wrap:wrap}.row>.search-input{width:100%}.row>.btn,.row>a.btn{flex:1 1 auto;text-align:center;justify-content:center}}@media (max-width: 600px){.data-table{font-size:.85rem}.data-table th,.data-table td{padding:.55rem .6rem;white-space:nowrap}.data-table .actions{gap:.55rem}}@media (max-width: 640px){.stat .stat-value{font-size:1.7rem}h1{font-size:1.4rem}.login-form-pane{padding:1.5rem 1rem}.auth-card{padding:1.5rem}}
