*,:before,:after{box-sizing:border-box}:root{--bg-base:#0a0c12;--bg-surface:#0f1117;--bg-elevated:#13161f;--bg-stream:#0d1021;--border:#2a2d3a;--text-primary:#fff;--text-secondary:#9ca3af;--text-muted:#6b7280;--text-dim:#4b5563;font-size:19px}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;margin:0;padding:0;font-family:Pretendard,Noto Sans KR,system-ui,-apple-system,sans-serif}#root{width:100%;min-height:100vh}button{font-family:inherit}p{margin:0}.header{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.header__logo{cursor:pointer;align-items:center;gap:10px;display:flex}.header__logo-img{object-fit:contain;border-radius:8px;width:36px;height:36px}.header__logo-text{flex-direction:column;display:flex}.header__logo-title{color:var(--text-primary);white-space:nowrap;font-size:.85rem;font-weight:700}.header__logo-sub{color:#b4b8be;font-size:.65rem}.header__nav{gap:8px;display:flex}.header__nav-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:6px 16px;font-size:.85rem;transition:background .15s,color .15s;display:flex}.header__nav-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.header__nav-btn--active{color:#080808;background:#94aee6}.header__right{align-items:center;gap:20px;display:flex}.header__clock{align-items:baseline;gap:8px;display:flex}.header__clock-date{color:var(--text-secondary);font-size:.72rem}.header__clock-time{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:1.2rem;font-weight:700}.header__user{cursor:pointer;border:1px solid var(--border);color:#d1d5db;-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:.8rem;display:flex;position:relative}.header__user:hover,.header__user--active{color:#fff;background:#374151;border-color:#6b7280}.header__dropdown{background:var(--bg-elevated);border:1px solid var(--border);z-index:200;border-radius:8px;min-width:210px;padding:4px 0;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #0006}.header__dropdown-item{text-align:left;color:#d1d5db;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:9px 16px;font-size:.8rem;display:flex}.header__dropdown-item:hover{background:var(--border);color:var(--text-primary)}.header__dropdown-item--logout{color:#ef4444}.header__dropdown-item--logout:hover{color:#f87171;background:#2a1a1a}.header__dropdown-divider{border:none;border-top:1px solid var(--border);margin:4px 0}.app-layout{background:var(--bg-base);min-height:100vh;color:var(--text-primary);flex-direction:column;display:flex}.app-layout__main{flex-direction:column;flex:1;margin-top:56px;display:flex}.monitor-camerabar{background:var(--bg-elevated);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;min-height:40px;padding:8px 16px;display:flex}.monitor-camerabar__left{align-items:center;gap:10px;display:flex}.monitor-camerabar__name{color:#e5e7eb;font-size:.8rem;font-weight:500}.monitor-camerabar__badge{border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:.7rem;font-weight:500;display:flex}.monitor-camerabar__badge--safe{color:#10b981;background:#10b98126;border:1px solid #10b9814d}.monitor-camerabar__badge--connected{color:#60a5fa;background:#3b82f626;border:1px solid #3b82f64d}.monitor-camerabar__badge--disconnected{color:#f87171;background:#ef444426;border:1px solid #ef44444d}.monitor-camerabar__controls{align-items:center;gap:12px;display:flex}.monitor-camerabar__ptz-btn{color:#8cabd4;cursor:pointer;background:#8cabd41a;border:1px solid #8cabd466;border-radius:4px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:600;transition:background .15s,color .15s;display:flex}.monitor-camerabar__ptz-btn:hover{color:#fff;background:#8cabd440}.monitor-camerabar__grid-btn{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;border-radius:4px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;display:flex}.monitor-camerabar__grid-btn:hover{background:var(--border);color:var(--text-primary)}.monitor-camerabar__detection-label{color:var(--text-secondary);font-size:.75rem}.monitor-camerabar__person-count{color:#e5e7eb;align-items:center;gap:4px;font-size:.8rem;display:flex}.monitor-camerabar__toggle{width:36px;height:20px;display:inline-block;position:relative}.monitor-camerabar__toggle input{opacity:0;width:0;height:0}.monitor-camerabar__toggle-slider{cursor:pointer;background:#374151;border-radius:999px;transition:background .2s;position:absolute;inset:0}.monitor-camerabar__toggle-slider:before{content:"";background:#fff;border-radius:50%;width:14px;height:14px;transition:transform .2s;position:absolute;top:3px;left:3px}.monitor-camerabar__toggle input:checked+.monitor-camerabar__toggle-slider{background:#829fdd}.monitor-camerabar__toggle input:checked+.monitor-camerabar__toggle-slider:before{transform:translate(16px)}.monitor-stream{background:var(--bg-stream);position:relative;overflow:hidden}.monitor-stream--main{border-radius:4px;width:100%;height:100%}.monitor-stream--thumb{aspect-ratio:16/9;cursor:pointer;border:2px solid #0000;border-radius:4px;width:100%;transition:border-color .15s}.monitor-stream--thumb:hover{border-color:#2563eb}.monitor-stream__img{object-fit:cover;width:100%;height:100%;display:block}.monitor-stream__skeleton-canvas{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.monitor-stream__placeholder{width:100%;height:100%;color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex}.monitor-stream__placeholder-icon{opacity:.4;color:#f0f8ff}@keyframes spin{to{transform:rotate(360deg)}}.monitor-stream__placeholder-icon--spin{opacity:.6;animation:1.2s linear infinite spin}.monitor-stream__placeholder-text{opacity:.4;color:#f0f8ff;font-size:.75rem}.monitor-stream__thumb-label{color:var(--text-primary);background:#000000a6;border-radius:4px;padding:2px 8px;font-size:.65rem;position:absolute;top:6px;left:6px}.monitor-stream__fps-badge{color:var(--text-secondary);background:#0009;border-radius:4px;padding:2px 7px;font-size:.65rem;position:absolute;top:8px;right:8px}.monitor-stream__conn-overlay{color:#fbbf24;background:#0000008c;justify-content:center;align-items:center;font-size:.75rem;display:flex;position:absolute;inset:0}.stream-overlay__box{box-sizing:border-box;cursor:pointer;pointer-events:auto;border:2px solid #0000;border-radius:4px;transition:border-color .2s,box-shadow .2s;position:absolute}.stream-overlay__box--selected{box-shadow:0 0 0 2px #ffffff59}.stream-overlay__tag{color:#fff;white-space:nowrap;pointer-events:none;border-radius:3px 3px 3px 0;align-items:center;gap:4px;padding:2px 6px;font-size:.62rem;font-weight:700;line-height:1.4;display:flex;position:absolute;top:-22px;left:-1px}.stream-overlay__tag-id{opacity:1}.stream-overlay__tag-reba,.stream-overlay__tag-fatigue{opacity:.85;font-weight:500}.monitor-statbar{background:#1a1a1a;border-bottom:1px solid #333;grid-template-columns:1fr 1px 1fr 1px 1fr;display:grid}.monitor-statbar__card{text-align:center;flex-direction:column;align-items:center;gap:4px;padding:14px 12px;display:flex}.monitor-statbar__label{color:#b0b0b0;white-space:nowrap;align-items:center;gap:4px;font-size:.72rem;display:flex}.monitor-statbar__value{color:#e7e4e4;font-size:1.5rem;font-weight:700;line-height:1}.monitor-statbar__value--danger{color:#ff4757}.monitor-statbar__divider{background:#333;align-self:stretch;width:1px}.monitor-worker{border-bottom:1px solid #333;flex:3;min-height:0;padding:0 16px 8px;overflow-y:auto}.monitor-worker::-webkit-scrollbar{width:4px}.monitor-worker::-webkit-scrollbar-track{background:0 0}.monitor-worker::-webkit-scrollbar-thumb{background:#333;border-radius:2px}.monitor-worker::-webkit-scrollbar-thumb:hover{background:#555}.monitor-worker__header{background:var(--bg-surface);z-index:1;align-items:center;gap:8px;padding:12px 0 8px;display:flex;position:sticky;top:0}.monitor-worker__icon{color:#b0b0b0}.monitor-worker__title{color:#fff;font-size:.88rem;font-weight:600}.monitor-worker__body{flex-direction:column;display:flex}.monitor-worker__empty{color:#666;text-align:center;padding:16px 0;font-size:.75rem}.monitor-worker__list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.monitor-worker__item{flex-direction:column;display:flex}.worker-row{cursor:pointer;width:100%;color:var(--text-primary);text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:8px 10px;transition:background .15s,border-color .15s;display:flex}.worker-row:hover{background:#242424}.worker-row--active{background:#6366f11f;border-color:#6366f159}.worker-id-badge{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.72rem;font-weight:700;display:flex}.worker-id-badge--high{color:#ff4757!important;background:#ff47572e!important}.worker-id-badge--medium{color:#ffa502!important;background:#ffa5022e!important}.worker-id-badge--low{color:#2ed573!important;background:#2ed5732e!important}.worker-row__info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.worker-row__name{color:#fff;font-size:.82rem;font-weight:600}.worker-row__meta{color:#b0b0b0;font-size:.7rem}.worker-row__risk-label{color:#b0b0b0}.worker-row__fatigue-col{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:3px;width:44px;display:flex}.worker-row__fatigue-pct{font-size:.7rem;font-weight:600}.worker-row__fatigue-bar-bg{background:#ffffff1a;border-radius:2px;width:100%;height:4px;overflow:hidden}.worker-row__fatigue-bar-fill{border-radius:2px;height:100%;transition:width .35s}.worker-row__chevron{color:#666;flex-shrink:0;align-items:center;display:flex}.worker-detail{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000008c;border-radius:0 6px 6px;flex-direction:column;gap:3px;margin-bottom:2px;padding:7px 10px 6px;animation:.13s ease-out slideInDetail;display:flex}@keyframes slideInDetail{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.worker-detail__row{justify-content:space-between;align-items:center;display:flex}.worker-detail__label{color:#b0b0b0;font-size:.7rem}.worker-detail__value{color:#e5e7eb;font-size:.72rem;font-weight:600}.worker-detail__section-title{color:#b0b0b0;align-items:center;gap:4px;margin:2px 0;font-size:.68rem;display:flex}.worker-detail__body-parts{flex-direction:column;gap:3px;display:flex}.fatigue-bar{align-items:center;gap:6px;display:flex}.fatigue-bar__label{color:#b0b0b0;flex-shrink:0;width:28px;font-size:.63rem}.fatigue-bar__track{background:#ffffff1a;border-radius:3px;flex:1;height:5px;overflow:hidden}.fatigue-bar__fill{border-radius:3px;height:100%;transition:width .4s}.fatigue-bar__pct{text-align:right;flex-shrink:0;width:28px;font-size:.6rem}.worker-detail__repetition{border-radius:4px;align-items:center;gap:4px;margin-top:2px;padding:4px 8px;font-size:.68rem;font-weight:600;display:flex}.worker-detail__repetition-type{font-weight:400}.monitor-alert{flex-direction:column;flex:7;min-height:0;padding:0 16px 10px;display:flex}.monitor-alert__header{flex-shrink:0;align-items:center;gap:8px;padding:12px 0 8px;display:flex}.monitor-alert__icon{color:#b0b0b0}.monitor-alert__title{color:#fff;font-size:.88rem;font-weight:600}.monitor-alert__count{color:#ef4444;background:#ef444433;border-radius:10px;margin-left:auto;padding:1px 7px;font-size:.65rem;font-weight:700}.monitor-alert__body{flex:1;overflow-y:auto}.monitor-alert__body::-webkit-scrollbar{width:4px}.monitor-alert__body::-webkit-scrollbar-track{background:0 0}.monitor-alert__body::-webkit-scrollbar-thumb{background:#333;border-radius:2px}.monitor-alert__empty{color:#666;text-align:center;padding:24px 0;font-size:.735rem}.monitor-alert__list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.alert-card{background:#242424;border-radius:6px;flex-direction:column;gap:4px;padding:8px 10px;display:flex}.alert-card--danger{border-left:3px solid #d96b78}.alert-card--warning{border-left:3px solid #d4885a}.alert-card__time{color:#9e9e9e;align-items:center;gap:4px;font-size:.68rem;display:flex}.alert-card__header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.alert-card__message{color:#fff;word-break:keep-all;flex:1;font-size:.73rem;line-height:1.4}.alert-card__badge{white-space:nowrap;border-radius:4px;flex-shrink:0;align-items:center;gap:3px;padding:2px 8px;font-size:.68rem;font-weight:500;display:flex}.alert-card__badge--danger{color:#d96b78;background:#d96b7826}.alert-card__badge--warning{color:#d4885a;background:#d4885a26}.alert-card__btn{color:#8cabd4;cursor:pointer;background:#8cabd426;border:none;border-radius:4px;justify-content:center;align-items:center;gap:4px;width:100%;margin-top:2px;padding:5px 8px;font-size:.72rem;font-weight:500;transition:background .15s;display:flex}.alert-card__btn:hover{background:#8cabd447}.eff-result{flex-direction:column;gap:4px;display:flex}.eff-result__summary{cursor:pointer;border:none;border-radius:4px;align-items:center;gap:4px;width:100%;padding:4px 8px;font-size:.69rem;font-weight:600;transition:opacity .15s;display:flex}.eff-result__summary--danger{color:#d96b78;background:#d96b7826}.eff-result__summary--safe{color:#4ade80;background:#4ade801f}.eff-result__summary--unknown{color:#888;cursor:default;background:#9696961f}.eff-result__summary:hover{opacity:.8}.eff-result__summary--unknown:hover{opacity:1}.eff-result__summary>svg:last-child{margin-left:auto}.eff-result__parts{background:#ffffff08;border-radius:4px;flex-direction:column;gap:2px;padding:4px 6px;display:flex}.eff-result__part{color:#888;align-items:center;gap:6px;font-size:.67rem;display:flex}.eff-result__part--risk{color:#d96b78}.eff-result__part--unknown{color:#555;font-style:italic}.eff-result__part-name{flex-shrink:0;width:28px;font-weight:600}.eff-result__part-class{flex:1}.eff-result__part-conf{opacity:.75;font-size:.65rem}.alert-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#000000b8;justify-content:center;align-items:center;animation:.18s ease-out alertOverlayIn;display:flex;position:fixed;inset:0}@keyframes alertOverlayIn{0%{opacity:0}to{opacity:1}}.alert-modal{background:#1a1a1a;border:1px solid #333;border-radius:12px;width:90%;max-width:480px;animation:.2s ease-out alertModalIn;overflow:hidden}@keyframes alertModalIn{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.alert-modal__header{border-bottom:1px solid #2a2a2a;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.alert-modal__header--danger{background:#d96b781f}.alert-modal__header--warning{background:#d4885a1f}.alert-modal__header-left{color:#fff;align-items:center;gap:8px;display:flex}.alert-modal__header--danger .alert-modal__header-left{color:#d96b78}.alert-modal__header--warning .alert-modal__header-left{color:#d4885a}.alert-modal__title{font-size:.95rem;font-weight:700}.alert-modal__close{color:#999;cursor:pointer;background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.alert-modal__close:hover{color:#fff;background:#ffffff2e}.alert-modal__body{flex-direction:column;gap:14px;padding:20px 24px;display:flex}.alert-modal__level-row{display:flex}.alert-modal__level-badge{border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:.75rem;font-weight:600;display:flex}.alert-modal__level-badge--danger{color:#d96b78;background:#d96b7826}.alert-modal__level-badge--warning{color:#d4885a;background:#d4885a26}.alert-modal__message{color:#fff;margin:0;font-size:.9rem;font-weight:600;line-height:1.4}.alert-modal__desc{color:#b0b0b0;background:#ffffff0a;border-left:2px solid #444;border-radius:6px;margin:0;padding:10px 12px;font-size:.78rem;line-height:1.6}.alert-modal__info-grid{flex-direction:column;gap:6px;display:flex}.alert-modal__info-row{background:#242424;border-radius:6px;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.alert-modal__info-label{color:#b0b0b0;align-items:center;gap:6px;font-size:.75rem;display:flex}.alert-modal__info-value{color:#fff;font-size:.82rem;font-weight:600}.alert-modal__footer{border-top:1px solid #2a2a2a;justify-content:flex-end;gap:8px;padding:14px 24px;display:flex}.alert-modal__btn{cursor:pointer;border:none;border-radius:6px;padding:9px 20px;font-size:.82rem;font-weight:600;transition:opacity .15s,transform .1s}.alert-modal__btn:hover{opacity:.88;transform:translateY(-1px)}.alert-modal__btn--cancel{color:#ccc;background:#2a2a2a}.alert-modal__btn--cancel:hover{opacity:1;background:#333}.alert-modal__btn--confirm{color:#fff;background:#3b5bdb}.monitor-actions{border-top:1px solid #333;flex-direction:column;gap:8px;margin-top:auto;padding:14px 16px;display:flex}.monitor-actions__btn{color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:15px;font-size:.95rem;font-weight:600;transition:opacity .15s,transform .1s;display:flex}.monitor-actions__btn:hover{opacity:.9;transform:translateY(-1px)}.monitor-actions__btn--ptz{background:#3b5bdb}.monitor-actions__btn--broadcast{background:#c87d3a}.monitor-actions__btn--alarm{background:#b84c4c}.ptz-overlay{pointer-events:none;z-index:100;border-radius:inherit;justify-content:flex-end;align-items:flex-end;padding:24px 24px 86px;animation:.18s ease-out ptzOverlayIn;display:flex;position:absolute;inset:0}@keyframes ptzOverlayIn{0%{opacity:0}to{opacity:1}}.ptz-modal{pointer-events:auto;background:#121212eb;border:1px solid #333;border-radius:12px;width:240px;animation:.2s ease-out ptzModalIn;overflow:hidden;box-shadow:0 8px 32px #00000080}@keyframes ptzModalIn{0%{opacity:0;transform:translateY(14px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.ptz-modal__body{flex-direction:column;gap:12px;padding:14px 16px;display:flex}.ptz-footer{justify-content:center;align-items:center;padding-top:4px;display:flex}.ptz-modal__controls{justify-content:center;align-items:flex-start;gap:20px;display:flex}.ptz-section{flex-direction:column;gap:8px;display:flex}.ptz-section__title{color:#888;text-align:center;text-transform:uppercase;letter-spacing:.05em;font-size:.68rem}.ptz-direction-grid{grid-template-rows:repeat(3,36px);grid-template-columns:repeat(3,36px);gap:3px;margin:0 auto;display:grid}.ptz-dir-btn{color:#ccc;cursor:pointer;-webkit-user-select:none;user-select:none;background:#2a2a2a;border:1px solid #383838;border-radius:6px;justify-content:center;align-items:center;transition:background .12s,color .12s,transform .1s;display:flex}.ptz-dir-btn:hover{color:#0d0d0d;background:#8cabd4;border-color:#8cabd4}.ptz-dir-btn:active,.ptz-dir-btn--active{color:#0d0d0d;background:#8cabd4;border-color:#8cabd4;transform:scale(.93)}.ptz-home-btn{color:#aaa;cursor:pointer;background:#1a1a1a;border:1px solid #444;border-radius:6px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.ptz-home-btn:hover{color:#0d0d0d;background:#8cabd4;border-color:#8cabd4}.ptz-zoom-control{flex-direction:column;align-items:center;gap:6px;display:flex}.ptz-zoom-btn{color:#ccc;cursor:pointer;background:#2a2a2a;border:1px solid #383838;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;transition:background .12s,color .12s,transform .1s;display:flex}.ptz-zoom-btn:hover{color:#0d0d0d;background:#8cabd4;border-color:#8cabd4}.ptz-zoom-btn:active{transform:scale(.93)}.ptz-zoom-label{color:#666;letter-spacing:.08em;font-size:.62rem}.ptz-preset-row{justify-content:center;gap:6px;display:flex}.ptz-preset-btn{color:#ccc;cursor:pointer;background:#242424;border:1px solid #383838;border-radius:6px;justify-content:center;align-items:center;width:34px;height:34px;font-size:.78rem;font-weight:600;transition:background .12s,color .12s;display:flex}.ptz-preset-btn:hover{color:#0d0d0d;background:#8cabd4;border-color:#8cabd4}.ptz-speed-control{align-items:center;gap:10px;display:flex}.ptz-speed-label{color:#888;text-align:right;min-width:34px;font-size:.72rem}.ptz-speed-slider{appearance:none;cursor:pointer;background:#333;border-radius:2px;outline:none;flex:1;height:4px}.ptz-speed-slider::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:#8cabd4;border-radius:50%;width:14px;height:14px}.ptz-speed-slider::-moz-range-thumb{cursor:pointer;background:#8cabd4;border:none;border-radius:50%;width:14px;height:14px}.ptz-hint{color:#555;text-align:center;font-size:.62rem}.monitor-page{background:var(--bg-base);flex-direction:column;height:calc(100vh - 56px);display:flex}.monitor-page__body{flex:1;display:flex;overflow:hidden}.monitor-page__video-area{background:var(--bg-base);flex-direction:column;flex:1;gap:8px;min-width:0;min-height:0;padding:12px;display:flex;overflow:hidden}.monitor-page__single-layout{flex-direction:column;flex:1;gap:8px;min-height:0;display:flex;overflow:hidden}.monitor-page__main{flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.monitor-page__main .monitor-stream--main{width:100%;height:100%;max-height:100%;aspect-ratio:unset}.ptz-floating-btn{color:#d8d5d5;cursor:pointer;z-index:110;background:#171718;border:none;border-radius:12px;justify-content:center;align-items:center;width:46px;height:46px;transition:background .2s,transform .1s;display:flex;position:absolute;bottom:24px;right:24px;box-shadow:0 4px 16px #0000004d}.ptz-floating-btn:hover{background:#6c90be}.ptz-floating-btn:active{transform:scale(.95)}.ptz-floating-btn--open{background:#6c90be}.monitor-page__thumbs{flex-shrink:0;gap:8px;height:140px;display:flex;overflow:hidden}.monitor-page__thumb-item{flex-shrink:0;width:220px;min-width:220px;overflow:hidden}.monitor-page__thumb-item .monitor-stream--thumb{height:100%;aspect-ratio:unset}.monitor-page__grid{gap:8px;width:100%;height:100%;display:grid}.monitor-page__grid--1{grid-template-columns:1fr}.monitor-page__grid--2{grid-template-rows:1fr;grid-template-columns:1fr 1fr}.monitor-page__grid--3,.monitor-page__grid--4{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.monitor-page__grid-empty{background:var(--bg-stream);aspect-ratio:16/9;border-radius:4px}.monitor-page__sidebar{background:var(--bg-surface);border-left:1px solid var(--border);flex-direction:column;width:360px;min-width:360px;display:flex;overflow:hidden}.drp{position:relative}.drp__trigger{color:#ccc;cursor:pointer;white-space:nowrap;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;transition:border-color .15s;display:flex}.drp__trigger:hover{border-color:#8cabd4}.drp__trigger-sep{color:#555}.drp__dropdown{z-index:500;background:#1e1e1e;border:1px solid #333;border-radius:10px;width:280px;padding:14px;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 8px 24px #00000080}.drp__cal-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.drp__cal-title{color:#e0e0e0;font-size:.84rem;font-weight:600}.drp__step-hint{color:#8cabd4;font-size:.7rem;font-weight:400}.drp__cal-nav{gap:2px;display:flex}.drp__cal-nav button{color:#888;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.drp__cal-nav button:hover{color:#fff;background:#2a2a2a}.drp__week-row{grid-template-columns:repeat(7,1fr);margin-bottom:4px;display:grid}.drp__week-day{text-align:center;color:#666;padding:4px 0;font-size:.7rem}.drp__week-day--sun{color:#d96b78}.drp__week-day--sat{color:#8cabd4}.drp__day-grid{grid-template-columns:repeat(7,1fr);gap:1px 0;display:grid}.drp__day{text-align:center;color:#ccc;cursor:pointer;z-index:1;background:0 0;border:none;border-radius:50%;padding:6px 0;font-size:.78rem;transition:background .1s,color .1s;position:relative}.drp__day:hover{color:#fff;background:#2a2a2a}.drp__day--other{color:#3a3a3a;cursor:default;pointer-events:none}.drp__day--sun{color:#c4737d}.drp__day--sat{color:#7a9ec4}.drp__day--start,.drp__day--end{z-index:2;background:#8cabd4;border-radius:50%;font-weight:700;color:#fff!important}.drp__day--in-range{color:#c8d8ec;background:#8cabd426;border-radius:0}.drp__day--start.drp__day--in-range{border-radius:50% 0 0 50%}.drp__day--end.drp__day--in-range{border-radius:0 50% 50% 0}.drp__day--start.drp__day--end{border-radius:50%}.drp__footer{border-top:1px solid #2a2a2a;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;display:flex}.drp__footer-btn{color:#888;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:4px;padding:4px 8px;font-size:.78rem;transition:color .15s,background .15s;display:flex}.drp__footer-btn:hover{color:#ccc;background:#2a2a2a}.drp__footer-btn--today{color:#8cabd4}.drp__footer-btn--today:hover{color:#a8c4e0;background:#8cabd41a}.analysis-page{background:#0f0f0f;min-height:calc(100vh - 56px);overflow-y:auto}.analysis-page__inner{flex-direction:column;gap:20px;max-width:1400px;margin:0 auto;padding:20px 24px 40px;display:flex}.analysis-page__header{flex-direction:column;align-items:center;gap:12px;display:flex}.analysis-page__title{color:#fff;text-align:center;margin:0;font-size:28px;font-weight:700}.analysis-page__controls{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.analysis-tab-group{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;display:flex;overflow:hidden}.analysis-tab{color:#888;cursor:pointer;background:0 0;border:none;padding:6px 14px;font-size:.8rem;transition:background .15s,color .15s}.analysis-tab:hover{color:#ccc;background:#222}.analysis-tab--active{color:#fff;background:#2c3e50}.analysis-date-group{align-items:center;gap:6px;display:flex}.analysis-date-group__label,.analysis-date-group__sep{color:#888;font-size:.78rem}.analysis-date-input{color:#ccc;cursor:pointer;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;padding:5px 8px;font-size:.78rem}.analysis-date-input:focus{border-color:#8cabd4;outline:none}.analysis-top-section{align-items:flex-start;gap:16px;display:flex}.analysis-stat-cards{grid-template-columns:repeat(6,1fr);gap:10px;width:100%;display:grid}.analysis-stat-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:12px 14px}.analysis-stat-card__label{color:#888;align-items:center;gap:5px;margin-bottom:6px;font-size:.72rem;display:flex}.analysis-stat-card__value{color:#e0e0e0;font-size:1.5rem;font-weight:700;line-height:1}.analysis-stat-card__value--small{font-size:1rem}.analysis-stat-card__unit{color:#888;margin-left:2px;font-size:.75rem;font-weight:400}.analysis-insights{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;flex:1;padding:14px 16px}.analysis-insights__title{color:#ccc;align-items:center;gap:6px;margin-bottom:10px;font-size:.82rem;font-weight:600;display:flex}.analysis-insights__list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.analysis-insights__item{color:#aaa;background:#111;border-left:2px solid #2a2a2a;border-radius:4px;padding:6px 10px;font-size:.78rem;line-height:1.4}.analysis-insights__item--rec{border-left-color:#8cabd4}.analysis-insights__nav-btn{color:#aaa;cursor:pointer;background:0 0;border:1px solid #333;border-radius:4px;align-items:center;padding:2px 4px;display:flex}.analysis-insights__nav-btn:disabled{opacity:.3;cursor:default}.analysis-insights__nav-btn:hover:not(:disabled){color:#fff;border-color:#666}.analysis-insights__date-label{color:#ccc;text-align:center;min-width:80px;font-size:.78rem}.analysis-insights__dots{align-items:center;gap:4px;display:flex}.analysis-insights__dot{cursor:pointer;background:#444;border-radius:50%;width:6px;height:6px;transition:background .2s}.analysis-insights__dot--active{background:#8cabd4}.analysis-insights__summary{border-bottom:1px solid #222;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:8px;padding:6px 0 8px;display:flex}.analysis-insights__summary-item{color:#aaa;font-size:.75rem}.analysis-insights__summary-item strong{color:#e0e0e0}.analysis-insights__summary-sep{color:#444;font-size:.75rem}.analysis-insights__llm-badge{color:#666;background:#222;border:1px solid #333;border-radius:10px;margin-left:auto;padding:2px 8px;font-size:.68rem}.analysis-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.analysis-panel{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:16px}.analysis-panel__title{color:#ccc;align-items:center;gap:6px;margin-bottom:12px;font-size:.82rem;font-weight:600;display:flex}.analysis-zone-toggle{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.analysis-zone-btn{color:#888;cursor:pointer;background:#111;border:1px solid #2a2a2a;border-radius:4px;padding:4px 10px;font-size:.75rem;transition:background .15s,color .15s}.analysis-zone-btn:hover{color:#ccc}.analysis-zone-btn--active{color:#fff;background:#2c3e50;border-color:#8cabd4}.analysis-pie-legend{flex-wrap:wrap;gap:8px 16px;margin-top:10px;display:flex}.analysis-pie-legend__item{color:#aaa;align-items:center;gap:6px;font-size:.75rem;display:flex}.analysis-pie-legend__dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.analysis-alert-list{flex-direction:column;gap:6px;max-height:420px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.analysis-alert-list::-webkit-scrollbar{width:4px}.analysis-alert-list::-webkit-scrollbar-track{background:0 0}.analysis-alert-list::-webkit-scrollbar-thumb{background:#333;border-radius:2px}.analysis-alert-item{background:#111;border-left:3px solid #0000;border-radius:6px;align-items:center;gap:10px;padding:8px 10px;display:flex}.analysis-alert-item--danger{border-left-color:#d96b78}.analysis-alert-item--warning{border-left-color:#d4885a}.analysis-alert-item--info{border-left-color:#8cabd4}.analysis-alert-item__content{flex:1;min-width:0}.analysis-alert-item__message{color:#ccc;white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;display:block;overflow:hidden}.analysis-alert-item__meta{color:#666;gap:8px;margin-top:3px;font-size:.7rem;display:flex}.analysis-alert-item__meta span{align-items:center;gap:3px;display:flex}.analysis-alert-item__btn{color:#888;cursor:pointer;white-space:nowrap;background:#1a1a1a;border:1px solid #333;border-radius:4px;flex-shrink:0;align-items:center;gap:4px;padding:4px 8px;font-size:.72rem;transition:color .15s,border-color .15s;display:flex}.analysis-alert-item__btn:hover{color:#fff;border-color:#555}.analysis-pattern-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.analysis-pattern-item{background:#111;border-radius:6px;align-items:center;gap:10px;padding:8px 10px;display:flex}.analysis-pattern-item__rank{color:#888;background:#2a2a2a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.72rem;font-weight:700;display:flex}.analysis-pattern-item__tags{flex-wrap:wrap;flex:1;gap:4px;display:flex}.analysis-joint-tag{border-radius:10px;padding:2px 7px;font-size:.7rem;font-weight:500}.analysis-pattern-item__stats{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.analysis-pattern-item__reba{font-size:.78rem;font-weight:700}.analysis-pattern-item__count{color:#666;font-size:.7rem}.analysis-table-wrap{overflow-x:auto}.analysis-table{border-collapse:collapse;width:100%;font-size:.78rem}.analysis-table th{text-align:left;color:#666;white-space:nowrap;border-bottom:1px solid #2a2a2a;padding:7px 10px;font-weight:500}.analysis-table td{color:#ccc;border-bottom:1px solid #1e1e1e;padding:7px 10px}.analysis-table tr:last-child td{border-bottom:none}.analysis-table tr:hover td{background:#111}.analysis-table__rank{color:#666;font-weight:600}.analysis-table__worker{font-weight:600}.analysis-reba-badge{border-radius:10px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-block}.analysis-chart-tooltip{color:#ccc;background:#1e1e1e;border:1px solid #333;border-radius:6px;padding:8px 12px;font-size:.78rem}.analysis-chart-tooltip__label{color:#888;margin-bottom:4px;font-size:.72rem}.analysis-empty{text-align:center;color:#555;padding:40px 0;font-size:.82rem}.analysis-modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.analysis-modal{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:10px;flex-direction:column;width:480px;max-width:90vw;max-height:90vh;display:flex;overflow-y:auto}.analysis-modal__header{border-bottom:1px solid #2a2a2a;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.analysis-modal__header--danger{border-top:3px solid #d96b78}.analysis-modal__header--warning{border-top:3px solid #d4885a}.analysis-modal__header--info{border-top:3px solid #8cabd4}.analysis-modal__header-left{color:#e0e0e0;align-items:center;gap:8px;font-size:.88rem;font-weight:600;display:flex}.analysis-modal__close{color:#888;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;display:flex}.analysis-modal__close:hover{color:#fff;background:#2a2a2a}.analysis-modal__body{flex-direction:column;gap:14px;padding:16px;display:flex}.analysis-modal__snapshot{background:#111;border-radius:6px;height:280px;overflow:hidden}.analysis-modal__snapshot img{object-fit:cover;width:100%;height:100%}.analysis-modal__snapshot-empty{color:#444;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;height:100%;font-size:.78rem;display:flex}.analysis-modal__info-grid{flex-direction:column;gap:6px;display:flex}.analysis-modal__info-row{background:#111;border-radius:4px;justify-content:space-between;align-items:center;padding:6px 10px;font-size:.78rem;display:flex}.analysis-modal__info-label{color:#888;align-items:center;gap:5px;display:flex}.analysis-modal__metrics{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.analysis-modal__metric{text-align:center;background:#111;border-radius:6px;padding:10px}.analysis-modal__metric-label{color:#666;justify-content:center;align-items:center;gap:4px;margin-bottom:6px;font-size:.7rem;display:flex}.analysis-modal__metric-value{color:#ccc;font-size:1.1rem;font-weight:700}.analysis-modal__message{color:#aaa;background:#111;border-radius:4px;padding:10px 12px;font-size:.8rem;line-height:1.5}.analysis-modal__footer{border-top:1px solid #2a2a2a;justify-content:flex-end;gap:8px;padding:12px 16px;display:flex}.analysis-modal__btn{cursor:pointer;color:#ccc;background:#2a2a2a;border:1px solid #333;border-radius:5px;padding:7px 16px;font-size:.8rem;transition:background .15s}.analysis-modal__btn:hover{background:#333}.analysis-modal__btn--primary{color:#fff;background:#2c3e50;border-color:#8cabd4}.analysis-modal__btn--primary:hover{background:#34495e}@media (width<=1100px){.analysis-stat-cards{grid-template-columns:repeat(3,1fr)}}@media (width<=900px){.analysis-grid{grid-template-columns:1fr}.analysis-stat-cards{grid-template-columns:repeat(3,1fr)}}@media (width<=600px){.analysis-stat-cards{grid-template-columns:repeat(2,1fr)}.analysis-page__header{flex-direction:column;align-items:flex-start}.analysis-page__title{font-size:1.3rem}}.user-page{background-color:#0d0d0d;flex-direction:column;align-items:center;width:100%;min-height:100%;padding:40px 24px 48px;display:flex}.user-page__header{width:100%;max-width:900px;margin-bottom:30px}.user-page__title{color:#fff;text-align:center;margin:0;font-size:24px;font-weight:700}.user-tabs-container{border-bottom:1px solid #333;width:100%;max-width:900px;margin-bottom:24px}.user-tabs{gap:24px;display:flex}.user-tab{color:#888;cursor:pointer;background:0 0;border:none;padding:12px 16px;font-size:15px;font-weight:600;transition:color .2s;position:relative}.user-tab:hover{color:#ccc}.user-tab--active{color:#8cabd4}.user-tab--active:after{content:"";background-color:#8cabd4;height:2px;position:absolute;bottom:-1px;left:0;right:0}.user-content{flex-direction:column;gap:24px;width:100%;max-width:900px;display:flex}.user-card{background:#151515;border:1px solid #2a2a2a;border-radius:12px;padding:30px}.user-card--profile{align-items:center;gap:24px;display:flex}.user-profile-avatar{color:#000;background-color:#8cabd4;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;font-size:32px;font-weight:700;display:flex}.user-profile-info{flex-direction:column;gap:6px;display:flex}.user-profile-name{color:#fff;font-size:20px;font-weight:700}.user-profile-email{color:#888;margin-bottom:4px;font-size:14px}.user-profile-role{color:#a0a0a0;background:#222;border-radius:12px;align-self:flex-start;padding:4px 12px;font-size:12px;font-weight:600}.user-stats-row{gap:24px;display:flex}.user-card--stat{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px;display:flex}.user-stat-icon{color:#8cabd4;margin-bottom:8px}.user-stat-value{color:#fff;font-size:26px;font-weight:700}.user-stat-label{color:#888;font-size:14px;font-weight:500}.user-card--list{padding:0;overflow:hidden}.user-list-title{color:#fff;border-bottom:1px solid #2a2a2a;margin:0;padding:24px 30px;font-size:16px;font-weight:700}.user-list-item{border-bottom:1px solid #222;justify-content:space-between;align-items:center;padding:20px 30px;display:flex}.user-list-item:last-child{border-bottom:none}.user-list-label{color:#888;font-size:14px;font-weight:500}.user-list-value{color:#fff;font-size:15px;font-weight:500}.user-btn-change-pw{color:#fff;cursor:pointer;background:#262626;border:1px solid #333;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.user-btn-change-pw:hover{background:#333}@media (width<=768px){.user-stats-row{flex-direction:column}}.user-pw-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.user-pw-modal{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;width:100%;max-width:400px;padding:32px}.user-pw-modal__title{color:#fff;margin:0 0 24px;font-size:18px;font-weight:700}.user-pw-form{flex-direction:column;gap:10px;display:flex}.user-pw-label{color:#888;margin-top:6px;font-size:13px}.user-pw-input{color:#fff;background:#111;border:1px solid #333;border-radius:6px;outline:none;padding:10px 14px;font-size:14px}.user-pw-input:focus{border-color:#8cabd4}.user-pw-error{color:#d96b78;margin:4px 0 0;font-size:13px}.user-pw-success{color:#5bb89a;margin:4px 0 0;font-size:13px}.user-pw-actions{justify-content:flex-end;gap:10px;margin-top:12px;display:flex}.user-pw-btn{cursor:pointer;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .2s}.user-pw-btn:disabled{opacity:.5;cursor:not-allowed}.user-pw-btn--cancel{color:#aaa;background:#262626;border:1px solid #333}.user-pw-btn--submit{color:#000;background:#8cabd4}.user-factory-select{color:#fff;appearance:none;background:#111;border:1px solid #333;border-radius:6px;outline:none;padding:10px 14px;font-size:14px}.user-factory-select:focus{border-color:#8cabd4}.user-factory-select option{color:#fff;background:#1a1a1a}.user-list-value-row{align-items:center;gap:16px;display:flex}.user-stat-value--factory{font-size:18px}.device-page{background-color:#0d0d0d;flex-direction:column;align-items:center;width:100%;min-height:100%;padding:40px 24px 48px;display:flex}.device-page__header{width:100%;max-width:900px;margin-bottom:24px}.device-page__title{color:#fff;text-align:center;margin:0;font-size:28px;font-weight:700}.device-section{background:#1a1a1a;border:1px solid #333;border-radius:12px;width:100%;max-width:900px;padding:1.5rem 2rem}.device-section__header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.device-section__label{color:#fff;margin:0;font-size:1.125rem;font-weight:700}.device-btn{cursor:pointer;color:#fff;background:#262626;border:1px solid #333;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:all .2s}.device-btn:hover:not(:disabled){background:#333}.device-btn:disabled{opacity:.6;cursor:not-allowed}.device-btn--primary{color:#0d0d0d;background:#8cabd4;border-color:#8cabd4}.device-btn--primary:hover:not(:disabled){background:#7a9bc4}.device-btn--outline{color:#8cabd4;background:0 0;border:1.5px solid #8cabd4;align-items:center;gap:6px;padding:8px 18px;display:flex}.device-btn--outline:hover{background:#8cabd41a}.device-camera-list{flex-direction:column;gap:.5rem;display:flex}.device-camera-card{background:#111;border:1px solid #2a2a2a;border-radius:10px;justify-content:space-between;align-items:center;padding:20px 24px;transition:all .2s;display:flex}.device-camera-card:hover{background:#1a1a1a;border-color:#8cabd4;transform:translateY(-1px);box-shadow:0 4px 12px #8cabd414}.device-camera-card__info{flex:1;align-items:center;gap:20px;min-width:0;display:flex}.device-camera-card__icon{color:#8cabd4;background:#8cabd41a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.device-camera-card__details{flex-direction:column;gap:4px;min-width:0;display:flex}.device-camera-card__name-row{align-items:center;gap:8px;display:flex}.device-camera-card__name{color:#fff;margin:0;font-size:16px;font-weight:600}.device-camera-card__badge{color:#9ca3af;background:#9ca3af1a;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600}.device-camera-card__badge--active{color:#22c55e;background:#22c55e1a}.device-camera-card__zone{color:#b0b0b0;margin:0;font-size:13px}.device-camera-card__rtsp{color:#555;white-space:nowrap;text-overflow:ellipsis;max-width:400px;margin:0;font-family:monospace;font-size:11px;overflow:hidden}.device-camera-card__edge-host{color:#4a9eff;align-items:center;gap:4px;margin:2px 0 0;font-family:monospace;font-size:11px;display:flex}.device-form__section-label{color:var(--text-muted,#888);text-transform:uppercase;letter-spacing:.04em;border-top:1px solid #ffffff0f;margin-top:4px;padding:4px 0 2px;font-size:.75rem;font-weight:600}.device-camera-card__actions{flex-shrink:0;gap:8px;display:flex}.device-icon-btn{color:#b0b0b0;cursor:pointer;background:0 0;border:1px solid #333;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;transition:all .2s;display:flex}.device-icon-btn:hover{color:#8cabd4;background:#ffffff0d;border-color:#8cabd4}.device-icon-btn--active{color:#22c55e;border-color:#22c55e4d}.device-icon-btn--active:hover{color:#22c55e;background:#22c55e0d;border-color:#22c55e}.device-icon-btn--danger:hover{color:#ef4444;background:#ef44441a;border-color:#ef4444}.device-empty{text-align:center;color:#666;padding:56px 32px}.device-empty__text{color:#666;margin:16px 0 4px;font-size:16px}.device-empty__sub{color:#444;margin:0;font-size:13px}.device-modal-overlay{z-index:1000;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.device-modal{background:#0d0d0d;border:1px solid #333;border-radius:12px;width:90%;max-width:580px;max-height:90vh;padding:24px 32px;overflow-y:auto}.device-modal__header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.device-modal__title{color:#fff;margin:0;font-size:20px;font-weight:700}.device-modal__close{color:#888;cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;transition:color .2s;display:flex}.device-modal__close:hover{color:#fff}.device-modal__tabs{gap:8px;margin-bottom:1.25rem;display:flex}.device-modal__tab{color:#888;cursor:pointer;background:0 0;border:1px solid #333;border-radius:6px;flex:1;padding:8px;font-size:13px;font-weight:600;transition:all .15s}.device-modal__tab--active{color:#8cabd4;background:#8cabd41a;border-color:#8cabd4}.device-modal__form{flex-direction:column;gap:16px;display:flex}.device-form__group{flex-direction:column;gap:6px;display:flex}.device-form__row{gap:8px;display:flex}.device-form__label{color:#fff;font-size:13px;font-weight:500}.device-form__input{box-sizing:border-box;color:#fff;background:#1a1a1a;border:1px solid #333;border-radius:8px;width:100%;padding:10px 14px;font-size:14px;transition:all .2s}.device-form__input:focus{background:#222;border-color:#8cabd4;outline:none}.device-form__input::placeholder{color:#555}.device-form__input--textarea{resize:vertical}.device-form__preview{color:#8cabd4;word-break:break-all;background:#1a1a1a;border:1px solid #333;border-radius:8px;padding:10px 14px;font-family:monospace;font-size:12px}.device-form__hint{color:#666;margin:0;font-size:11px}.device-form__msg{font-size:13px}.device-form__msg--ok{color:#22c55e}.device-form__msg--err{color:#ef4444}.device-form__section-toggle{color:#aaa;cursor:pointer;text-align:left;background:0 0;border:1px solid #333;border-radius:6px;width:100%;padding:6px 12px;font-size:13px;transition:border-color .2s,color .2s}.device-form__section-toggle:hover{color:#ccc;border-color:#555}.device-form__actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.software-page{background-color:#0d0d0d;flex-direction:column;align-items:center;width:100%;min-height:100%;padding:40px 24px 48px;display:flex}.software-page__header{width:100%;max-width:900px;margin-bottom:24px}.software-page__title{color:#fff;text-align:center;margin:0;font-size:28px;font-weight:700}.software-section{background:#1a1a1a;border:1px solid #333;border-radius:12px;width:100%;max-width:900px;margin-bottom:24px;padding:1.5rem 2rem}.software-section--update{border-color:#8cabd44d}.software-section__header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.software-section__label{color:#fff;margin:0;font-size:1.125rem;font-weight:700}.software-btn{cursor:pointer;color:#fff;background:#262626;border:1px solid #333;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.software-btn:hover:not(:disabled){background:#333}.software-btn:disabled{opacity:.6;cursor:not-allowed}.software-btn--primary{color:#0d0d0d;background:#8cabd4;border-color:#8cabd4}.software-btn--primary:hover:not(:disabled){background:#7a9bc4}.software-btn--large{width:100%;padding:14px 32px;font-size:16px}.software-btn--outline{color:#8cabd4;background:0 0;border:1.5px solid #8cabd4;padding:8px 18px}.software-btn--outline:hover:not(:disabled){background:#8cabd41a}.software-icon--spin{animation:1s linear infinite spin}.software-version-card{background:#111;border:1px solid #2a2a2a;border-radius:10px;flex-direction:column;gap:24px;padding:24px;display:flex}.software-version-info{flex-direction:column;gap:16px;display:flex}.software-version-row{border-bottom:1px solid #222;justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.software-version-row:last-child{border-bottom:none;padding-bottom:0}.software-version-label{color:#a0a0a0;font-size:15px;font-weight:500}.software-version-value{color:#fff;font-size:16px;font-weight:600}.software-version-time{color:#888;font-size:14px;font-weight:400}.software-status-area{border-top:1px dashed #333;padding-top:20px}.software-status{border-radius:8px;align-items:center;gap:12px;padding:16px;font-size:16px;font-weight:600;display:flex}.software-status--success{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e33}.software-status--warning{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b33}.software-release-notes{background:#111;border:1px solid #2a2a2a;border-radius:8px;margin-bottom:24px;padding:16px 20px}.software-release-notes pre{color:#d1d5db;white-space:pre-wrap;margin:0;font-family:inherit;font-size:14px;line-height:1.6}.software-action-area{justify-content:center;display:flex}.software-progress-area{background:#111;border:1px solid #2a2a2a;border-radius:8px;flex-direction:column;gap:12px;padding:24px;display:flex}.software-progress-text{color:#fff;justify-content:space-between;font-size:14px;font-weight:600;display:flex}.software-progress-bar{background:#333;border-radius:4px;width:100%;height:8px;overflow:hidden}.software-progress-fill{background:#8cabd4;border-radius:4px;height:100%;transition:width .3s}.software-empty{text-align:center;padding:40px}.software-empty__text{color:#666;font-size:15px}.login-page{background-color:#0d0d0d;flex-direction:column;min-height:100vh;display:flex}.login-header{z-index:100;background-color:#1a1a1a;border-bottom:1px solid #333;justify-content:space-between;align-items:center;height:70px;padding:0 24px;display:flex;position:fixed;top:0;left:0;right:0}.login-header__left{align-items:center;gap:16px;display:flex}.login-header__logo{object-fit:contain;border-radius:8px;width:40px;height:40px}.login-header__title{color:#fff;letter-spacing:1px;margin:0;font-size:18px;font-weight:700;line-height:1.2}.login-header__subtitle{color:#b0b0b0;margin:0;font-size:12px;line-height:1.4}.login-header__datetime{background-color:#1a1a1a;border:1px solid #333;border-radius:8px;align-items:center;gap:14px;padding:8px 20px;display:flex}.login-header__date{color:#b0b0b0;font-size:16px;font-weight:500}.login-header__divider{background-color:#333;width:1px;height:22px}.login-header__time{color:#f0e0ea;font-variant-numeric:tabular-nums;letter-spacing:2px;font-size:24px;font-weight:700}.login-main{flex:1;justify-content:center;align-items:center;margin-top:70px;padding:32px;display:flex}.login-box{flex-direction:column;align-items:center;width:100%;max-width:450px;display:flex}.login-box__logo-section{flex-direction:column;align-items:center;margin-bottom:48px;display:flex}.login-box__big-logo{border-radius:16px;width:100px;height:100px;margin-bottom:24px}.login-box__title{color:#fff;text-align:center;margin:0 0 4px;font-size:24px;font-weight:700}.login-box__subtitle{color:#b0b0b0;text-align:center;margin:0;font-size:16px}.login-form{flex-direction:column;gap:24px;width:100%;display:flex}.login-form__group{flex-direction:column;gap:8px;display:flex}.login-form__label{color:#fff;letter-spacing:1px;font-size:14px;font-weight:500}.login-form__input{box-sizing:border-box;color:#fff;background:#ffffff0d;border:2px solid #ffffff1a;border-radius:8px;width:100%;padding:16px;font-size:16px;transition:all .3s}.login-form__input:focus{background:#ffffff14;border-color:#8cabd4;outline:none}.login-form__input::placeholder{color:#666}.login-form__password-wrap{width:100%;position:relative}.login-form__password-wrap .login-form__input{padding-right:48px}.login-form__password-toggle{color:#b0b0b0;cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-form__password-toggle:hover{color:#fff}.login-form__password-toggle:active{color:#8cabd4}.login-form__remember-row{color:#b0b0b0;align-items:center;margin-top:-8px;font-size:14px;display:flex}.login-form__checkbox-label{cursor:pointer;align-items:center;gap:8px;display:flex}.login-form__checkbox-label input{cursor:pointer;width:16px;height:16px}.login-form__submit{color:#0d0d0d;cursor:pointer;background:#8cabd4;border:none;border-radius:8px;width:100%;margin-top:8px;padding:16px;font-size:18px;font-weight:600;transition:all .2s}.login-form__submit:hover:not(:disabled){background:#7a9bc4;transform:translateY(-2px);box-shadow:0 4px 12px #8cabd44d}.login-form__submit:disabled{opacity:.6;cursor:not-allowed}.login-box__signup{text-align:center;color:#b0b0b0;margin-top:32px;font-size:16px}.login-box__signup-link{color:#8cabd4;cursor:pointer;margin-left:6px;font-weight:600}.login-box__signup-link:hover{text-decoration:underline}.login-error{color:#d96b78;text-align:center;background:#d96b781a;border:1px solid #d96b78;border-radius:8px;width:100%;margin-bottom:16px;padding:12px;font-size:14px}.login-footer{text-align:center;color:#666;padding:24px;font-size:12px}.register-page{background-color:#0d0d0d;flex-direction:column;min-height:100vh;display:flex}.register-header{z-index:100;background-color:#1a1a1a;border-bottom:1px solid #333;justify-content:space-between;align-items:center;height:70px;padding:0 24px;display:flex;position:fixed;top:0;left:0;right:0}.register-header__left{align-items:center;gap:16px;display:flex}.register-header__logo{object-fit:contain;border-radius:8px;width:40px;height:40px}.register-header__title{color:#fff;letter-spacing:1px;margin:0;font-size:18px;font-weight:700;line-height:1.2}.register-header__subtitle{color:#b0b0b0;margin:0;font-size:12px;line-height:1.4}.register-header__datetime{background-color:#1a1a1a;border:1px solid #333;border-radius:8px;align-items:center;gap:14px;padding:8px 20px;display:flex}.register-header__date{color:#b0b0b0;font-size:16px;font-weight:500}.register-header__divider{background-color:#333;width:1px;height:22px}.register-header__time{color:#f0e0ea;font-variant-numeric:tabular-nums;letter-spacing:2px;font-size:24px;font-weight:700}.register-main{flex:1;justify-content:center;align-items:center;margin-top:70px;padding:32px;display:flex}.register-box{flex-direction:column;align-items:center;width:100%;max-width:560px;display:flex}.register-box__title{color:#fff;text-align:center;margin:0 0 4px;font-size:32px;font-weight:700}.register-box__subtitle{color:#b0b0b0;text-align:center;margin:0 0 40px;font-size:16px}.register-form{flex-direction:column;gap:20px;width:100%;display:flex}.register-form__group{flex-direction:column;gap:8px;display:flex}.register-form__label{color:#fff;font-size:14px;font-weight:500}.register-form__input{box-sizing:border-box;color:#fff;background:#ffffff0d;border:2px solid #ffffff1a;border-radius:8px;width:100%;padding:12px 16px;font-size:16px;transition:all .3s}.register-form__input:focus{background:#ffffff14;border-color:#8cabd4;outline:none}.register-form__input::placeholder{color:#666}.register-form__input--err{border-color:#d96b78!important}.register-form__input--ok{border-color:#6bd978!important}.register-form__username-row{gap:8px;display:flex}.register-form__username-row .register-form__input{flex:1}.register-form__check-btn{color:#8cabd4;cursor:pointer;white-space:nowrap;background:#8cabd426;border:2px solid #8cabd4;border-radius:8px;flex-shrink:0;align-items:center;gap:4px;padding:0 16px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.register-form__check-btn:hover:not(:disabled){background:#8cabd44d}.register-form__check-btn:disabled{opacity:.4;cursor:not-allowed}.register-form__status{align-items:center;gap:4px;font-size:13px;display:flex}.register-form__status--ok{color:#6bd978}.register-form__status--err{color:#d96b78}.register-form__password-wrap{width:100%;position:relative}.register-form__password-wrap .register-form__input{padding-right:48px}.register-form__password-toggle{color:#b0b0b0;cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.register-form__password-toggle:hover{color:#fff}.register-form__password-toggle:active{color:#8cabd4}.register-form__submit{color:#0d0d0d;cursor:pointer;background:#8cabd4;border:none;border-radius:8px;width:100%;margin-top:8px;padding:16px;font-size:18px;font-weight:600;transition:all .2s}.register-form__submit:hover:not(:disabled){background:#7a9bc4;transform:translateY(-2px);box-shadow:0 4px 12px #8cabd44d}.register-form__submit:disabled{opacity:.6;cursor:not-allowed}.register-box__login{text-align:center;color:#b0b0b0;margin-top:32px;font-size:16px}.register-box__login-link{color:#8cabd4;cursor:pointer;margin-left:6px;font-weight:600}.register-box__login-link:hover{text-decoration:underline}.register-error{color:#d96b78;text-align:center;background:#d96b781a;border:1px solid #d96b78;border-radius:8px;width:100%;margin-bottom:16px;padding:12px;font-size:14px}.register-success{color:#6bd978;text-align:center;background:#6bd9781a;border:1px solid #6bd978;border-radius:8px;width:100%;margin-bottom:16px;padding:12px;font-size:14px}.register-form__select{box-sizing:border-box;color:#fff;cursor:pointer;appearance:none;background:#ffffff0d url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") right 14px center no-repeat;border:2px solid #ffffff1a;border-radius:8px;width:100%;padding:12px 36px 12px 16px;font-size:16px;transition:all .3s}.register-form__select:focus{background-color:#ffffff14;border-color:#8cabd4;outline:none}.register-form__select option{color:#fff;background:#1a1a1a}.register-form__factory-loading{color:#888;align-items:center;gap:8px;padding:10px 0;font-size:14px;display:flex}@keyframes register-spin{to{transform:rotate(360deg)}}.register-spin{animation:.8s linear infinite register-spin}.register-footer{text-align:center;color:#666;padding:24px;font-size:12px}
