:root{--bg:#f3f6fb;--surface:#ffffffeb;--surface-strong:#fff;--surface-muted:#eef3fb;--border:#dbe4f0;--text:#172033;--text-soft:#5c6b82;--primary:#2563eb;--primary-strong:#1d4ed8;--success:#16a34a;--danger:#dc2626;--warning:#d97706;--shadow:0 18px 50px #0f172a14;--radius-lg:20px;--radius-md:14px;--radius-sm:10px}*{box-sizing:border-box;margin:0;padding:0}#root,body,html{min-height:100%}body{background:radial-gradient(circle at top left,#2563eb26,#0000 28%),radial-gradient(circle at top right,#16a34a1f,#0000 22%),#f3f6fb;background:radial-gradient(circle at top left,#2563eb26,#0000 28%),radial-gradient(circle at top right,#16a34a1f,#0000 22%),var(--bg);color:#172033;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}button,input,select,textarea{font:inherit}button{transition:transform .15s ease,box-shadow .15s ease,background .15s ease}button:hover:not(:disabled){transform:translateY(-1px)}button:disabled{cursor:not-allowed;opacity:.55}input,select,textarea{background:#fff;border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:12px;color:#172033;color:var(--text);padding:12px 14px;width:100%}input:focus,select:focus,textarea:focus{border-color:#2563eb73;box-shadow:0 0 0 4px #2563eb1f;outline:none}textarea{min-height:120px;resize:vertical}.layout{display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#0f172a,#172554);box-shadow:8px 0 30px #0f172a40;color:#fff;display:flex;flex-direction:column;gap:22px;height:100vh;inset:0 auto 0 0;overflow-y:auto;padding:28px 22px;position:fixed;width:280px}.logo{padding:10px 6px 0}.logo h1{font-size:34px;letter-spacing:.08em}.logo span{color:#ffffffb8;display:inline-block;font-size:13px;margin-top:6px}.device-summary{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.sidebar-mini-btn{background:#1e293bcc;border:1px solid #94a3b859;border-radius:10px;color:#e2e8f0;flex:1 1;font-size:12px;padding:8px 10px}.sidebar-mini-btn:hover:not(:disabled){background:#0f172ae0}.summary-item{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff14;border-radius:12px;padding:8px 10px;text-align:center}.summary-item .count{display:block;font-size:20px;font-weight:700;line-height:1.1;margin-bottom:2px}.summary-item .label{color:#ffffffad;font-size:11px}.summary-item.online .count{color:#4ade80}.summary-item.offline .count{color:#f87171}.nav{display:flex;flex:1 1;flex-direction:column;gap:8px;min-height:0;overflow-y:auto;padding-right:2px}.nav-link{align-items:center;border-radius:14px;color:#ffffffc7;display:flex;font-weight:500;gap:10px;padding:14px 16px;text-decoration:none}.nav-link:hover{background:#ffffff14;color:#fff}.nav-link.active{background:linear-gradient(135deg,#2563ebe6,#0ea5e9e6);box-shadow:0 12px 30px #2563eb40;color:#fff}.badge{align-items:center;background:#ffffff2e;border-radius:999px;display:inline-flex;font-size:12px;height:24px;justify-content:center;margin-left:auto;min-width:24px;padding:0 8px}.main-content{flex:1 1;margin-left:280px;padding:18px 20px}.header{align-items:flex-start;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffeb;background:var(--surface);border:1px solid #fff9;border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 18px 50px #0f172a14;box-shadow:var(--shadow);display:flex;gap:12px;justify-content:space-between;margin-bottom:14px;padding:14px 16px}.header h2{font-size:22px;line-height:1.2}.header p{color:#5c6b82;color:var(--text-soft);font-size:13px;margin-top:4px}.selected-info{background:#2563eb14;border-radius:12px;color:#1d4ed8;color:var(--primary-strong);font-size:13px;font-weight:600;padding:8px 12px;white-space:nowrap}.language-mini-btn{background:#eef3fb;border-radius:10px;color:#172033;color:var(--text);font-size:12px;padding:8px 10px}.language-mini-btn,.top-device-picker{border:1px solid #dbe4f0;border:1px solid var(--border)}.top-device-picker{background:#fff;background:var(--surface-strong);border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 18px 50px #0f172a14;box-shadow:var(--shadow);margin-bottom:24px;padding:16px}.top-device-head{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.top-device-head h3{font-size:16px}.top-device-actions{display:flex;gap:8px}.top-mini-btn{background:#eef3fb;border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:10px;color:#172033;color:var(--text);font-size:12px;padding:8px 12px}.top-device-list{grid-gap:8px;display:grid;gap:8px;grid-auto-rows:38px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));max-height:176px;overflow-y:auto;padding-right:4px}.top-device-item{grid-gap:8px;align-items:center;background:#f8fbff;border:1px solid #d8e2f0;border-radius:10px;color:#172033;color:var(--text);display:grid;font-size:12px;gap:8px;grid-template-columns:auto auto minmax(0,1fr) auto;padding:6px 10px}.top-device-item input{height:14px;margin:0;width:14px}.top-device-item .status-dot{height:7px;width:7px}.top-device-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-device-screen{color:#5c6b82;color:var(--text-soft)}.top-device-item.selected{background:#eaf2ff;border-color:#2563eb73}.top-device-item.offline{opacity:.55}.top-device-item.stale{background:#fff7ed;border-color:#d9770673}.content{display:flex;flex-direction:column;gap:24px}.dashboard,.device-selector,.instant-control,.maintenance-page,.marquee-page,.media-upload,.page-shell,.schedules-page{display:flex;flex-direction:column;gap:20px}.dashboard h2,.device-selector h2,.instant-control h2,.maintenance-page h2,.marquee-page h2,.media-upload h2,.page-title h2,.schedules-page h2{font-size:22px;margin-bottom:4px}.page-hint,.page-title p,.selected-devices,.selector-info,.upload-help{color:#5c6b82;color:var(--text-soft);font-size:13px;line-height:1.45}.card,.control-panel,.device-list,.marquee-form,.preview-card,.schedule-form,.selector-toolbar,.upload-form{background:#fff;background:var(--surface-strong);border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 18px 50px #0f172a14;box-shadow:var(--shadow);padding:24px}.stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr))}.stat-card{align-items:center;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:14px;box-shadow:0 18px 50px #0f172a14;box-shadow:var(--shadow);display:flex;gap:10px;padding:14px}.stat-icon{background:#eef3fb;background:var(--surface-muted);border-radius:12px;display:grid;font-size:20px;height:42px;place-items:center;width:42px}.stat-value{font-size:24px;font-weight:700;line-height:1}.stat-label{color:#5c6b82;color:var(--text-soft);font-size:12px;margin-top:2px}.stat-card.online .stat-value{color:#16a34a;color:var(--success)}.stat-card.offline .stat-value{color:#dc2626;color:var(--danger)}.section-heading{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:16px}.section-heading p{color:#5c6b82;color:var(--text-soft);font-size:14px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}td,th{border-bottom:1px solid #edf2f7;padding:14px 12px;text-align:left}th{color:#5c6b82;color:var(--text-soft);font-size:13px;font-weight:600}tr:hover td{background:#f8fbff}.status-pill{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:700;gap:6px;padding:6px 10px}.status-pill.online{background:#dcfce7;color:#166534}.status-pill.offline{background:#fee2e2;color:#991b1b}.status-pill.stale{background:#ffedd5;color:#9a3412}.selector-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.action-buttons,.button-group,.sd-buttons,.selector-actions{display:flex;flex-wrap:wrap;gap:12px}.device-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.device-card{align-items:flex-start;background:#fff;background:var(--surface-strong);border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:18px;box-shadow:0 18px 50px #0f172a14;box-shadow:var(--shadow);cursor:pointer;display:flex;gap:14px;padding:18px;position:relative}.device-card:hover{border-color:#2563eb66}.device-card.selected{background:linear-gradient(180deg,#fff,#eff6ff);border-color:#2563eb94}.device-card.offline{cursor:not-allowed;opacity:.74}.device-checkbox input{accent-color:#2563eb;accent-color:var(--primary);height:20px;width:20px}.device-info{flex:1 1}.device-info h3{font-size:17px;margin-bottom:8px}.device-info p{color:#5c6b82;color:var(--text-soft);font-size:14px;margin-top:6px}.device-status{font-weight:700}.device-status.online{color:#16a34a;color:var(--success)}.device-status.offline{color:#dc2626;color:var(--danger)}.disabled-overlay{background:#dc26261f;border-radius:999px;color:#991b1b;font-size:12px;font-weight:700;inset:auto 18px 18px auto;padding:6px 10px;position:absolute}.empty-state,.selected-devices,.selector-info,.warning{background:#fff;background:var(--surface-strong);border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:14px;padding:16px 18px}.warning{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.form-group label{font-weight:600}.input-help{color:#5c6b82;color:var(--text-soft);font-size:12px}.stream-slot-select{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.stream-slot-detail{font-feature-settings:"tnum";background:#2563eb0f;border-radius:10px;display:flex;flex-wrap:wrap;font-size:13px;font-variant-numeric:tabular-nums;gap:8px 14px;margin-top:6px;padding:8px 12px}.stream-slot-detail .slot-host,.stream-slot-detail strong{color:#172033;color:var(--text)}.stream-slot-detail .slot-health.online{color:#047857}.stream-slot-detail .slot-health.offline{color:#b91c1c}.stream-slot-detail .slot-health.unknown{color:#5c6b82;color:var(--text-soft)}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.media-stage{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1.4fr 1fr;margin-bottom:18px}.media-cabinet,.media-drop-panel{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:16px;padding:14px}.drop-zone{align-items:center;background:#dbeafe59;border:2px dashed #93c5fd;border-radius:14px;cursor:pointer;display:flex;flex-direction:column;gap:8px;justify-content:center;min-height:180px;text-align:center}.drop-zone.active{background:#93c5fd52;border-color:#2563eb;box-shadow:inset 0 0 0 1px #2563eb33}.drop-icon{font-size:30px}.drop-title{color:#172033;color:var(--text);font-weight:700}.drop-hint{color:#5c6b82;color:var(--text-soft);font-size:13px;max-width:90%;word-break:break-word}.hidden-file-input{display:none}.cabinet-head{align-items:baseline;display:flex;justify-content:space-between;margin-bottom:10px}.cabinet-head h3{font-size:16px}.cabinet-head span{color:#5c6b82;color:var(--text-soft);font-size:12px}.cabinet-grid{grid-gap:8px;display:grid;gap:8px}.device-folder-card{align-items:center;background:#eff6ff;border:1px solid #dbeafe;border-radius:12px;display:flex;gap:10px;padding:10px 12px}.folder-icon{font-size:18px}.folder-body{min-width:0}.folder-name{color:#1e3a8a;font-size:13px;font-weight:700}.folder-meta{color:#4b5563;font-size:12px;margin-top:2px}.cabinet-empty{border:1px dashed #cbd5e1;border-radius:10px;color:#5c6b82;color:var(--text-soft);font-size:13px;padding:12px}.media-queue{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:16px;margin-bottom:18px;padding:14px}.queue-head{align-items:baseline;display:flex;justify-content:space-between;margin-bottom:10px}.queue-head h3{font-size:16px}.queue-head span{color:#5c6b82;color:var(--text-soft);font-size:12px}.queue-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.queue-empty{border:1px dashed #cbd5e1;border-radius:10px;color:#5c6b82;color:var(--text-soft);font-size:13px;padding:12px}.queue-card{grid-gap:10px;align-items:center;background:#eff6ff;border:1px solid #dbeafe;border-radius:12px;display:grid;gap:10px;grid-template-columns:72px 1fr auto;padding:8px}.queue-preview{align-items:center;background:#0f172a;border-radius:8px;display:flex;height:52px;justify-content:center;overflow:hidden;width:72px}.queue-preview img,.queue-preview video{height:100%;object-fit:cover;width:100%}.queue-file-icon{color:#cbd5e1;font-size:18px}.queue-meta{min-width:0}.queue-name{color:#1e3a8a;font-size:13px;font-weight:700}.queue-info,.queue-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.queue-info{color:#4b5563;font-size:12px;margin-top:2px}.action-btn,.btn-danger,.btn-execute,.btn-ghost,.btn-primary,.btn-secondary{border:none;border-radius:12px;cursor:pointer;font-weight:600;padding:12px 18px}.btn-execute,.btn-primary{background:linear-gradient(135deg,#2563eb,#0ea5e9);background:linear-gradient(135deg,var(--primary),#0ea5e9);box-shadow:0 12px 24px #2563eb2e;color:#fff}.btn-execute:hover:not(:disabled),.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#0284c7);background:linear-gradient(135deg,var(--primary-strong),#0284c7)}.btn-ghost,.btn-secondary{background:#eef3fb;color:#172033;color:var(--text)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.action-btn{background:#eff6ff;color:#1e3a8a}.action-btn.active{background:#dbeafe;box-shadow:inset 0 0 0 1px #2563eb2e;color:#1d4ed8}.instant-tech{gap:16px}.instant-hero{background:linear-gradient(130deg,#0b1227,#111c3f 45%,#0f2d4f);border:1px solid #60a5fa38;border-radius:20px;box-shadow:0 20px 44px #0f172a4d;color:#dbeafe;overflow:hidden;padding:20px;position:relative}.instant-hero .page-title h2{color:#f8fafc;margin-bottom:6px}.instant-hero .page-title p{color:#dbeafed6}.instant-hero-grid{background-image:linear-gradient(#38bdf814 1px,#0000 0),linear-gradient(90deg,#38bdf814 1px,#0000 0);background-size:26px 26px;inset:0;-webkit-mask-image:radial-gradient(circle at 50% 30%,#000 45%,#0000 95%);mask-image:radial-gradient(circle at 50% 30%,#000 45%,#0000 95%);pointer-events:none;position:absolute}.instant-lang-switch{align-items:center;background:#0f172a73;border:1px solid #94a3b866;border-radius:999px;color:#dbeafe;display:inline-flex;font-size:12px;gap:10px;margin-bottom:12px;padding:8px 10px;position:relative;z-index:1}.instant-lang-buttons{display:inline-flex;gap:6px}.instant-lang-btn{background:#1e293bb3;border:1px solid #94a3b86b;border-radius:999px;color:#cbd5e1;font-size:12px;font-weight:700;min-width:50px;padding:4px 10px}.instant-lang-btn.active{background:linear-gradient(135deg,#1d4ed8,#0ea5e9);border-color:#7dd3fcb3;color:#fff}.instant-kpis{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:14px}.instant-kpi{background:#0f172a66;border:1px solid #94a3b84d;border-radius:12px;padding:10px 12px;position:relative;z-index:1}.instant-kpi strong{color:#f8fafc;display:block;font-size:20px;letter-spacing:.04em;margin-top:4px}.kpi-label{color:#bfdbfee6;font-size:11px;letter-spacing:.06em;text-transform:uppercase}.instant-kpi.ok{background:#064e3b5c;border-color:#34d39973}.instant-kpi.warn{background:#78350f57;border-color:#fbbf2473}.instant-panel{background:linear-gradient(180deg,#f8fbff,#eef5ff)}.instant-stage{grid-gap:14px;display:grid;gap:14px;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);margin-bottom:14px}.instant-block{background:#fff;border:1px solid #d7e6ff;border-radius:14px;padding:14px}.instant-action-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.instant-action-btn{align-items:flex-start;background:linear-gradient(180deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe;border-radius:12px;display:flex;flex-direction:column;gap:5px;min-height:96px;text-align:left}.instant-action-btn.active{background:linear-gradient(135deg,#1d4ed8,#0369a1);border-color:#60a5fa;box-shadow:0 0 0 1px #93c5fd70,0 12px 24px #2563eb3d;color:#eff6ff}.instant-action-btn.active small{color:#dbeafee0}.instant-action-code{align-items:center;background:#ffffff8f;border:1px solid #2563eb4d;border-radius:999px;display:inline-flex;font-size:12px;font-weight:700;height:24px;justify-content:center;letter-spacing:.08em;min-width:44px}.instant-action-btn.active .instant-action-code{background:#0f172a57;border-color:#bfdbfe80}.instant-action-label{font-size:14px;font-weight:700}.instant-action-btn small{color:#1e40af;font-size:12px;line-height:1.3}.instant-target-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}.instant-target-card{background:linear-gradient(180deg,#f8fbff,#edf5ff);border:1px solid #dbeafe;border-radius:12px;padding:10px}.instant-target-card.online{border-color:#16a34a59}.instant-target-card.offline{border-color:#dc262659;opacity:.9}.instant-target-head{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-bottom:8px}.instant-target-id{color:#1d4ed8;font-size:12px;font-weight:700}.instant-target-name{color:#0f172a;font-size:14px;font-weight:700;margin-bottom:6px}.instant-target-meta{color:#475569;font-size:12px;margin-bottom:3px}.instant-submit-bar{align-items:center;background:linear-gradient(90deg,#eff6ff,#e0f2fe);border:1px solid #cfe2ff;border-radius:14px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-top:12px;padding:12px 14px}.instant-submit-hint{color:#1e3a8a;font-size:13px}.instant-execute{min-width:180px}.preview{align-items:center;border-radius:18px;box-shadow:0 18px 50px #0f172a14;box-shadow:var(--shadow);display:flex;min-height:88px;padding:18px 20px}.preview-text{overflow:hidden;white-space:nowrap;width:100%}.preview-text span{animation:marquee-scroll 12s linear infinite;display:inline-block;padding-left:100%}@keyframes marquee-scroll{0%{transform:translateX(0)}to{transform:translateX(-100%)}}.maintenance-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr))}.m-card{background:#fff;background:var(--surface-strong);border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:18px;box-shadow:0 18px 50px #0f172a14;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px;padding:22px}.m-card p{color:#5c6b82;color:var(--text-soft)}.volume-control{align-items:center;display:flex;gap:12px}.upload-help ul{margin-top:10px;padding-left:20px}.loading,.upload-help ul{color:#5c6b82;color:var(--text-soft)}.loading{padding:40px;text-align:center}@media (max-width:1100px){.sidebar{height:auto;position:static;width:100%}.layout{flex-direction:column}.main-content{margin-left:0;padding:20px}}@media (max-width:768px){.main-content{padding:16px}.header{flex-direction:column;padding:14px}.top-device-head{align-items:stretch;flex-direction:column}.top-device-actions{width:100%}.top-mini-btn{flex:1 1}.top-device-list{max-height:176px}.form-row,.maintenance-grid,.stats-grid,.top-device-list{grid-template-columns:1fr}.section-heading,.selector-toolbar{align-items:stretch}.device-grid,.instant-action-grid,.instant-kpis,.instant-stage,.media-stage{grid-template-columns:1fr}}.sync-status-widget{background:#fff;background:var(--surface-strong);border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-md);margin-bottom:12px;padding:10px 12px}.sync-status-footer,.sync-status-head{align-items:center;display:flex;gap:12px;justify-content:space-between}.sync-status-head{margin-bottom:10px}.sync-status-footer{margin-top:10px}.sync-link-btn{background:#dbeafe;border-radius:999px;color:#1d4ed8;font-size:12px;font-weight:600;padding:6px 10px;text-decoration:none}.sync-warning-mini{background:#fff7ed;border-radius:10px;color:#9a3412;font-size:12px;margin:8px 0;padding:8px 10px}.sync-inline-link{color:#b45309;display:inline-block;font-weight:600;margin-left:8px;text-decoration:underline}.sync-page{gap:20px}.sync-page,.sync-summary-card{display:flex;flex-direction:column}.sync-summary-card{gap:14px}.sync-summary-head{align-items:center;display:flex;gap:12px;justify-content:space-between}.sync-summary-meta{color:#5c6b82;color:var(--text-soft);display:flex;flex-wrap:wrap;font-size:13px;gap:14px}.sync-badges,.sync-error-codes{display:flex;flex-wrap:wrap;gap:8px}.sync-badge{align-items:center;display:inline-flex}.sync-all-good,.sync-badge{border-radius:999px;font-size:12px;font-weight:700;padding:4px 10px}.sync-all-good{background:#dcfce7;color:#166534}.sync-results-meta{color:#5c6b82;color:var(--text-soft);display:flex;flex-wrap:wrap;font-size:13px;gap:12px;margin-bottom:10px}.sync-error-badge{background:#fee2e2;color:#b91c1c}.security-page{gap:20px}.security-card,.security-page{display:flex;flex-direction:column}.security-card{gap:14px}.security-meta-row{color:#5c6b82;color:var(--text-soft);display:flex;flex-wrap:wrap;font-size:14px;gap:14px}.security-qr-block{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px}.mfa-qr{border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:10px;height:180px;width:180px}.security-qr-meta{display:flex;flex-direction:column;gap:10px;min-width:280px}.security-inline-form{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.security-inline-form input,.security-inline-form select{min-width:0;width:100%}.security-inline-form button{justify-self:start}@media (max-width:720px){.security-inline-form{grid-template-columns:1fr}.security-inline-form button{justify-self:stretch}}.user-management .table-wrap{overflow-x:visible}.user-management .table-wrap table{table-layout:auto;width:100%}.user-management .table-wrap td,.user-management .table-wrap th{word-break:break-word}@media (max-width:1100px){.user-management .table-wrap thead{display:none}.user-management .table-wrap table,.user-management .table-wrap tbody,.user-management .table-wrap td,.user-management .table-wrap tr{display:block;width:100%}.user-management .table-wrap tr{background:#fff;border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:12px;margin-bottom:12px;padding:8px 12px}.user-management .table-wrap td{grid-gap:10px;align-items:center;border:none;display:grid;gap:10px;grid-template-columns:110px 1fr;padding:6px 0}.user-management .table-wrap td:before{color:#5c6b82;color:var(--text-soft);content:attr(data-label);font-size:12px;font-weight:600}.user-management .table-wrap td>*{min-width:0}}.user-actions{display:flex;flex-direction:column;gap:8px;min-width:0}.user-actions__buttons{display:flex;flex-wrap:wrap;gap:8px}.user-actions__field{color:#5c6b82;color:var(--text-soft);display:flex;flex-direction:column;font-size:12px;gap:4px}.user-actions__field input{min-width:0;width:100%}.user-actions__field--row{align-items:center;flex-direction:row;gap:8px}.user-actions__field--row input{flex:1 1}.security-help{background:#fbfdff;border:1px dashed #dbe4f0;border:1px dashed var(--border);border-radius:10px;color:#5c6b82;color:var(--text-soft);font-size:12px;line-height:1.45;padding:10px 12px}.security-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.security-kv{align-items:center;background:#f8fbff;border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:12px;display:flex;gap:8px;justify-content:space-between;padding:10px 12px}.security-kv span{color:#5c6b82;color:var(--text-soft);font-size:13px}.preview-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));margin-bottom:24px}.device-preview-card{background:#fff;background:var(--surface-strong);border:1px solid #dbe4f0;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-md);overflow:hidden}.preview-header{align-items:center;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:space-between;padding:10px 14px}.preview-name{color:#172033;color:var(--text)}.preview-screen{color:#5c6b82;color:var(--text-soft);font-size:11px;margin-left:auto}.status-dot{background:#9ca3af;border-radius:50%;flex:0 0 auto;height:8px;width:8px}.status-dot.online{background:#16a34a;background:var(--success)}.status-dot.offline{background:#dc2626;background:var(--danger)}.preview-image-wrap{align-items:center;aspect-ratio:16/9;background:#1e293b;display:flex;justify-content:center}.preview-image{height:100%;object-fit:contain;width:100%}.preview-placeholder{color:#64748b;font-size:13px}.preview-meta{background:#0f172ae6;border-top:1px solid #dbe4f0;border-top:1px solid var(--border);color:#e2e8f0;font-size:12px;padding:8px 12px}.preview-meta small{color:#cbd5e1;display:block;font-size:11px;margin-top:4px;opacity:1}.preview-meta.ok{background:#14532df2;border-top:1px solid #86efac73;color:#dcfce7}.preview-meta.stale{background:#92400ef2;border-top:1px solid #fdba7473;color:#fef3c7}.preview-meta.error{background:#991b1beb;border-top:1px solid #fecaca80;color:#ffe5e5}.preview-meta.missing{background:#78350ff2;border-top:1px solid #fdba7466;color:#fef3c7}.preview-meta.offline{background:#334155f2;border-top:1px solid #94a3b873;color:#e2e8f0}.preview-meta.unknown{background:#1e293bf2;border-top:1px solid #94a3b859;color:#e2e8f0}.frame-layout{margin:16px 0}.frame-label-text{color:#172033;color:var(--text);font-size:14px;font-weight:500;margin-bottom:8px}.frame-container{max-width:400px}.frame-bg{background:#1e293b;border-radius:10px;border-radius:var(--radius-sm);padding:12px}.frame-slot{background:#334155;border:2px solid #475569;border-radius:6px;cursor:pointer;padding:12px;text-align:center;transition:all .15s}.frame-slot:hover{background:#1e3a5f;border-color:#60a5fa}.frame-slot.selected{background:#1e40af;border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 2px #2563eb4d}.frame-name{color:#e2e8f0;font-size:12px;font-weight:600}.frame-slot.mframe{margin-bottom:8px;padding:20px 12px}.frame-sub-row{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}.frame-hint{color:#5c6b82;color:var(--text-soft);font-size:12px;margin-top:8px}.sidebar-footer{align-items:center;border-top:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-top:auto;padding:16px 20px}.user-info{color:#94a3b8;display:flex;flex-direction:column;font-size:13px}.user-info small{color:#64748b;font-size:11px;text-transform:uppercase}.btn-logout{background:#0000;border:1px solid #475569;border-radius:6px;color:#94a3b8;cursor:pointer;font-size:12px;padding:4px 10px}.btn-logout:hover{background:#dc2626;border-color:#dc2626;color:#fff}.btn-sm-danger{align-items:center;background:#0000;border:1px solid #dc2626;border:1px solid var(--danger);border-radius:6px;color:#dc2626;color:var(--danger);cursor:pointer;display:inline-flex;font-size:14px;height:24px;justify-content:center;line-height:1;width:24px}.btn-sm-danger:hover{background:#dc2626;background:var(--danger);color:#fff}.section{margin-bottom:24px}.empty-state{color:#5c6b82;color:var(--text-soft);font-size:15px;padding:40px;text-align:center}
/*# sourceMappingURL=main.ef66151f.css.map*/