*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif;background:#f5f6fa;color:#2c3e50}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f1729,#1a2744,#0d2137 60%,#0f1729);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 30% 50%,rgba(56,189,248,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 20%,rgba(14,165,233,.04) 0%,transparent 50%)}.login-card{position:relative;z-index:1;background:#fffffff2;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:48px 40px;width:420px;box-shadow:0 8px 48px #00000040,0 0 0 1px #38bdf81a}.login-card h1{font-size:24px;text-align:center;background:linear-gradient(135deg,#0ea5e9,#38bdf8);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px;font-weight:700}.login-card .subtitle{text-align:center;color:#94a3b8;font-size:14px;margin-bottom:32px}.form-item{margin-bottom:20px}.form-item label{display:block;margin-bottom:6px;font-size:14px;color:#475569;font-weight:500}.form-item input{width:100%;padding:12px 16px;border:1.5px solid #e2e8f0;border-radius:10px;background:#f8fafc;color:#1e293b;font-size:15px;transition:border-color .2s,box-shadow .2s}.form-item input:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a}button[type=submit]{width:100%;padding:13px;background:linear-gradient(135deg,#0ea5e9,#38bdf8);border:none;border-radius:10px;font-size:16px;font-weight:700;color:#fff;cursor:pointer;margin-top:8px;transition:all .3s;letter-spacing:1px}button[type=submit]:hover{transform:translateY(-1px);box-shadow:0 6px 24px #0ea5e959}button[type=submit]:disabled{opacity:.5;cursor:not-allowed;transform:none}.error{color:#ef4444;text-align:center;margin-top:12px;font-size:14px}.layout{display:flex;min-height:100vh}.sidebar{width:232px;background:#fff;border-right:1px solid #e8ecf1;display:flex;flex-direction:column;flex-shrink:0;box-shadow:2px 0 12px #00000008}.sidebar .logo{padding:22px 20px;font-size:16px;font-weight:700;background:linear-gradient(135deg,#0ea5e9,#38bdf8);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;gap:10px}.sidebar .logo .icon{font-size:22px}.menu{flex:1;padding:12px 0}.menu-item{display:flex;align-items:center;gap:12px;padding:11px 20px;margin:2px 12px;color:#64748b;border-radius:8px;text-decoration:none;font-size:14px;transition:all .25s}.menu-item:hover{background:#f0f9ff;color:#0ea5e9}.menu-item.router-link-active{background:linear-gradient(135deg,#0ea5e91a,#38bdf80f);color:#0ea5e9;font-weight:600;box-shadow:inset 3px 0 #0ea5e9}.user-info{padding:16px 20px;border-top:1px solid #f1f5f9;font-size:13px;color:#94a3b8;display:flex;justify-content:space-between;align-items:center}.user-info button{padding:4px 12px;background:#fff;border:1px solid #e2e8f0;color:#64748b;border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s}.user-info button:hover{border-color:#ef4444;color:#ef4444;background:#fef2f2}.content{flex:1;padding:28px;overflow-y:auto;background:#f5f6fa}.dashboard h2{font-size:22px;margin-bottom:24px;color:#1e293b;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:32px}.stat-card{display:block;background:#fff;border:1px solid #e8ecf1;border-radius:14px;padding:24px 20px;text-align:center;text-decoration:none;transition:all .3s;box-shadow:0 2px 8px #00000008;position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#0ea5e9,#38bdf8);opacity:0;transition:opacity .3s}.stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px #00000014;border-color:#bae6fd}.stat-card:hover:after{opacity:1}.stat-value{font-size:38px;font-weight:800;color:#1e293b}.stat-label{font-size:13px;color:#94a3b8;margin-top:6px;font-weight:500}.stat-card.online .stat-value{color:#10b981}.stat-card.offline .stat-value{color:#ef4444}.quick-links h3{font-size:18px;margin-bottom:16px;color:#1e293b;font-weight:600}.links{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.link-card{display:flex;flex-direction:column;gap:8px;padding:22px 20px;background:#fff;border:1px solid #e8ecf1;border-radius:12px;text-decoration:none;transition:all .3s;box-shadow:0 2px 8px #00000008}.link-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px #0ea5e91a;border-color:#7dd3fc}.link-icon{font-size:30px}.link-title{font-size:16px;color:#1e293b;font-weight:600}.link-desc{font-size:13px;color:#94a3b8}.bigscreen-container{display:flex;flex-direction:column;height:calc(100vh - 56px)}.bigscreen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.bigscreen-header h2{font-size:20px;color:#1e293b;font-weight:700}.actions{display:flex;gap:8px}.actions button{padding:7px 18px;background:#fff;border:1px solid #e2e8f0;color:#475569;border-radius:8px;cursor:pointer;font-size:13px;transition:all .2s}.actions button:hover{background:#f0f9ff;border-color:#0ea5e9;color:#0ea5e9}.bigscreen-frame{flex:1;border-radius:10px;overflow:hidden;border:1px solid #e8ecf1;background:#fff;box-shadow:0 2px 12px #0000000a}.bigscreen-frame iframe{width:100%;height:100%}.admin-page{padding:4px}.admin-card{background:#fff;border-radius:12px;padding:24px;margin-bottom:20px;border:1px solid #e8ecf1;box-shadow:0 2px 8px #0000000a}.admin-card h3{margin:0 0 16px;font-size:16px;color:#1e293b}.admin-form{max-width:420px}.admin-form .form-item{margin-bottom:14px}.admin-form label{display:block;margin-bottom:5px;font-size:13px;color:#475569;font-weight:500}.form-input{width:100%;padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#1e293b;background:#fafbfc;box-sizing:border-box}.form-input:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a}.btn-primary{padding:9px 22px;background:#0ea5e9;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.btn-primary:hover{background:#0284c7}.btn-primary:disabled{background:#94a3b8;cursor:not-allowed}.btn-secondary{padding:9px 22px;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;cursor:pointer}.btn-secondary:hover{background:#e2e8f0}.btn-sm{padding:4px 12px;background:#f0f9ff;color:#0ea5e9;border:1px solid #bae6fd;border-radius:6px;font-size:12px;cursor:pointer;margin-right:6px}.btn-sm:hover{background:#e0f2fe}.btn-danger{color:#ef4444;border-color:#fecaca;background:#fef2f2}.btn-danger:hover{background:#fee2e2}.msg-ok{color:#16a34a;font-size:13px;margin-top:8px}.msg-err{color:#ef4444;font-size:13px;margin-top:8px}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:10px 14px;text-align:left;border-bottom:1px solid #f1f5f9;font-size:13px}.admin-table th{color:#64748b;font-weight:600;background:#f8fafc}.admin-table tr:hover{background:#f8fafc}.tag-ok{color:#16a34a;background:#f0fdf4;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500}.tag-fail{color:#ef4444;background:#fef2f2;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500}.action-cell{white-space:nowrap}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.info-item{padding:10px 0}.info-item label{display:block;font-size:12px;color:#94a3b8;margin-bottom:3px}.info-item span{font-size:14px;color:#1e293b}.modal-overlay{position:fixed;inset:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:#fff;border-radius:14px;padding:28px;width:440px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.wide-modal{width:800px}.modal-card h3{margin:0 0 20px;font-size:17px}.modal-actions{display:flex;gap:10px;margin-top:18px}.assign-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.assign-panel{border:1px solid #e8ecf1;border-radius:10px;padding:14px}.assign-panel h4{margin:0 0 10px;font-size:14px;color:#475569}.device-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid #f8fafc;font-size:13px}.device-row small{color:#94a3b8}.empty-hint{color:#94a3b8;font-size:13px;padding:12px 0}.menu-divider{border-top:1px solid rgba(255,255,255,.1);margin:8px 16px}.menu-label{padding:6px 20px;font-size:11px;color:#fff6;text-transform:uppercase;letter-spacing:1px}.row-locked{opacity:.5;background:#fefce8}.row-locked td{color:#a1a1aa!important}.tag-locked{color:#d97706;background:#fffbeb;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500;border:1px solid #fde68a}.assign-summary{display:flex;gap:16px;padding:12px 16px;background:#f8fafc;border-radius:8px;font-size:13px;color:#475569;margin-bottom:8px}
