:root{--bg: #09090b;--bg-elev: #18181b;--bg-hover: #27272a;--bg-active: #1e293b;--fg: #fafafa;--fg-secondary: #a1a1aa;--fg-muted: #71717a;--border: #27272a;--border-subtle: #1f1f23;--accent: #3b82f6;--accent-hover: #60a5fa;--accent-dim: rgba(59,130,246,.1);--ok: #22c55e;--ok-dim: rgba(34,197,94,.1);--warn: #eab308;--warn-dim: rgba(234,179,8,.1);--err: #ef4444;--err-dim: rgba(239,68,68,.1);--info: #06b6d4;--info-dim: rgba(6,182,212,.1);--logic: #a855f7;--logic-dim: rgba(168,85,247,.1);--radius: 8px;--radius-sm: 4px;--radius-lg: 12px;--radius-full: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", system-ui, sans-serif;--font-mono: "SF Mono", "Cascadia Code", "Fira Code", Consolas, monospace;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.3);--shadow-lg: 0 8px 24px rgba(0,0,0,.4);--bg-card: rgba(255,255,255,.05);--bg-card-hover: rgba(255,255,255,.08);--bg-input: rgba(255,255,255,.06);--border-hover: rgba(255,255,255,.18);--text-primary: #fafafa;--text-secondary: rgba(255,255,255,.55);--text-hint: rgba(255,255,255,.3);--text-success: #22c55e;--text-warning: #eab308;--text-error: #ef4444;--btn-primary-bg: #3b82f6;--btn-primary-color: #ffffff;--btn-primary-hover: #60a5fa;--btn-secondary-bg: rgba(59,130,246,.1);--btn-secondary-color: #60a5fa;--btn-danger-bg: rgba(239,68,68,.1);--btn-danger-color: #ef4444;--focus-ring: rgba(59,130,246,.4);--brand-primary: #3b82f6;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", system-ui, sans-serif;--transition-fast: .12s ease;--transition-normal: .18s ease;--touch-target: 48px;--bottom-nav-height: 64px;--connection-bar-height: 48px;--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-top: env(safe-area-inset-top, 0px)}:root[data-theme=light]{--bg: #ffffff;--bg-elev: #f4f4f5;--bg-hover: #e4e4e7;--bg-active: #dbeafe;--fg: #09090b;--fg-secondary: #52525b;--fg-muted: #71717a;--border: #d4d4d8;--border-subtle: #e4e4e7;--accent: #2563eb;--accent-hover: #3b82f6;--accent-dim: rgba(37,99,235,.1);--ok: #16a34a;--ok-dim: rgba(22,163,74,.1);--warn: #ca8a04;--warn-dim: rgba(202,138,4,.1);--err: #dc2626;--err-dim: rgba(220,38,38,.1);--info: #0891b2;--info-dim: rgba(8,145,178,.1);--logic: #9333ea;--logic-dim: rgba(147,51,234,.1);--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 24px rgba(0,0,0,.15);--bg-card: rgba(0,0,0,.03);--bg-card-hover: rgba(0,0,0,.06);--bg-input: rgba(0,0,0,.04);--border-hover: rgba(0,0,0,.18);--text-primary: #09090b;--text-secondary: rgba(0,0,0,.55);--text-hint: rgba(0,0,0,.3);--text-success: #16a34a;--text-warning: #ca8a04;--text-error: #dc2626;--btn-primary-bg: #2563eb;--btn-primary-color: #ffffff;--btn-primary-hover: #3b82f6;--btn-secondary-bg: rgba(37,99,235,.1);--btn-secondary-color: #2563eb;--btn-danger-bg: rgba(220,38,38,.1);--btn-danger-color: #dc2626;--focus-ring: rgba(37,99,235,.3);--brand-primary: #2563eb}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-family);font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{background:var(--bg);color:var(--text-primary);min-height:100dvh;overflow-x:hidden;padding-top:var(--safe-area-top);padding-bottom:var(--safe-area-bottom)}body.embedded .connection-bar,body.embedded .bottom-nav{display:none}.standalone-banner{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--warn-dim);color:var(--warn);font-size:12px;border-bottom:1px solid var(--border)}.banner-x{background:none;border:none;color:var(--warn);cursor:pointer;padding:var(--space-1);margin-left:auto}#app{display:flex;flex-direction:column;min-height:100dvh}.page-content{flex:1;padding:16px;padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + 16px);overflow-y:auto}.connection-bar{display:flex;align-items:center;gap:8px;height:var(--connection-bar-height);padding:0 16px;background:var(--bg-card);border-bottom:1px solid var(--border)}.conn-indicator{width:8px;height:8px;border-radius:50%;background:var(--text-hint)}.conn-connected{background:var(--text-success)}.conn-connecting{background:var(--text-warning)}.conn-offline{background:var(--text-error)}.conn-label{font-size:14px;color:var(--text-secondary)}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-nav-height) + var(--safe-area-bottom));padding-bottom:var(--safe-area-bottom);background:var(--bg);border-top:1px solid var(--border);z-index:100}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:var(--touch-target);background:none;border:none;color:var(--text-hint);cursor:pointer;-webkit-tap-highlight-color:transparent}.nav-item.nav-active{color:var(--brand-primary)}.nav-icon{width:24px;height:24px}.nav-label{font-size:11px;font-weight:500}.deck-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.app-tile{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;cursor:pointer;min-height:120px;transition:background var(--transition-fast)}.app-tile:active{background:var(--bg-card-hover)}.tile-icon{font-size:32px;line-height:1;display:flex;align-items:center;justify-content:center}.tile-svg-icon{width:32px;height:32px}.tile-letter{font-size:24px;font-weight:700;color:var(--text-secondary)}.tile-info{display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}.tile-name{font-size:14px;font-weight:600}.tile-desc{font-size:11px;color:var(--text-secondary);line-height:1.3}.tile-status{width:8px;height:8px;border-radius:50%}.status-online{background:var(--text-success)}.status-offline{background:var(--text-hint)}.app-list{display:flex;flex-direction:column;gap:8px}.app-row{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;min-height:var(--touch-target)}.app-row:active{background:var(--bg-card-hover)}.app-row-icon{width:10px;height:10px;border-radius:50%}.app-row-info{flex:1;display:flex;flex-direction:column;gap:2px}.app-row-name{font-size:14px;font-weight:600}.app-row-desc{font-size:12px;color:var(--text-secondary)}.app-row-status{font-size:12px;color:var(--text-hint)}.hub-list{display:flex;flex-direction:column;gap:8px}.hub-card{padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.hub-card.hub-active{border-color:var(--brand-primary)}.hub-card-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.hub-card-name{font-weight:600;font-size:15px}.hub-badge{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--btn-primary-bg);color:var(--btn-primary-color)}.hub-card-url{font-size:13px;color:var(--text-secondary);display:block}.hub-card-type{font-size:12px;color:var(--text-hint);display:block;margin-bottom:8px}.hub-card-actions{display:flex;gap:8px}.connect-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80dvh;padding:24px;text-align:center}.connect-title{font-size:24px;font-weight:700;margin-bottom:8px}.connect-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:24px}.connect-tabs{display:flex;gap:8px;margin-bottom:16px}.tab-btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:none;color:var(--text-secondary);cursor:pointer;font-size:14px;min-height:var(--touch-target)}.tab-btn.active{background:var(--btn-primary-bg);color:var(--btn-primary-color);border-color:var(--btn-primary-bg)}.connect-panel{width:100%;max-width:400px;text-align:left}.settings-page{max-width:500px}.settings-form{display:flex;flex-direction:column;gap:16px}.setting-row{display:flex;flex-direction:column;gap:4px}.setting-label{font-size:13px;color:var(--text-secondary);font-weight:500}.page-title{font-size:20px;font-weight:700;margin-bottom:16px}.input-label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:4px;margin-top:12px}.input{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary);font-size:16px;min-height:var(--touch-target);outline:none;font-family:var(--font-family)}.input:focus{border-color:var(--brand-primary);box-shadow:0 0 0 2px var(--focus-ring)}.textarea{resize:vertical;min-height:80px}select.input{appearance:none}select.input option{background:#1a1a1a;color:#fff}.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border:none;border-radius:8px;background:var(--btn-primary-bg);color:var(--btn-primary-color);font-size:15px;font-weight:600;cursor:pointer;min-height:var(--touch-target);margin-top:16px;width:100%}.btn-primary:active{background:var(--btn-primary-hover)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border:1px solid var(--border);border-radius:6px;background:var(--btn-secondary-bg);color:var(--btn-secondary-color);font-size:13px;cursor:pointer;min-height:36px}.btn-danger{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border:1px solid transparent;border-radius:6px;background:var(--btn-danger-bg);color:var(--btn-danger-color);font-size:13px;cursor:pointer;min-height:36px}.btn-sm{padding:6px 12px;font-size:12px;min-height:32px}.error-text{color:var(--text-error);font-size:13px;margin-top:8px}.status-text{color:var(--text-success);font-size:13px;margin-top:8px}.loading-text{color:var(--text-hint);font-size:14px;text-align:center;padding:24px}.empty-text{color:var(--text-secondary);font-size:14px;text-align:center;padding:24px}.hidden{display:none}.qr-viewport{width:100%;aspect-ratio:1;background:var(--bg);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center}.qr-video{width:100%;height:100%;object-fit:cover}.qr-fallback{padding:16px;color:var(--text-secondary);font-size:13px}.app-tile{box-shadow:var(--shadow-sm)}.app-tile:active{box-shadow:var(--shadow-md)}.tile-summary{font-size:12px;color:var(--text-secondary);line-height:1.3;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.signal-bars{display:flex;align-items:flex-end;gap:2px;height:16px}.signal-bar{width:3px;border-radius:1px;background:var(--text-hint);transition:background var(--transition-fast)}.signal-bar:nth-child(1){height:4px}.signal-bar:nth-child(2){height:7px}.signal-bar:nth-child(3){height:11px}.signal-bar:nth-child(4){height:16px}.signal-bar.active{background:var(--text-success)}.conn-type-icon{width:16px;height:16px;color:var(--text-secondary)}.conn-hub-name{font-size:14px;font-weight:600;color:var(--text-primary)}.hub-card{box-shadow:var(--shadow-sm)}.hub-card-time{font-size:12px;color:var(--text-hint);display:block}.hub-card-url{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hub-card-status{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px}.hub-card-status.online{background:var(--text-success)}.hub-card-status.offline{background:var(--text-hint)}.settings-page .input,.settings-page .select,.settings-page .btn-primary{min-height:44px}.settings-section-label{font-size:12px;font-weight:600;color:var(--text-hint);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;margin-top:24px}.settings-section-label:first-child{margin-top:0}.skeleton-line{height:14px;background:linear-gradient(90deg,var(--bg-card) 25%,var(--border) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:4px;margin-bottom:8px}.skeleton-line:last-child{width:60%}.skeleton-circle{width:40px;height:40px;border-radius:50%;background:linear-gradient(90deg,var(--bg-card) 25%,var(--border) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}.skeleton-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:8px}.skeleton-card .skeleton-line:first-child{width:40%;height:18px;margin-bottom:16px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;padding:32px 24px;color:var(--text-hint);font-size:14px;display:flex;flex-direction:column;align-items:center;gap:16px}.empty-state-icon{width:48px;height:48px;color:var(--text-hint);opacity:.5}.empty-state-text{max-width:280px;line-height:1.5}.app-row,.hub-card{box-shadow:var(--shadow-sm)}.dash{display:flex;flex-direction:column;gap:16px}.dash-welcome{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:var(--shadow-sm)}.dash-welcome-row{display:flex;align-items:center;gap:12px}.dash-avatar{width:44px;height:44px;border-radius:50%;background:var(--accent-dim);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.dash-welcome-text{flex:1}.dash-greeting{font-size:16px;font-weight:600}.dash-role{display:flex;align-items:center;gap:8px;margin-top:4px}.dash-role-tag{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--accent-dim);color:var(--accent);font-weight:500}.dash-slug{font-size:12px;color:var(--text-hint)}.dash-stats,.dash-stats-skeleton{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.dash-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center;box-shadow:var(--shadow-sm)}.dash-stat-value{font-size:24px;font-weight:700;line-height:1.2}.dash-stat-label{font-size:11px;color:var(--text-secondary);margin-top:2px;text-transform:uppercase;letter-spacing:.05em}.dash-section{display:flex;flex-direction:column;gap:8px}.dash-section-title{font-size:13px;font-weight:600;color:var(--text-hint);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:8px}.dash-count{font-weight:400;font-size:12px;color:var(--text-success);text-transform:none;letter-spacing:0}.dash-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.dash-action-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border:1px solid var(--border);border-radius:10px;background:var(--bg-card);color:var(--text-primary);cursor:pointer;min-height:var(--touch-target);transition:background var(--transition-fast)}.dash-action-btn:active{background:var(--bg-card-hover)}.dash-action-btn svg{width:22px;height:22px;color:var(--accent)}.dash-action-btn span{font-size:11px;font-weight:500}.dash-app-list{display:flex;flex-direction:column;gap:4px}.dash-app-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;min-height:44px}.dash-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-green{background:var(--text-success)}.dot-red{background:var(--text-error)}.dash-app-name{flex:1;font-size:14px;font-weight:500}.dash-app-status{font-size:12px;color:var(--text-hint)}.dash-app-stopped{color:var(--text-error)}.dash-open-btn{padding:4px 12px;border:1px solid var(--accent);border-radius:6px;background:none;color:var(--accent);font-size:12px;font-weight:500;cursor:pointer;min-height:28px}.dash-open-btn:active{background:var(--accent-dim)}.dash-footer{text-align:center;padding:16px 0;color:var(--text-hint);font-size:12px}.standalone-banner{display:none!important}
