*{margin:0;padding:0;box-sizing:border-box}html{height:100%}#app{height:100%;min-height:100%;display:flex;flex-direction:column}:root{--primary-color: #6366f1;--primary-dark: #4f46e5;--primary-light: #818cf8;--secondary-color: #8b5cf6;--success-color: #10b981;--error-color: #ef4444;--warning-color: #f59e0b;--bg-gradient-start: #667eea;--bg-gradient-end: #764ba2;--card-bg: rgba(255, 255, 255, .98);--card-shadow: 0 20px 60px rgba(0, 0, 0, .15);--border-color: #e5e7eb;--text-primary: #1f2937;--text-secondary: #6b7280;--surface: #f9fafb;--surface-hover: #f3f4f6}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#e0f2fe;background-attachment:fixed;color:var(--text-primary);height:100vh;height:100dvh;padding:max(8px,env(safe-area-inset-top)) max(8px,env(safe-area-inset-right)) max(8px,env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left));line-height:1.5;overflow:hidden;margin:0}.container{max-width:1800px;margin:0 auto;background:#ffffffd1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:16px;box-shadow:var(--card-shadow);padding:12px;overflow:hidden;height:100%;display:flex;flex-direction:column}.container header{text-align:center;margin-bottom:8px;padding-bottom:8px;border-bottom:2px solid var(--border-color);position:relative;flex-shrink:0}.container header:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));border-radius:2px}.container header h1{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:clamp(1.5em,3vw,2.2em);font-weight:700;letter-spacing:-.5px;margin:0}.desktop-header-row{position:relative;display:flex;align-items:center;justify-content:center}.desktop-header-row .language-switcher{position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:.85rem;padding:.25rem .5rem;border-radius:6px;border:1px solid var(--border-color, #ccc);background:var(--panel-bg, #fff);color:inherit;max-width:8.5rem}.main-layout{display:flex;gap:12px;flex:1;min-height:0;overflow:hidden;position:relative;--sidebar-width: 360px}.left-sidebar{width:var(--sidebar-width);flex-shrink:0;display:flex;flex-direction:column;gap:16px;overflow:hidden;min-height:0;padding-right:8px;transition:width .28s ease,opacity .28s ease,padding .28s ease,gap .28s ease}.main-layout--sidebar-collapsed .left-sidebar{width:0;max-height:0;min-height:0;flex:0 0 0;padding:0;gap:0;opacity:0;pointer-events:none;overflow:hidden}.left-sidebar::-webkit-scrollbar{width:6px}.left-sidebar::-webkit-scrollbar-track{background:transparent}.left-sidebar::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:3px}.left-sidebar::-webkit-scrollbar-thumb:hover{background:#6366f180}.right-content{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.tabs{display:flex;gap:6px;margin-bottom:8px;background:#f9fafbb8;padding:4px;border-radius:10px;box-shadow:inset 0 2px 4px #0000000f;flex-shrink:0}.tab-btn{padding:8px 16px;border:none;background:transparent;color:var(--text-secondary);font-size:clamp(13px,1.3vw,15px);font-weight:600;cursor:pointer;border-radius:8px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.tab-btn:hover{color:var(--primary-color);background:#6366f114}.tab-btn.active{color:#fff;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));box-shadow:0 4px 12px #6366f14d;transform:translateY(-1px)}.tab-content{display:none}.tab-content.active{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.tab-content--panel.active{overflow:hidden}.tab-panel-shell{flex:1;min-height:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;background:#ffffff7a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:10px;padding:12px;border:1px solid rgba(203,213,225,.68);box-shadow:0 2px 8px #00000014}.tab-panel-shell--room{overflow:hidden;padding:clamp(4px,.8vw,10px);min-height:0}.tab-panel-shell--room .room-layout-panel{flex:1;min-height:0;height:100%}.connection-section,.status-section{background:#ffffffad;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px;border-radius:10px;border:1px solid rgba(229,231,235,.65);box-shadow:0 2px 6px #0000000d;transition:all .3s ease;flex-shrink:0}.alert-history-card{background:#ffffffad;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px;border-radius:10px;border:1px solid rgba(229,231,235,.65);box-shadow:0 2px 6px #0000000d;transition:all .3s ease;flex:1;min-height:120px;display:flex;flex-direction:column;overflow:hidden}.connection-section:hover,.status-section:hover,.alert-history-card:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-2px)}.alert-history-card:hover{transform:none}.connection-section h2,.status-section h2,.alert-history-card h2{color:var(--primary-color);margin-bottom:10px;font-size:clamp(1em,1.5vw,1.1em);font-weight:700;display:flex;align-items:center;gap:6px}.connection-section h2:before,.status-section h2:before,.alert-history-card h2:before{content:"";width:4px;height:24px;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:2px}.alert-history-list{overflow-y:auto;overflow-x:hidden;padding-right:6px}.alert-history-root--scroll{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.alert-history-root--scroll .alert-history-list{flex:1;min-height:0}.alert-history-empty{font-size:13px;color:var(--text-secondary);padding:8px 0}.alert-history-list::-webkit-scrollbar{width:8px}.alert-history-list::-webkit-scrollbar-track{background:#0f172a14;border-radius:8px}.alert-history-list::-webkit-scrollbar-thumb{background:#4755698c;border-radius:8px}.alert-history-list::-webkit-scrollbar-thumb:hover{background:#475569bf}.alert-history-item{background:#fff;border:1px solid var(--border-color);border-radius:8px;padding:8px 10px;margin-bottom:8px}.alert-history-id{font-weight:700;margin-bottom:4px}.alert-history-xy,.alert-history-time{font-size:12px;color:var(--text-secondary)}.form-group{margin-bottom:10px}.form-group label{display:block;margin-bottom:4px;font-weight:600;color:var(--text-primary);font-size:clamp(11px,1.2vw,13px);letter-spacing:.2px}.form-group input{width:100%;padding:6px 10px;border:2px solid var(--border-color);border-radius:6px;font-size:clamp(12px,1.3vw,14px);transition:all .3s ease;background:#fff;color:var(--text-primary)}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a;transform:translateY(-1px)}.form-group input::placeholder{color:var(--text-secondary);opacity:.6}.button-group{display:flex;gap:10px;margin-top:16px}.btn{padding:12px 24px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;letter-spacing:.3px}.btn-primary{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;box-shadow:0 4px 12px #6366f14d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;box-shadow:0 4px 12px #6b72804d}.btn-secondary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6b728066}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-small{padding:8px 16px;font-size:13px;background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;margin-top:12px;box-shadow:0 2px 8px #6b728033}.status-indicator{margin-bottom:16px}.status-indicator span{display:inline-flex;align-items:center;border-radius:12px;font-weight:600;font-size:14px;box-shadow:0 2px 8px #00000026;position:relative;padding:10px 20px 10px 36px}.status-indicator span:before{content:"";position:absolute;left:14px;width:8px;height:8px;border-radius:50%;background:#fff;box-shadow:0 0 8px #fffc}.status-connected{background:linear-gradient(135deg,var(--success-color),#059669);color:#fff}.status-disconnected{background:linear-gradient(135deg,var(--error-color),#dc2626);color:#fff}.device-online-row{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;background:#fff;border-radius:8px;border:1px solid var(--border-color)}.device-online-label{font-size:13px;color:var(--text-secondary)}.device-online-row span:last-child{font-weight:600;font-size:13px}.device-status-online{color:var(--success-color)}.device-status-offline{color:var(--error-color)}.status-section--compact{padding:10px 12px}.status-section--compact h2{display:none}.status-row-compact{display:flex;flex-wrap:wrap;align-items:center;gap:6px 8px;margin-bottom:8px;padding:8px 10px;background:#fff;border-radius:8px;border:1px solid var(--border-color);font-size:clamp(12px,.78rem + .15vw,13px)}.status-row-compact--connection{font-weight:600}.status-row-compact__pill{display:inline-block;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:600}.status-row-compact__sep{color:var(--text-secondary);font-weight:400}.status-row-compact--frames{color:var(--text-secondary);font-weight:500}.device-online-row--compact{margin-bottom:0}.stats{display:flex;flex-direction:column;gap:6px}.stat-item{display:flex;flex-direction:column;padding:8px;background:#fff;border-radius:8px;border:1px solid var(--border-color);box-shadow:0 2px 4px #0000000a;transition:all .3s ease}.stat-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:var(--primary-light)}.stat-item label{font-weight:500;color:var(--text-secondary);font-size:clamp(10px,1.1vw,12px);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.stat-item span{font-weight:700;color:var(--text-primary);font-size:clamp(14px,2vw,18px);line-height:1}.extended-stats{margin-top:8px;padding:10px;border-radius:8px;background:#bee6ff59;border:1px solid #bae6fd;display:flex;flex-direction:column;gap:6px}.extended-title{font-weight:600;color:#0369a1;font-size:clamp(12px,1.3vw,14px);letter-spacing:.5px}.extended-item{display:flex;justify-content:space-between;align-items:center;font-size:clamp(12px,1.3vw,14px);color:#0f172a}.extended-label{font-weight:600;color:#0369a1}.extended-value{font-weight:600}.person-count-display{margin-top:12px;padding:12px;background:#e0f2fe;border-radius:10px;box-shadow:0 2px 8px #0000001a;text-align:center;border:1px solid #bae6fd;flex-shrink:0}.person-count-label{color:#0369a1;font-size:clamp(12px,1.3vw,14px);font-weight:600;margin-bottom:4px;letter-spacing:1px}.person-count-value{color:#0369a1;font-size:clamp(32px,6vw,56px);font-weight:700;line-height:1}.status-options{margin-top:10px;display:flex;flex-direction:column;gap:6px}.checkbox-inline{display:flex;align-items:center;gap:8px;font-size:clamp(12px,1.3vw,14px);color:#0369a1;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-inline input[type=checkbox]{width:18px;height:18px;accent-color:#0284c7;cursor:pointer}.visualization-section{background:#ffffff7a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:10px;padding:8px;box-shadow:0 2px 8px #00000014;border:1px solid rgba(203,213,225,.68);flex:1;min-height:0;display:flex;flex-direction:column}.visualization-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;flex-shrink:0;padding:0 4px}.visualization-track-id{margin-right:8px}.upgrade-try-resume{margin:8px 0 4px}.upgrade-status-hint{color:#0369a1;font-size:13px}.upgrade-status-hint span{font-weight:500}.visualization-header-actions{display:flex;align-items:center;gap:12px}.visualization-header-actions .install-mode-group{display:flex;align-items:center;gap:8px}.visualization-header-actions .install-mode-group>label{font-size:13px;font-weight:500;color:var(--text-secondary);margin:0}.visualization-header-actions .install-mode-group .install-mode-options{gap:12px}.reset-view-btn{padding:6px 12px;font-size:13px;font-weight:500;color:var(--primary-color);background:#6366f11a;border:1px solid var(--primary-light);border-radius:8px;cursor:pointer}.reset-view-btn:hover{background:#6366f133}.visualization-section h2{color:var(--primary-color);margin:0;font-size:clamp(1em,1.5vw,1.1em);font-weight:700}#trackCanvas,.track-canvas{display:block;width:100%;height:100%;flex:1;min-height:0;border-radius:8px;background:#ffffff47;overflow:hidden;touch-action:none}.log-sidebar{position:fixed;top:0;right:0;width:400px;height:100vh;background:#e0f2fe;padding:20px;border-left:2px solid #bae6fd;box-shadow:-4px 0 24px #00000026;display:flex;flex-direction:column;z-index:1000;transform:translate(100%);transition:transform .3s ease-in-out;overflow-y:auto;pointer-events:none}.log-sidebar.open{transform:translate(0);pointer-events:auto}.log-toggle-btn{position:fixed;top:50%;right:0;transform:translateY(-50%);width:48px;height:80px;background:linear-gradient(135deg,#0284c7,#0369a1);border:none;border-radius:12px 0 0 12px;color:#fff;font-size:24px;cursor:pointer;z-index:1001;box-shadow:-2px 0 12px #0003;transition:all .3s ease;display:flex;align-items:center;justify-content:center;padding:0}.log-toggle-btn:hover{width:52px;box-shadow:-4px 0 16px #0000004d}.log-toggle-btn.active{right:400px}.sidebar-toggle-btn{position:absolute;top:50%;left:var(--sidebar-width);transform:translate(-100%,-50%);width:22px;height:56px;background:linear-gradient(135deg,var(--primary-color, #2f6dbe),var(--primary-dark, #24579a));border:none;border-radius:0 8px 8px 0;color:#fff;font-size:12px;cursor:pointer;z-index:20;box-shadow:2px 0 8px #0000001f;transition:left .28s ease,width .2s ease,box-shadow .2s ease,transform .28s ease;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.main-layout--sidebar-collapsed .sidebar-toggle-btn{left:0;transform:translateY(-50%)}.sidebar-toggle-btn:hover{width:26px;box-shadow:2px 0 12px #0000002e}.sidebar-toggle-icon{line-height:1;-webkit-user-select:none;user-select:none}.log-toggle-icon{font-size:24px;transition:transform .3s ease;display:inline-block}.log-toggle-btn.active .log-toggle-icon{transform:rotate(180deg)}.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:2px solid #bae6fd;flex-shrink:0}.log-header h2,.log-header .log-header-title{color:#0369a1;margin:0;font-size:1.1em;font-weight:700}.log-header .log-header-title{cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 8px;border-radius:6px;transition:background .2s}.log-header .log-header-title:hover{background:#0284c71a}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;color:#0369a1}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#0284c7}.checkbox-label span{font-weight:500}.log-container{background:linear-gradient(135deg,#0f172a,#1e293b);color:#10b981;padding:16px;border-radius:10px;flex:1;min-height:200px;overflow-y:auto;font-family:SF Mono,Monaco,Consolas,Courier New,monospace;font-size:12px;margin-bottom:12px;border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 2px 8px #0000004d;line-height:1.6}.log-entry{margin-bottom:5px;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.1)}.log-info{color:#60a5fa}.log-success{color:#34d399}.log-warning{color:#fbbf24}.log-error{color:#f87171}.log-container::-webkit-scrollbar{width:10px}.log-container::-webkit-scrollbar-track{background:#0f172a80;border-radius:10px}.log-container::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#475569,#334155);border-radius:10px;border:2px solid rgba(15,23,42,.5)}.log-container::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#64748b,#475569)}.config-panel{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.config-panel__body{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px;flex:1;min-height:0;align-items:stretch}.config-col--session.is-collapsed{visibility:hidden;pointer-events:none}.config-session-toggle{margin-top:10px;flex-shrink:0}.config-col{display:flex;flex-direction:column;min-height:0;overflow:hidden}.config-col--main,.config-col--session{background:linear-gradient(135deg,#ffffff 0%,var(--surface) 100%);padding:14px;border-radius:10px;border:1px solid var(--border-color);box-shadow:0 3px 5px #0000000d}.config-col__title{color:var(--primary-color);margin:0 0 10px;font-size:1.05em;font-weight:700;flex-shrink:0}.config-col--session .config-log{flex:1;min-height:120px;max-height:none}.config-actions--session{grid-template-columns:1fr 1fr;margin-top:0}.config-status--inline{margin:0 0 8px;padding-top:0;border-top:none;flex-shrink:0}.config-clear-log{align-self:flex-start;margin-top:8px;flex-shrink:0}.config-last-op{font-size:12px;text-align:right;max-width:58%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.config-version-upgrade{margin-top:8px;padding-top:10px;border-top:1px solid var(--border-color);flex-shrink:0}.config-version-upgrade h3{margin:0 0 8px;font-size:.95em;color:var(--primary-color);font-weight:700}.version-pair{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}.status-item--compact{margin-bottom:0;padding:6px 8px;flex-direction:column;align-items:flex-start;gap:2px}.status-item--compact label{font-size:11px}.status-item--compact span{font-size:13px;font-weight:600;word-break:break-all}.upgrade-progress-unified{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:4px 10px;align-items:center;margin-bottom:8px;padding:8px 10px;background:#6366f10f;border:1px solid rgba(99,102,241,.15);border-radius:8px}.upgrade-progress-unified__label{grid-column:1 / -1;font-size:13px;font-weight:600;color:var(--text-primary)}.upgrade-progress-unified__track{grid-column:1;height:8px;background:#94a3b859;border-radius:4px;overflow:hidden}.upgrade-progress-unified__fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));transition:width .25s ease}.upgrade-progress-unified__pct{font-size:12px;font-weight:700;color:var(--primary-color);min-width:36px;text-align:right}.upgrade-hint-line{margin:0 0 8px;font-size:13px;color:#0369a1;line-height:1.4}.config-section,.config-response-section{background:linear-gradient(135deg,#ffffff 0%,var(--surface) 100%);padding:14px;border-radius:10px;border:1px solid var(--border-color);box-shadow:0 3px 5px #0000000d;transition:all .3s ease;display:flex;flex-direction:column;min-height:0;overflow:hidden}.config-response-section .log-container{flex:1;min-height:150px}.config-section:hover,.config-response-section:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-2px)}.config-section h2,.config-response-section h2{color:var(--primary-color);margin-bottom:10px;font-size:1.05em;font-weight:700;display:flex;align-items:center;gap:6px;flex-shrink:0}.config-section h2:before,.config-response-section h2:before{content:"";width:4px;height:24px;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:2px}.config-params{margin:10px 0;flex-shrink:0}.param-group{display:flex;align-items:center;margin-bottom:8px;gap:8px;padding:8px 10px;background:#fff;border-radius:8px;border:1px solid var(--border-color);transition:all .3s ease}.param-group:hover{border-color:var(--primary-light);box-shadow:0 2px 8px #6366f11a}.param-group label{min-width:132px;font-weight:600;color:var(--text-primary);font-size:13px}.param-group input[type=number]{flex:1;padding:8px 10px;border:1px solid var(--border-color);border-radius:7px;font-size:13px;font-weight:600;transition:all .3s ease;background:#fff}.param-group input[type=number]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.install-mode-group .install-mode-options{display:flex;gap:20px;flex-wrap:wrap}.install-mode-group .radio-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500}.form-group-readonly{padding:8px 12px;background:var(--surface);border-radius:8px}.form-group-readonly .topic-preview{font-size:13px;color:var(--text-secondary);word-break:break-all}.form-group select{width:100%;padding:10px 14px;font-size:14px;border:2px solid var(--border-color);border-radius:8px;background:#fff;cursor:pointer}.param-unit{color:var(--text-secondary);font-size:12px;font-weight:500;min-width:28px;padding:5px 8px;background:var(--surface);border-radius:6px}.config-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:10px 0;flex-shrink:0}.config-status{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color);flex-shrink:0}.status-item{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;margin-bottom:6px;background:#fff;border-radius:8px;border:1px solid var(--border-color);transition:all .3s ease}.status-item:hover{border-color:var(--primary-light);box-shadow:0 1px 5px #0000000d}.status-item label{font-weight:600;color:var(--text-secondary);font-size:13px}.status-active{color:var(--success-color);font-weight:700;padding:4px 12px;background:#10b9811a;border-radius:8px}.status-inactive{color:var(--text-secondary);font-weight:500;padding:4px 12px;background:var(--surface);border-radius:8px}.config-log{flex:1;min-height:150px;max-height:320px;height:auto;overflow-y:auto;overscroll-behavior:contain}@media (max-width: 1024px){.main-layout{flex-direction:column}.left-sidebar{width:100%;max-height:400px}.main-layout--sidebar-collapsed .left-sidebar{width:0;max-height:0;flex:0 0 0}.right-content{margin-right:0;flex:1 1 0;min-height:0}.log-sidebar{width:360px}.log-toggle-btn.active{right:360px}.stats{grid-template-columns:repeat(2,1fr)}.config-actions{grid-template-columns:1fr}.layout-desktop .main-layout{flex-direction:row}.layout-desktop .left-sidebar{width:var(--sidebar-width);max-height:none}.layout-desktop .main-layout--sidebar-collapsed .left-sidebar{width:0;max-height:0;min-height:0;flex:0 0 0}.layout-desktop .right-content{flex:1 1 0;min-width:0;min-height:0}}body:has(.layout-desktop){background:#edf1f6;color:#1f2937}.layout-desktop{flex:1;width:100%;height:100%;min-height:0;display:flex;flex-direction:column;--primary-color: #2f6dbe;--primary-dark: #24579a;--primary-light: #6fa3e3;--secondary-color: #3f6f9f;--success-color: #2f8aac;--error-color: #8a7d78;--warning-color: #9a8a74;--bg-gradient-start: #2f6dbe;--bg-gradient-end: #6fa3e3;--card-bg: #f9fbff;--card-shadow: 0 1px 3px rgba(15, 23, 42, .08), 0 10px 24px rgba(15, 23, 42, .08);--border-color: rgba(51, 65, 85, .18);--text-primary: #1f2937;--text-secondary: #4b5563;--surface: #f4f7fb;--surface-hover: #ebf1f8;--panel-bg: #f9fbff;--input-bg: #ffffff;--focus-ring: rgba(47, 109, 190, .24);--morandi-green: #2f8aac;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.layout-desktop .main-layout{flex:1 1 0;flex-direction:row;min-height:0}.layout-desktop .left-sidebar{width:var(--sidebar-width);max-height:none;flex:0 0 var(--sidebar-width)}.layout-desktop .main-layout--sidebar-collapsed .left-sidebar{width:0;max-height:0;min-height:0;flex:0 0 0}.layout-desktop .right-content{flex:1 1 0;min-width:0;min-height:0}.layout-desktop .container{border:1px solid var(--border-color);-webkit-backdrop-filter:none;backdrop-filter:none;flex:1 1 0;width:100%;min-height:0;max-height:100%;margin-bottom:clamp(4px,1vh,14px);padding-bottom:clamp(4px,.8vh,10px);box-shadow:0 2px 10px #1e40af0d,0 14px 32px #0f172a14}.layout-desktop header{border-bottom-color:var(--border-color)}.layout-desktop header:after{width:40px;height:2px;background:var(--primary-color);border-radius:1px}.layout-desktop header h1{background:none;-webkit-text-fill-color:var(--primary-color);color:var(--primary-color);font-weight:600;letter-spacing:-.02em}.layout-desktop .left-sidebar::-webkit-scrollbar-thumb{background:#2c2a271a}.layout-desktop .left-sidebar::-webkit-scrollbar-thumb:hover{background:#2c2a272e}.layout-desktop .tabs{background:var(--surface);box-shadow:inset 0 1px #94a3b83d}.layout-desktop .tab-btn:hover{color:var(--text-primary);background:#2f6dbe24}.layout-desktop .tab-btn.active{color:#fff;background:linear-gradient(135deg,var(--primary-color),#3f7fce);box-shadow:0 2px 10px #2f6dbe57;transform:none}.layout-desktop .connection-section,.layout-desktop .status-section{background:#fbfdff;border-color:var(--border-color);box-shadow:0 1px 2px #0f172a0d}.layout-desktop .connection-section:hover,.layout-desktop .status-section:hover{box-shadow:0 6px 20px #2563eb1a;transform:translateY(-1px)}.layout-desktop .form-group input{background:var(--input-bg);border-color:var(--border-color);color:var(--text-primary)}.layout-desktop .form-group input:focus{border-color:#2f6dbe9e;box-shadow:0 0 0 3px var(--focus-ring)}.layout-desktop .btn-primary{background:var(--primary-color);color:#fff;box-shadow:0 2px 10px #2f6dbe4d}.layout-desktop .btn-primary:hover:not(:disabled){background:var(--primary-dark);color:#fff;box-shadow:0 4px 14px #2f6dbe61}.layout-desktop .btn-secondary,.layout-desktop .btn-small{background:#e6e9e8;color:#444c57;box-shadow:none}.layout-desktop .btn-secondary:hover:not(:disabled),.layout-desktop .btn-small:hover:not(:disabled){background:#d9dddc;color:#2a2d33;box-shadow:none}.layout-desktop .device-online-row,.layout-desktop .stat-item{background:var(--input-bg);border-color:var(--border-color)}.layout-desktop .stat-item:hover{border-color:#2c2a271c}.layout-desktop .extended-stats{background:#2c2a2709;border-color:#2c2a2712}.layout-desktop .extended-title,.layout-desktop .extended-label,.layout-desktop .extended-item{color:var(--text-primary)}.layout-desktop .person-count-display{background:#5a9a8e17;border-color:#5a9a8e38}.layout-desktop .person-count-label{color:var(--text-secondary)}.layout-desktop .person-count-value{color:var(--morandi-green);font-weight:700}.layout-desktop .checkbox-inline{color:var(--text-secondary)}.layout-desktop .checkbox-inline input[type=checkbox]{accent-color:var(--primary-color)}.layout-desktop .tab-panel-shell,.layout-desktop .visualization-section{background:#ffffff6b;border-color:#cbd5e1ad;box-shadow:none}.layout-desktop .visualization-header-actions .install-mode-group>label{color:var(--text-secondary)}.layout-desktop .install-mode-group .radio-label{color:var(--text-primary)}.layout-desktop .reset-view-btn{color:var(--text-primary);background:#2f6dbe1a;border-color:#2f6dbe4d}.layout-desktop .reset-view-btn:hover{background:#2f6dbe2e}.layout-desktop .track-canvas{background:#f4f8fe38;border:1px solid rgba(96,165,250,.08);min-height:0}@media (max-height: 760px){body:has(.layout-desktop){padding:4px}.layout-desktop .container{padding:8px;margin-bottom:0}.layout-desktop header{margin-bottom:4px;padding-bottom:4px}.layout-desktop header h1{font-size:1.15rem}.layout-desktop .tabs{margin-bottom:4px}.layout-desktop .tab-btn{padding:6px 12px;font-size:13px}.layout-desktop .activity-overview.visualization-section{padding:6px;gap:6px}.layout-desktop .activity-status-hero{padding:10px 12px}.layout-desktop .activity-status-hero__label{font-size:12px;margin-bottom:4px}.layout-desktop .activity-status-hero__value{font-size:1.5rem}.layout-desktop .activity-room-panel{padding:6px 8px 8px}.layout-desktop .activity-room-panel .room-layout-canvas{min-height:0}.layout-desktop .visualization-header{margin-bottom:4px}.layout-desktop .visualization-header h2{font-size:.95em}.layout-desktop .visualization-header-actions .install-mode-group>label,.layout-desktop .reset-view-btn{font-size:12px}}@media (max-height: 640px){.layout-desktop .activity-status-hero{padding:8px 10px}.layout-desktop .activity-status-hero__value{font-size:1.25rem}.layout-desktop .activity-overview__meta{display:none}}.layout-desktop .activity-overview__main--room-only .activity-room-panel{flex:1 1 0;min-height:0}.layout-desktop .log-sidebar{background:var(--card-bg);border-left-color:var(--border-color);box-shadow:-8px 0 28px #2c2a2712}.fall-alert-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#dc262638;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1400}.fall-alert-dialog{min-width:320px;max-width:480px;background:#fffffff2;border:2px solid #ef4444;border-radius:14px;box-shadow:0 16px 36px #ef444459;padding:18px 22px;color:#111827}.fall-alert-title{color:#b91c1c;font-size:28px;font-weight:800;margin-bottom:10px}.fall-alert-row{font-size:20px;margin-bottom:6px}.layout-desktop .log-toggle-btn{background:var(--primary-color);color:#fff;box-shadow:-2px 0 10px #2f6dbe4d}.layout-desktop .log-toggle-btn:hover{background:var(--primary-dark);color:#fff}.layout-desktop .sidebar-toggle-btn{background:var(--primary-color);box-shadow:2px 0 10px #2f6dbe4d}.layout-desktop .sidebar-toggle-btn:hover{background:var(--primary-dark)}.layout-desktop .log-header,.layout-desktop .log-header h2,.layout-desktop .log-header .log-header-title{border-bottom-color:var(--border-color);color:var(--text-primary)}.layout-desktop .log-header .log-header-title:hover{background:#2c2a270a}.layout-desktop .checkbox-label{color:var(--text-secondary)}.layout-desktop .checkbox-label input[type=checkbox]{accent-color:var(--primary-color)}.layout-desktop .config-col--main,.layout-desktop .config-col--session{background:#fbfdff;border-color:var(--border-color);box-shadow:0 1px 2px #0f172a0d}.layout-desktop .upgrade-progress-unified{background:#5b7a9b14;border-color:#5b7a9b38}.layout-desktop .upgrade-progress-unified__fill{background:linear-gradient(90deg,#5b7a9b,#7a9bb8)}.layout-desktop .upgrade-progress-unified__label,.layout-desktop .upgrade-progress-unified__pct{color:#334155}.layout-desktop .upgrade-hint-line{color:#475569}.layout-desktop .param-group{background:var(--input-bg);border-color:var(--border-color)}.layout-desktop .param-group:hover{border-color:#2c2a271a;box-shadow:none}.layout-desktop .param-group input[type=number]{background:#fff;border-color:var(--border-color);color:var(--text-primary)}.layout-desktop .param-group input[type=number]:focus{border-color:#2f6dbe9e;box-shadow:0 0 0 3px var(--focus-ring)}.layout-desktop .form-group select{background:var(--input-bg);border-color:var(--border-color);color:var(--text-primary)}.layout-desktop .form-group-readonly,.layout-desktop .status-item{background:var(--input-bg)}.layout-desktop .status-active{background:#5a9a8e1a;color:var(--text-primary)}.layout-desktop .status-inactive,.layout-desktop .param-unit{background:var(--surface);color:var(--text-secondary)}.layout-desktop .device-status-online{color:var(--text-primary)}.layout-desktop .device-status-offline{color:#9a9288}.layout-desktop .status-connected{background:linear-gradient(135deg,#e8eeec,#dce8e4);color:var(--text-primary)}.layout-desktop .status-disconnected{background:linear-gradient(135deg,#f6f4f0,#ebe8e2);color:var(--text-secondary)}.layout-desktop .log-container{background:linear-gradient(180deg,#fcfcfa,#f2f4f3);color:#444c57;border-color:#21262d14}.layout-desktop .log-info{color:#6b665e}.layout-desktop .log-success{color:#2c2a27}.layout-desktop .log-warning{color:#7a7268}.layout-desktop .log-error{color:#6b665e}.room-layout-canvas{width:100%;height:100%;min-height:0;border-radius:8px;overflow:hidden}.room-layout-canvas--interactive{touch-action:none;cursor:default;-webkit-user-select:none;user-select:none}.activity-overview.visualization-section{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;padding:clamp(8px,1.2vw,14px);gap:clamp(8px,1.2vh,14px)}.activity-overview__meta{flex-shrink:0}.activity-overview__chips{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(6px,.8vw,10px)}.activity-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;font-size:clamp(11px,1vw,13px);font-weight:600;border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-secondary)}.activity-chip--ok{color:var(--morandi-green);border-color:#2f8aac47;background:#2f8aac14}.activity-chip--warn{color:var(--error-color);border-color:#8a7d7859;background:#8a7d7814}.activity-chip--muted{color:var(--text-secondary)}.activity-timeout-row{display:inline-flex;align-items:center;gap:6px;font-size:clamp(11px,1vw,13px);color:var(--text-secondary);margin-left:auto}.activity-timeout-row input{width:52px;padding:4px 6px;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-primary);font-size:13px}.activity-timeout-row input:focus{outline:none;border-color:#2f6dbe9e;box-shadow:0 0 0 3px var(--focus-ring)}.activity-status-hero{flex-shrink:0;padding:clamp(18px,3vh,32px) clamp(16px,3vw,40px);border-radius:12px;border:1px solid rgba(33,38,45,.1);background:linear-gradient(135deg,#f6f4f0,#fcfcfa);text-align:center}.activity-status-hero--active{border-color:#2f8aac59;background:linear-gradient(135deg,#2f8aac1f,#fcfcfa)}.activity-status-hero--inactive{border-color:#21262d1f}.activity-status-hero--absent{border-color:#8a7d7852;background:linear-gradient(135deg,#8a7d7814,#fcfcfa)}.activity-status-hero--paused{opacity:.9}.activity-status-hero__label{font-size:clamp(14px,1.6vw,18px);color:#6b665e;margin-bottom:clamp(6px,1vh,10px)}.activity-status-hero__value{font-size:clamp(2.25rem,6vw,3.75rem);font-weight:700;line-height:1.1;color:#2c2a27;letter-spacing:.02em}.activity-status-hero--active .activity-status-hero__value{color:#2f6d8a}.activity-status-hero--inactive .activity-status-hero__value{color:#6b665e}.activity-status-hero--absent .activity-status-hero__value{color:#7a7268}.activity-fall-overlay{z-index:1500}.activity-overview__main{flex:1;min-height:0;display:grid;grid-template-columns:minmax(240px,.75fr) minmax(0,1.25fr);gap:clamp(8px,1vw,12px);position:relative}.activity-overview__main--room-only{grid-template-columns:1fr}.activity-overview__main--room-only .activity-room-panel{min-height:0;height:100%}.activity-overview__main--history-collapsed{grid-template-columns:1fr}.activity-history-panel{display:flex;flex-direction:column;min-height:0;padding:10px 12px 12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.activity-history-panel__head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0;margin-bottom:6px}.activity-history-panel__head .activity-subsection__title{margin-bottom:0}.activity-history-toggle{flex-shrink:0;padding:4px 10px;font-size:12px;font-weight:600;color:var(--text-secondary);background:var(--surface);border:1px solid var(--border-color);border-radius:6px;cursor:pointer}.activity-history-toggle:hover{color:var(--primary-color);border-color:#2f6dbe59;background:#2f6dbe0f}.activity-history-expand{position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:5;writing-mode:vertical-rl;padding:12px 8px;font-size:13px;font-weight:600;letter-spacing:2px;color:var(--primary-color);background:var(--card-bg);border:1px solid var(--border-color);border-left:none;border-radius:0 8px 8px 0;cursor:pointer;box-shadow:2px 0 8px #0f172a0f}.activity-history-expand:hover{background:#2f6dbe14}.activity-room-panel{display:flex;flex-direction:column;min-height:0;min-width:0;padding:10px 12px 12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.activity-overview__main--history-collapsed .activity-room-panel{padding-left:clamp(36px,3vw,44px)}.activity-subsection__title{margin:0 0 8px;color:var(--primary-color);font-size:clamp(.95em,1.4vw,1.05em);font-weight:700;display:flex;align-items:center;gap:6px;flex-shrink:0}.activity-subsection__title:before{content:"";width:4px;height:20px;background:var(--primary-color);border-radius:2px}.activity-room-panel .room-layout-canvas{flex:1;min-height:0;border:1px solid var(--border-color);border-radius:8px;background:#fff}.activity-history-panel .alert-history-root--scroll{flex:1;min-height:0}@media (max-width: 900px){.activity-overview__main{grid-template-columns:1fr}.activity-history-panel{max-height:240px}.activity-room-panel .room-layout-canvas{min-height:220px}.activity-timeout-row{margin-left:0;width:100%}}.layout-desktop .activity-overview.visualization-section{background:#ffffff6b;border-color:#cbd5e1ad;box-shadow:none}.layout-desktop .activity-history-panel,.layout-desktop .activity-room-panel{background:var(--input-bg);border-color:var(--border-color)}.layout-desktop .activity-status-hero--active{border-color:#2f8aac59;background:linear-gradient(135deg,#2f8aac1f,#fcfcfa)}.layout-desktop .activity-timeout-row input{background:var(--input-bg);border-color:var(--border-color)}.room-layout-panel{container-type:size;container-name:room-layout;--room-gap: clamp(4px, .55vh, 10px);--room-readout-fs: clamp(10px, .72rem + .25vw, 12px);--room-chip-fs: clamp(10px, .7rem + .2vw, 12px);--room-canvas-min-h: clamp(6.5rem, 20dvh, 16rem);--room-bottom-max-h: min(46dvh, 18rem);display:flex;flex-direction:column;gap:var(--room-gap);height:100%;min-height:0;padding:0}.room-layout-panel__canvas-wrap{flex:1 1 0;min-height:var(--room-canvas-min-h);border:1px solid rgba(33,38,45,.1);border-radius:clamp(6px,.8vw,10px);overflow:hidden;background:#fff;display:flex;flex-direction:column}.room-layout-panel__canvas-wrap .room-layout-canvas{flex:1;min-height:0}.room-layout-panel__bottom{flex:0 1 auto;display:flex;flex-direction:column;gap:var(--room-gap);min-height:0;max-height:var(--room-bottom-max-h)}.room-layout-panel__scroll{flex:1 1 auto;min-height:0;overflow-x:hidden;overflow-y:auto;display:flex;flex-direction:column;gap:var(--room-gap);-webkit-overflow-scrolling:touch}.room-layout-panel__footer{flex-shrink:0;padding-top:clamp(4px,.5vh,8px);border-top:1px solid rgba(33,38,45,.1);background:#f9fbfff5}.room-layout-panel__save-btn{width:100%;min-height:clamp(2rem,5vh,2.5rem);font-size:clamp(13px,.85rem + .15vw,15px)}.room-layout-panel__save-note{margin:clamp(2px,.35vh,4px) 0 0;font-size:clamp(9px,.62rem + .15vw,11px);line-height:1.35;color:#7a7268;text-align:center}.room-layout-panel__note--path{margin:clamp(2px,.35vh,4px) 0 0;font-size:clamp(9px,.58rem + .12vw,10px);line-height:1.35;color:#9a9288;word-break:break-all}.room-layout-panel__hint,.room-layout-panel__note{font-size:12px;color:#7a7268;line-height:1.45;margin:0 0 8px}.room-name-row{margin:0 0 clamp(4px,.5vh,8px)}.room-name-row input{font-size:clamp(12px,.82rem + .1vw,14px)}.room-form-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.room-form-row{display:grid;grid-template-columns:100px 1fr auto;align-items:center;gap:8px;font-size:14px}.room-form-row input{width:100%;padding:6px 8px}.room-install-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px;font-size:14px}.room-form-actions{margin-top:12px}.room-layout-readout{margin:0;padding:clamp(4px,.6vh,6px) clamp(6px,.9vw,10px);border-radius:clamp(6px,.8vw,8px);background:#2f6d8a0f;border:1px solid rgba(47,109,138,.12);font-size:var(--room-readout-fs);line-height:1.4;color:#3d3832;word-break:break-word}.room-layout-readout--compact{display:flex;flex-wrap:wrap;align-items:center;gap:.15em .45em;line-height:1.35}.room-layout-readout__part+.room-layout-readout__part:before{content:"·";margin-right:.45em;color:#9a9288}.room-layout-readout__part:first-child:before{content:none;margin:0}.room-layout-readout--muted{margin-top:-4px;padding-top:0;background:transparent;border:none;font-size:12px;color:#7a7268}.room-zones-section{margin-top:0;padding-top:0;border-top:none}.room-zones-section--compact{display:flex;flex-direction:column;gap:6px}.room-zones-head{display:flex;flex-wrap:wrap;align-items:center;gap:8px;min-height:28px}.room-zones-section h3{margin:0;font-size:clamp(12px,.78rem + .2vw,14px);flex-shrink:0}.room-zones-empty{font-size:12px;color:#9a9288;padding:0}.room-zones-chip-row{display:flex;flex-wrap:nowrap;align-items:center;gap:6px;margin:0;overflow-x:auto;flex:1 1 auto;min-width:0;padding-bottom:1px}.room-zone-chip{flex:0 0 auto;display:inline-flex;align-items:center;padding:clamp(3px,.45vh,5px) clamp(7px,.9vw,10px);border:1px solid rgba(33,38,45,.12);border-radius:999px;cursor:pointer;font-size:var(--room-chip-fs);line-height:1.2;background:#faf8f5;color:#3d3832;white-space:nowrap}.room-zone-chip:hover{border-color:#2f6d8a59}.room-zone-chip--selected{border-color:#2f6d8a;background:#2f6d8a1f;color:#2f6d8a}.room-zone-chip--disabled{opacity:.55}.room-zones-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:0}.room-zones-toolbar .btn-small{flex:0 1 auto;min-width:0}.room-zone-editor{display:flex;flex-direction:column;gap:8px;padding:6px 8px;border-radius:8px;background:#2f6d8a0d}.room-zone-editor--inline{flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px 12px}.room-zone-editor__field{display:inline-flex;align-items:center;gap:6px;font-size:13px}.room-zone-editor__field select{min-width:108px;padding:4px 6px;font-size:13px}.room-zone-editor .room-form-row{grid-template-columns:72px 1fr}.room-zone-enable{font-size:clamp(12px,.78rem + .15vw,14px);margin:0}@container room-layout (max-width: 520px){.room-layout-readout--compact{flex-direction:column;align-items:flex-start;gap:.2em}.room-layout-readout__part+.room-layout-readout__part:before{content:none;margin:0}.room-zones-head{flex-direction:column;align-items:flex-start}}@container room-layout (max-height: 520px){.room-layout-panel{--room-canvas-min-h: clamp(5rem, 16dvh, 10rem);--room-bottom-max-h: min(52dvh, 14rem)}.room-layout-panel__save-note,.room-layout-panel__note--path{display:none}}@container room-layout (max-height: 420px){.room-layout-panel{--room-canvas-min-h: clamp(4rem, 14dvh, 8rem)}.room-zone-editor--inline{padding:4px 6px;gap:6px 8px}}@media (max-height: 760px){.tab-panel-shell--room{padding:4px 6px}.room-layout-panel{--room-canvas-min-h: clamp(5.5rem, 18dvh, 12rem);--room-bottom-max-h: min(50dvh, 16rem)}}@media (max-height: 640px){.room-layout-panel__save-note,.room-layout-panel__note--path{display:none}}@media (max-width: 1024px){.room-layout-panel{--room-canvas-min-h: clamp(5rem, 18dvh, 13rem)}}body:has(.layout-mobile){background:#f4f3ef;color:#2a2d33}.layout-mobile{--mobile-bg: #f4f3ef;--mobile-surface: #fcfcfa;--mobile-surface-elevated: #f1f2f0;--mobile-accent: #2f6dbe;--mobile-accent-hover: #24579a;--mobile-accent-soft: #2f8aac;--mobile-success: #2f8aac;--mobile-error: #8a7d78;--mobile-warning: #9a8a74;--mobile-text: #2a2d33;--mobile-text-muted: #666d76;--mobile-border: rgba(33, 38, 45, .12);--mobile-focus-ring: rgba(47, 109, 190, .24);--mobile-accent-press: #1f4a80;--mobile-secondary-press: #d8dddc;--mobile-nav-press-bg: rgba(47, 109, 190, .2);--mobile-nav-press-bg-muted: rgba(33, 38, 45, .08);--mobile-nav-height: 56px;--mobile-safe-bottom: env(safe-area-inset-bottom, 0);position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:var(--mobile-bg);color:var(--mobile-text);overflow:hidden;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-tap-highlight-color:transparent}.layout-mobile button:focus{outline:none}.layout-mobile button:focus-visible{outline:2px solid var(--mobile-accent);outline-offset:2px}.mobile-header{flex-shrink:0;display:flex;flex-direction:row;align-items:center;gap:8px;padding:8px 12px;padding-top:max(8px,env(safe-area-inset-top));background:var(--mobile-surface);border-bottom:1px solid var(--mobile-border);font-family:inherit}.mobile-header-title{margin:0;font-size:1rem;font-weight:600;letter-spacing:-.02em;color:var(--mobile-accent);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:none;-webkit-background-clip:unset;background-clip:unset;-webkit-text-fill-color:var(--mobile-accent)}.mobile-header-tools{display:flex;flex-shrink:0;align-items:center;gap:6px;max-width:min(68vw,280px)}.mobile-reset-btn{flex-shrink:0;padding:5px 10px;font-size:11px;font-weight:500;color:var(--mobile-text);background:#fffefb;border:1px solid var(--mobile-border);border-radius:8px;cursor:pointer;transition:transform .1s ease,background .1s ease,border-color .1s ease}.mobile-reset-btn:active{transform:scale(.96);background:#ebe7df;border-color:#2c2a2724}.mobile-install-select{flex-shrink:1;min-width:0;max-width:6.75rem;padding:5px 8px;font-size:12px;font-weight:500;color:var(--mobile-text);background:#fffefb;border:1px solid var(--mobile-border);border-radius:8px;cursor:pointer;transition:transform .1s ease,background .1s ease,border-color .1s ease}.mobile-install-select:active{transform:scale(.98);background:#ebe7df;border-color:#2c2a2724}.mobile-install-select:focus{outline:none;border-color:#6f8a9e8c;box-shadow:0 0 0 3px var(--mobile-focus-ring)}.mobile-main{flex:1;min-height:0;overflow:hidden}.mobile-pane{height:100%;overflow:auto;-webkit-overflow-scrolling:touch}.mobile-pane--track{overflow:hidden}.mobile-track{position:relative;width:100%;height:100%;min-height:200px;box-sizing:border-box;padding-bottom:calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + 6px)}.mobile-track-canvas{display:block;width:100%;height:100%;object-fit:contain;background:#faf9f5}.mobile-track-overlay{position:absolute;bottom:calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + 10px);left:10px;right:10px;top:auto;z-index:5;display:flex;justify-content:center;pointer-events:none}.mobile-track-info{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px 10px;width:100%;max-width:100%;min-height:40px;padding:8px 12px;background:#fffefbf7;border-radius:10px;border:1px solid var(--mobile-border);pointer-events:auto;box-shadow:0 4px 18px #2c2a270f;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.mobile-track-info::-webkit-scrollbar{display:none}.mobile-track-count{flex:0 0 auto;display:flex;align-items:center;gap:6px;min-width:0}.mobile-track-count .label{font-size:11px;font-weight:500;line-height:1.2;color:var(--mobile-text-muted)}.mobile-track-count .value{font-size:clamp(14px,3.8vw,16px);font-weight:700;line-height:1;color:var(--mobile-accent-soft)}.mobile-track-status{flex:1 1 auto;justify-content:center;display:flex;align-items:center;flex-shrink:0;gap:8px}.mobile-track-badge{padding:2px 0;font-size:11px;font-weight:600;line-height:1.25;white-space:nowrap}.mobile-track-badge.connected{color:var(--mobile-success)}.mobile-track-badge.disconnected{color:var(--mobile-error)}.mobile-track-badge.online{color:var(--mobile-success)}.mobile-track-badge.offline{color:var(--mobile-text-muted)}.mobile-track-toggle{flex:0 0 auto;padding:6px 12px;min-height:32px;font-size:11px;font-weight:500;line-height:1.2;border-radius:8px;border:1px solid var(--mobile-border);background:#f0ede6;color:var(--mobile-text-muted);cursor:pointer;transition:transform .1s ease,background .1s ease,border-color .1s ease,color .1s ease;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.mobile-track-toggle.on{background:#6f8a9e1f;border-color:#6f8a9e47;color:var(--mobile-text)}.mobile-track-toggle:active{transform:scale(.96)}.mobile-track-toggle:active:not(.on){background:#e5e0d6;border-color:#2c2a2724}.mobile-track-toggle.on:active{background:#6f8a9e38;border-color:#6f8a9e61}.mobile-connect{padding:20px 16px;padding-bottom:calc(20px + var(--mobile-nav-height) + var(--mobile-safe-bottom))}.mobile-connect-card{background:var(--mobile-surface-elevated);border-radius:16px;padding:20px;border:1px solid rgba(44,42,39,.09)}.mobile-connect-card h2{margin:0 0 20px;font-size:1.1rem;color:var(--mobile-text)}.mobile-form{margin-bottom:16px}.mobile-form label{display:block;margin-bottom:6px;font-size:13px;color:var(--mobile-text-muted)}.mobile-form input{width:100%;padding:12px 14px;font-size:16px;border:1px solid var(--mobile-border);border-radius:10px;background:#fffefb;color:var(--mobile-text)}.mobile-form input::placeholder{color:var(--mobile-text-muted);opacity:.6}.mobile-select{width:100%;padding:12px 14px;font-size:16px;border:1px solid var(--mobile-border);border-radius:10px;background:#fffefb;color:var(--mobile-text);cursor:pointer}.mobile-config-hint{margin:8px 0 0;font-size:12px;color:var(--mobile-text-muted);word-break:break-all}.mobile-form.form-group-readonly{padding:12px 14px;background:#f0ede6;border-radius:10px}.mobile-form .topic-preview{font-size:14px;color:var(--mobile-text-muted);word-break:break-all}.mobile-form input:focus{outline:none;border-color:#6f8a9e8c;box-shadow:0 0 0 3px var(--mobile-focus-ring)}.mobile-actions{display:flex;gap:12px;margin-top:24px}.mobile-connect-status{margin-top:16px;padding-top:14px;border-top:1px solid rgba(44,42,39,.08)}.mobile-connect-status__row{display:flex;justify-content:space-between;gap:12px;font-size:13px;color:var(--mobile-text-muted)}.mobile-connect-status__row span:last-child{font-weight:600;color:var(--mobile-text)}.mobile-btn{flex:1;padding:14px 20px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .12s ease,opacity .2s,background .12s ease,box-shadow .12s ease}.mobile-btn:disabled{opacity:.5;cursor:not-allowed}.mobile-btn.primary{background:var(--mobile-accent);color:#fffefb;box-shadow:0 2px 10px #6f8a9e38}.mobile-btn.primary:hover:not(:disabled){background:var(--mobile-accent-hover);box-shadow:0 3px 12px #6f8a9e47}.mobile-btn:active:not(:disabled){transform:scale(.97)}.mobile-btn.primary:active:not(:disabled){background:var(--mobile-accent-press);box-shadow:0 1px 6px #2c2a271f}.mobile-btn.secondary:active:not(:disabled){background:var(--mobile-secondary-press);box-shadow:inset 0 1px 2px #2c2a270f}.mobile-btn.secondary{background:#e8e4dc;color:#6b665e}.mobile-btn.small{width:100%;margin-top:12px;padding:10px;font-size:13px}.mobile-config{height:100%;overflow-y:auto;padding-bottom:calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + 20px)}.mobile-config-scroll{padding:16px}.mobile-config-section{margin-bottom:24px}.mobile-config-section h3{margin:0 0 12px;font-size:.95rem;color:var(--mobile-text-muted)}.mobile-config-section input[type=text]{width:100%;padding:12px 14px;font-size:16px;border:1px solid var(--mobile-border);border-radius:10px;background:#fffefb;color:var(--mobile-text)}.mobile-param-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}.mobile-param-row span{flex:0 0 80px;font-size:13px;color:var(--mobile-text-muted)}.mobile-param-row input{flex:1;padding:10px 12px;font-size:16px;border:1px solid var(--mobile-border);border-radius:8px;background:#fffefb;color:var(--mobile-text)}.mobile-check{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer}.mobile-check input{width:20px;height:20px;accent-color:var(--mobile-accent)}.mobile-config-actions{margin-top:20px}.mobile-btn-row{display:flex;gap:10px;margin-bottom:10px}.mobile-btn-row .mobile-btn{flex:1}.mobile-status-row{margin-top:16px;padding:12px;background:var(--mobile-surface-elevated);border:1px solid rgba(44,42,39,.08);border-radius:10px;font-size:13px}.mobile-status-row .status-on{color:var(--mobile-accent-soft)}.mobile-status-row .status-off{color:var(--mobile-text-muted)}.mobile-config-log{min-height:120px;max-height:320px;padding:12px;background:linear-gradient(180deg,#fffefb,#f3f1ec);border:1px solid rgba(44,42,39,.09);border-radius:10px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;color:#6b665e;overflow-y:auto;overscroll-behavior:contain;margin-bottom:10px}.mobile-log-entry{margin-bottom:4px;padding-bottom:4px;border-bottom:1px solid rgba(44,42,39,.07)}.mobile-log-entry.log-success{color:var(--mobile-success)}.mobile-log-entry.log-error{color:var(--mobile-error)}.mobile-log-entry.log-warning{color:var(--mobile-warning)}.mobile-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--mobile-nav-height) + var(--mobile-safe-bottom));padding-bottom:var(--mobile-safe-bottom);display:flex;background:var(--mobile-surface);border-top:1px solid var(--mobile-border);z-index:100}.mobile-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px;border:none;border-radius:10px;background:transparent;color:var(--mobile-text-muted);font-size:11px;cursor:pointer;transition:background .12s ease,color .12s ease}.mobile-nav-btn .nav-icon{font-size:20px;display:inline-flex;align-items:center;justify-content:center;transition:transform .12s ease}.mobile-nav-btn .nav-icon-svg{width:1.1em;height:1.1em}.mobile-nav-btn.active{color:var(--mobile-accent)}.mobile-nav-btn.active .nav-icon{transform:scale(1.1)}.mobile-nav-btn:active{background:var(--mobile-nav-press-bg-muted)}.mobile-nav-btn.active:active{background:var(--mobile-nav-press-bg)}.mobile-nav-btn:active .nav-icon{transform:scale(.92)}.mobile-nav-btn.active:active .nav-icon{transform:scale(1.02)}.mobile-alert-history-panel{position:absolute;left:10px;right:10px;bottom:calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + 64px);z-index:8;max-height:42vh;display:flex;flex-direction:column;background:#fffefbfa;border:1px solid var(--mobile-border);border-radius:12px;box-shadow:0 8px 28px #2c2a271f;overflow:hidden;pointer-events:auto}.mobile-alert-history-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:13px;font-weight:600;border-bottom:1px solid var(--mobile-border);flex-shrink:0}.mobile-alert-history-close{border:none;background:transparent;font-size:20px;line-height:1;padding:0 4px;cursor:pointer;color:var(--mobile-text-muted)}.alert-history-root--compact .alert-history-list{flex:1;min-height:0;overflow-y:auto;padding:8px 12px 12px}.mobile-alert-history-panel .alert-history-root{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.alert-history-root--compact .alert-history-item{padding:8px 10px;margin-bottom:6px;font-size:12px;border-radius:8px;background:var(--mobile-surface-elevated);border:1px solid var(--mobile-border)}.mobile-status-row.upgrade-status-hint{flex-direction:column;align-items:flex-start;gap:4px;color:var(--mobile-accent);font-size:12px;font-weight:500}.mobile-upgrade-progress{margin:8px 0;padding:10px 12px;border-radius:10px;background:#2f6dbe14;border:1px solid rgba(47,109,190,.2)}.mobile-upgrade-progress__label{display:block;font-size:13px;font-weight:600;color:var(--mobile-text);margin-bottom:6px}.mobile-upgrade-progress__row{display:flex;align-items:center;gap:10px}.mobile-upgrade-progress__track{flex:1;height:8px;border-radius:4px;background:#94a3b859;overflow:hidden}.mobile-upgrade-progress__fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--mobile-accent),#6b9fd4);transition:width .25s ease}.mobile-upgrade-progress__pct{font-size:12px;font-weight:700;color:var(--mobile-accent);min-width:36px;text-align:right}.mobile-upgrade-hint{margin:6px 0 8px;font-size:12px;line-height:1.4;color:var(--mobile-accent)}.mobile-checkbox-row{display:flex;align-items:flex-start;gap:8px;margin:10px 0 4px;font-size:13px;color:var(--mobile-text)}.mobile-checkbox-row input{margin-top:2px;flex-shrink:0}.mobile-log-btn--active{border-color:#2f6dbe73;color:var(--mobile-accent);background:#2f6dbe14}.layout-mobile .log-sidebar{width:min(360px,92vw);z-index:1100;padding:16px;padding-top:max(16px,env(safe-area-inset-top));padding-bottom:calc(16px + var(--mobile-nav-height) + var(--mobile-safe-bottom))}.layout-mobile .log-toggle-btn--mobile{top:auto;bottom:calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + 12px);transform:none;width:44px;height:48px;z-index:1001}.layout-mobile .log-toggle-btn--mobile.active{right:min(360px,92vw)}.mobile-pane--activity{height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.mobile-pane--room{height:100%;overflow:hidden;display:flex;flex-direction:column;min-height:0}.mobile-room{flex:1;min-height:0;display:flex;flex-direction:column;padding:8px 10px calc(var(--mobile-nav-height) + var(--mobile-safe-bottom) + 8px);box-sizing:border-box}.mobile-activity{min-height:100%;padding:0;box-sizing:border-box}.mobile-activity .activity-overview.visualization-section{min-height:100%;padding:8px;border:none;background:transparent;box-shadow:none}.mobile-activity .activity-overview__meta{margin-bottom:4px}.mobile-activity .activity-overview__chips{width:100%}.mobile-activity .activity-status-hero__value{font-size:clamp(1.75rem,8vw,2.5rem)}.mobile-activity .activity-overview__main{grid-template-columns:1fr}.mobile-activity .activity-history-panel{max-height:220px}.mobile-activity .activity-room-panel .room-layout-canvas{min-height:220px}.mobile-room .room-layout-panel{height:100%;min-height:0;padding:0;gap:clamp(4px,.6vh,8px);--room-canvas-min-h: clamp(4.5rem, 18dvh, 10rem);--room-bottom-max-h: min(40dvh, 14rem)}.mobile-room .room-layout-panel__bottom{flex:0 1 auto;min-height:0;max-height:var(--room-bottom-max-h)}.mobile-room .room-layout-panel__footer{flex-shrink:0;background:#f9fbfffa;padding-bottom:4px}.mobile-room .room-layout-panel__canvas-wrap{flex:1 1 0;min-height:var(--room-canvas-min-h);height:auto}.mobile-room .room-layout-panel__canvas-wrap .room-layout-canvas{min-height:0}.mobile-room .room-form-row{grid-template-columns:88px 1fr auto;font-size:13px}.mobile-room .room-zones-chip-row{margin-bottom:8px}.mobile-room .room-zones-toolbar .btn-small{flex:1 1 0;min-width:0}.mobile-room .room-zone-editor--inline{flex-direction:column;align-items:stretch}.layout-mobile .mobile-nav-btn .nav-label{font-size:10px;line-height:1.1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
