.dev-hub-root{min-height:100vh;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(16,185,129,.12),transparent),radial-gradient(ellipse 60% 40% at 100% 50%,rgba(99,102,241,.08),transparent),#060606;color:var(--text-main);position:relative;font-feature-settings:"ss01","cv01"}.dev-hub-grid-bg{inset:0;background-image:linear-gradient(rgba(16,185,129,.04) 1px,transparent 0),linear-gradient(90deg,rgba(16,185,129,.04) 1px,transparent 0);background-size:48px 48px}.dev-hub-glow,.dev-hub-grid-bg{position:fixed;pointer-events:none;z-index:0}.dev-hub-glow{width:50vw;height:50vw;border-radius:50%;filter:blur(120px);opacity:.35}.dev-hub-glow--tl{top:-20%;left:-10%;background:radial-gradient(circle,rgba(16,185,129,.25),transparent 70%)}.dev-hub-glow--br{bottom:-20%;right:-10%;background:radial-gradient(circle,rgba(99,102,241,.2),transparent 70%)}.dev-hub-shell{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:1.5rem clamp(1rem,3vw,2.5rem) 3rem}.dev-hub-root--shell{--dev-hub-topbar-h:56px;--dev-hub-sidebar-w:252px;min-height:100vh}.dev-hub-frame{position:relative;z-index:1;min-height:100vh}.dev-hub-topbar{position:fixed;top:0;left:0;right:0;z-index:50;height:var(--dev-hub-topbar-h);display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:0 1rem;border-bottom:1px solid var(--border);background:rgba(6,6,6,.92);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.dev-hub-menu-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.04);color:var(--text-main);cursor:pointer;flex-shrink:0}.dev-hub-menu-btn:hover{background:rgba(255,255,255,.08)}.dev-hub-topbar-start{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;min-width:0}.dev-hub-topbar-brand{display:flex;align-items:center;gap:.65rem;text-decoration:none;color:inherit}.dev-hub-brand-mark--sm{width:36px;height:36px;border-radius:10px}.dev-hub-topbar-brand-text{display:flex;flex-direction:column;line-height:1.1}.dev-hub-topbar-brand-title{font-size:.95rem;font-weight:800;letter-spacing:-.02em}.dev-hub-topbar-brand-sub{font-size:.68rem;color:var(--text-sub);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.dev-hub-breadcrumbs{display:flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:600}.dev-hub-crumb{color:var(--text-sub);text-decoration:none;transition:color .15s}.dev-hub-crumb.active,.dev-hub-crumb:hover{color:var(--text-main)}.dev-hub-crumb-sep{color:var(--text-sub);opacity:.5}.dev-hub-topbar-actions{display:flex;align-items:center;gap:.35rem}.dev-hub-sidebar-backdrop{display:none;position:fixed;inset:0;z-index:35;border:none;padding:0;margin:0;background:rgba(0,0,0,.55);opacity:0;pointer-events:none;transition:opacity .2s ease;cursor:pointer}.dev-hub-sidebar-backdrop.is-open{opacity:1;pointer-events:auto}.dev-hub-frame-body{padding-top:var(--dev-hub-topbar-h);min-height:100vh}.dev-hub-sidebar{position:fixed;top:var(--dev-hub-topbar-h);left:0;bottom:0;z-index:45;width:var(--dev-hub-sidebar-w);display:flex;flex-direction:column;border-right:1px solid var(--border);background:rgba(8,8,8,.94);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:.75rem;overflow:hidden}.dev-hub-sidebar-head{display:none;align-items:center;justify-content:space-between;padding:.25rem .35rem .75rem;border-bottom:1px solid var(--border);margin-bottom:.5rem;flex-shrink:0}.dev-hub-sidebar-head-title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--text-sub)}.dev-hub-sidebar-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text-main);cursor:pointer}.dev-hub-sidebar-nav{flex:1 1;min-height:0;display:flex;flex-direction:column;gap:.15rem;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding-right:.15rem;-webkit-overflow-scrolling:touch}.dev-hub-sidebar-label{margin:1rem .5rem .35rem;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--text-sub)}.dev-hub-sidebar-label:first-child{margin-top:0}.dev-hub-sidebar-apps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.15rem}.dev-hub-nav-item{display:flex;align-items:center;gap:.65rem;padding:.55rem .65rem;border-radius:var(--radius-md);text-decoration:none;color:var(--text-sub);font-size:.85rem;font-weight:600;border:1px solid transparent;transition:background .15s,color .15s,border-color .15s}.dev-hub-nav-item:hover{color:var(--text-main);background:rgba(255,255,255,.04)}.dev-hub-nav-item.active{color:var(--text-main);background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.25)}.dev-hub-nav-item--sub{padding-left:2rem;font-size:.78rem}.dev-hub-nav-icon-wrap{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:rgba(255,255,255,.04);flex-shrink:0}.dev-hub-nav-item.active .dev-hub-nav-icon-wrap{background:color-mix(in srgb,var(--nav-accent,#10b981) 18%,transparent)}.dev-hub-nav-item-text{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:.05rem}.dev-hub-nav-item-title{font-weight:700;letter-spacing:-.01em}.dev-hub-nav-item-meta{font-size:.68rem;font-weight:600;color:var(--text-sub);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.dev-hub-nav-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.15);flex-shrink:0}.dev-hub-nav-dot--running{background:#10b981;box-shadow:0 0 8px rgba(16,185,129,.6)}.dev-hub-nav-dot--error{background:#ef4444}.dev-hub-sidebar-foot{margin-top:auto;padding-top:1rem;border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.dev-hub-sidebar-stat{padding:.5rem .65rem;border-radius:var(--radius-md);background:rgba(255,255,255,.03);border:1px solid var(--border)}.dev-hub-sidebar-stat-label{display:block;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-sub)}.dev-hub-sidebar-stat-value{font-size:1rem;font-weight:800;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:#10b981}.dev-hub-main{flex:1 1;min-width:0;overflow:auto;padding:1.25rem clamp(1rem,2.5vw,2rem) 2.5rem}@media (min-width:1024px){.dev-hub-main{margin-left:var(--dev-hub-sidebar-w)}}.dev-hub-nav-item--external .dev-hub-nav-external{margin-left:auto;opacity:.45;flex-shrink:0}.dev-hub-admin-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;font-weight:800;color:#f59e0b;padding:.35rem .55rem;border-radius:8px;border:1px solid rgba(245,158,11,.25);background:rgba(245,158,11,.08)}.dev-hub-login-divider{margin:1.75rem 0;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}.dev-hub-login-admin-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.dev-hub-login-admin-title{margin:0;font-size:.95rem;font-weight:800;letter-spacing:.02em}.dev-hub-login-admin-hint{margin:0 0 1rem;font-size:.8rem;color:var(--text-sub);line-height:1.5}.dev-hub-login-admin-success{padding:.85rem 1rem;border-radius:10px;background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);font-size:.85rem;line-height:1.5}.dev-hub-admin-login-backdrop{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;padding:1rem}.dev-hub-admin-login-modal{width:100%;max-width:360px;background:#0a0a0a;border:1px solid #222;border-radius:14px;padding:1.5rem;display:flex;flex-direction:column;gap:.65rem}.dev-hub-admin-login-modal h2{margin:0;font-size:1.1rem}.dev-hub-admin-login-modal p{margin:0;font-size:.82rem;color:var(--text-sub)}.dev-hub-admin-login-modal input{padding:.65rem .75rem;border-radius:8px;border:1px solid #222;background:#111;color:#fff}.dev-hub-admin-login-error{color:#f87171!important;font-size:.8rem!important}.dev-hub-admin-login-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.25rem}.dev-hub-admin-chat-fab{bottom:1rem;width:48px;height:48px;border-radius:999px;border:none;background:#f59e0b;color:#000;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(245,158,11,.35)}.dev-hub-admin-chat-fab,.dev-hub-admin-chat-panel{position:fixed;right:1rem;z-index:1100;display:flex}.dev-hub-admin-chat-panel{bottom:4.25rem;width:320px;max-height:420px;background:rgba(10,10,10,.98);border:1px solid var(--border);border-radius:14px;flex-direction:column;overflow:hidden}.dev-hub-admin-chat-head{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;border-bottom:1px solid var(--border);font-size:.85rem}.dev-hub-admin-chat-head button{background:transparent;border:none;color:var(--text-sub);font-size:1.2rem;cursor:pointer}.dev-hub-admin-chat-msgs{flex:1 1;overflow-y:auto;padding:.6rem .75rem;display:flex;flex-direction:column;gap:.4rem}.dev-hub-admin-chat-msg{background:rgba(255,255,255,.04);border-radius:8px;padding:.4rem .55rem;font-size:.82rem}.dev-hub-admin-chat-user{display:block;font-size:.68rem;color:#f59e0b;font-weight:800}.dev-hub-admin-chat-form{display:flex;gap:.4rem;padding:.55rem;border-top:1px solid var(--border)}.dev-hub-admin-chat-form input{flex:1 1;border-radius:8px;border:1px solid var(--border);background:#111;color:#fff;padding:.4rem .55rem;font-size:.8rem}.dev-hub-admin-chat-form button{border:none;border-radius:8px;background:#f59e0b;color:#000;font-weight:800;padding:.4rem .65rem;font-size:.78rem;cursor:pointer}.dev-hub-admin-chat-toast{position:fixed;right:1rem;bottom:5.25rem;z-index:1101;background:#111827;color:#f9fafb;border:1px solid #374151;border-radius:10px;padding:.55rem .75rem;font-size:.8rem}.dev-hub-page{max-width:1400px}.dev-hub-page--fill{max-width:none;display:flex;flex-direction:column;min-height:calc(100vh - var(--dev-hub-topbar-h) - 2.5rem)}.dev-hub-page--fill .dev-hub-workspace-wrap{flex:1 1;min-height:0}.dev-hub-page-header{margin-bottom:1.5rem}.dev-hub-page-title{font-size:clamp(1.35rem,2.5vw,1.75rem);font-weight:900;letter-spacing:-.03em;margin:0;line-height:1.1}.dev-hub-page-subtitle{margin:.4rem 0 0;font-size:.875rem;color:var(--text-sub);font-weight:500}@media (max-width:1023px){.dev-hub-menu-btn{display:flex}.dev-hub-sidebar-backdrop{display:block}.dev-hub-sidebar{top:0;width:min(88vw,300px);max-width:300px;padding-top:.5rem;transform:translateX(-105%);transition:transform .22s cubic-bezier(.16,1,.3,1);box-shadow:none;z-index:60}.dev-hub-sidebar.is-open{transform:translateX(0);box-shadow:8px 0 40px rgba(0,0,0,.45)}.dev-hub-sidebar-head{display:flex}.dev-hub-main{margin-left:0}.dev-hub-breadcrumbs,.dev-hub-topbar-brand-sub{display:none}}@media (max-width:640px){.dev-hub-topbar-actions .btn{padding-left:.6rem;padding-right:.6rem;min-width:40px}.dev-hub-topbar-action-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}}@media (min-width:1024px){.dev-hub-sidebar{transform:none!important}}.dev-hub-header{justify-content:space-between;gap:1rem;flex-wrap:wrap}.dev-hub-brand,.dev-hub-header{display:flex;align-items:center}.dev-hub-brand{gap:.85rem}.dev-hub-brand-mark{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(16,185,129,.25)}.dev-hub-title{font-size:1.35rem;font-weight:800;letter-spacing:-.03em;line-height:1.1}.dev-hub-subtitle{font-size:.8rem;color:var(--text-sub);font-weight:500}.dev-hub-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:2rem}.dev-hub-metric{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.1rem 1.25rem;-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur))}.dev-hub-metric-value{font-size:1.75rem;font-weight:900;letter-spacing:-.04em;line-height:1}.dev-hub-metric-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-sub);font-weight:700;margin-top:.35rem}.dev-hub-apps{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.dev-hub-app-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;display:flex;flex-direction:column;gap:1rem;transition:border-color .2s,transform .2s,box-shadow .2s}.dev-hub-app-card:hover{border-color:rgba(16,185,129,.35);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.dev-hub-app-head{display:flex;align-items:flex-start;gap:.85rem}.dev-hub-app-dot{width:10px;height:10px;border-radius:50%;margin-top:.35rem;flex-shrink:0}.dev-hub-app-name{font-weight:800;font-size:1.05rem;letter-spacing:-.02em}.dev-hub-app-desc{font-size:.8rem;color:var(--text-sub);margin-top:.2rem;line-height:1.4}.dev-hub-app-meta{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.dev-hub-pill{padding:.25rem .55rem;border-radius:999px;border:1px solid var(--border);color:var(--text-sub)}.dev-hub-pill--running{color:#10b981;border-color:rgba(16,185,129,.35);background:rgba(16,185,129,.08)}.dev-hub-pill--error{color:#ef4444;border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.08)}.dev-hub-pill--healthy{color:#06b6d4;border-color:rgba(6,182,212,.35)}.dev-hub-app-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto}.dev-hub-app-actions .btn{width:auto;flex:1 1;min-width:5rem}.dev-hub-workspace-wrap{display:flex;flex-direction:column;gap:.5rem}.dev-hub-workspace-toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.5rem .65rem;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.02)}.dev-hub-workspace-toolbar-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--text-sub);margin-right:.25rem}.dev-hub-workspace{height:min(86vh,calc(100dvh - 5.5rem));min-height:520px;border:1px solid rgba(16,185,129,.12);border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(180deg,rgba(12,12,14,.98),rgba(6,6,8,1));box-shadow:inset 0 0 0 1px rgba(255,255,255,.04),0 24px 48px rgba(0,0,0,.45)}.dev-hub-workspace--flex{display:flex;flex-direction:row;align-items:stretch}.dev-hub-workspace--loading{display:flex;align-items:center;justify-content:center;color:var(--text-sub);padding:3rem}.dev-hub-resize-handle{flex:0 0 6px;cursor:col-resize;background:rgba(255,255,255,.04);border-left:1px solid var(--border);border-right:1px solid var(--border);transition:background .15s;position:relative;z-index:2}.dev-hub-resize-handle:active,.dev-hub-resize-handle:hover{background:rgba(16,185,129,.25)}.dev-hub-preview{display:flex;flex-direction:column;flex:1 1;min-height:0;min-width:0;overflow:hidden}.dev-hub-action-btn,.dev-hub-tap{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.dev-hub-action-btn{cursor:pointer;-webkit-user-select:none;user-select:none;width:auto!important;flex:1 1 auto;min-width:4.5rem;min-height:38px!important}.dev-hub-port-hint{font-size:.68rem;color:var(--text-sub);margin:.15rem 0 0}.dev-hub-port-control{display:flex;flex-direction:column;gap:.35rem;width:100%}.dev-hub-port-control--compact{margin-bottom:.25rem}.dev-hub-port-label{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-sub)}.dev-hub-port-row{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.dev-hub-port-host{font-family:ui-monospace,monospace;font-size:.8rem;color:var(--text-sub);font-weight:600}.dev-hub-port-input{width:5.5rem;min-height:36px!important;padding:.35rem .5rem!important;font-family:ui-monospace,monospace;font-size:.85rem!important}.dev-hub-port-error{font-size:.72rem;color:var(--error);margin:0}.dev-hub-preview-root{display:flex;flex-direction:column;flex:1 1;min-height:0;height:100%;width:100%}.dev-hub-preview-root--min .dev-hub-preview-bar{border-bottom:none}.dev-hub-preview-root--contrast .dev-hub-iframe-wrap{outline:3px solid #f8fafc;outline-offset:-3px}.dev-hub-preview-root--reduce-motion .spinner-mini{animation:none!important}.dev-hub-preview-bar{display:flex;align-items:center;gap:.5rem;padding:.65rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-sub);flex-wrap:wrap;flex-shrink:0}.dev-hub-preview-window-controls{display:flex;align-items:center;gap:.25rem;margin-left:auto;flex-shrink:0}.dev-hub-preview-win-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid var(--border);border-radius:6px;background:rgba(255,255,255,.04);color:var(--text-sub);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.dev-hub-preview-win-btn.active,.dev-hub-preview-win-btn:hover{color:var(--brand);border-color:rgba(16,185,129,.45);background:rgba(16,185,129,.1)}.dev-hub-preview-a11y{position:relative}.dev-hub-preview-a11y-menu{position:absolute;top:calc(100% + .35rem);right:0;z-index:30;min-width:220px;padding:.75rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);box-shadow:0 12px 40px rgba(0,0,0,.45)}.dev-hub-preview-a11y-label{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-sub);margin:0 0 .5rem}.dev-hub-preview-a11y-row{display:flex;align-items:center;gap:.35rem;margin-bottom:.5rem}.dev-hub-preview-a11y-row button{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-sub);color:var(--text);cursor:pointer}.dev-hub-preview-a11y-row span{flex:1 1;text-align:center;font-size:.8rem;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.dev-hub-preview-a11y-check{display:flex;align-items:center;gap:.5rem;font-size:.78rem;margin-bottom:.35rem;cursor:pointer}.dev-hub-preview-a11y-skip{display:block;margin-top:.5rem;font-size:.75rem;font-weight:700;color:var(--brand)}.dev-hub-workspace-hint{font-size:.72rem;color:var(--text-sub);margin-left:auto}.dev-hub-workspace--preview-maximized{height:min(92vh,calc(100dvh - 4.5rem))}.dev-hub-workspace--preview-maximized .dev-hub-iframe-wrap{min-height:0}.dev-hub-workspace--preview-maximized .dev-hub-iframe-zoom{min-height:100%}.dev-hub-preview--maximized{flex:1 1 100%!important;width:100%!important;max-width:100%!important}.dev-hub-preview--minimized{flex:0 0 auto!important;max-height:3.35rem;overflow:hidden}.dev-hub-panel--hidden{border:none!important}.dev-hub-iframe-zoom{transform-origin:top left}.dev-hub-iframe-zoom iframe{width:100%;height:100%;border:0;display:block}#dev-hub-app-preview:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.dev-hub-preview-url{flex:1 1;font-size:.75rem;color:var(--text-sub);font-family:ui-monospace,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dev-hub-iframe-wrap{flex:1 1 auto;min-height:0;height:100%;background:#030303;position:relative;overflow:auto;-webkit-overflow-scrolling:touch}.dev-hub-iframe-zoom{min-height:min(720px,100%)}.dev-hub-preview--maximized .dev-hub-iframe-wrap{min-height:0}.dev-hub-iframe-placeholder{flex-direction:column;gap:1rem;color:var(--text-sub);padding:2rem;text-align:center}.dev-hub-iframe-loading,.dev-hub-iframe-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.dev-hub-iframe-loading{gap:.75rem;background:rgba(0,0,0,.55);color:#a7f3d0;font-size:.85rem;font-weight:600;pointer-events:none}.dev-hub-preview-status{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-sub);padding:.2rem .5rem;border-radius:6px;background:rgba(255,255,255,.04)}.dev-hub-preview-status--ok{color:#10b981;background:rgba(16,185,129,.1)}.dev-hub-panel{min-width:0;background:var(--bg-sub);border-left:1px solid var(--border)}.dev-hub-panel,.dev-hub-panel-inner{display:flex;flex-direction:column;flex:1 1;min-height:0;height:100%}.dev-hub-panel-body{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;overflow:hidden}.dev-hub-workspace--flipped .dev-hub-panel{border-left:none;border-right:1px solid var(--border)}@media (max-width:1024px){.dev-hub-workspace{height:auto;min-height:0}.dev-hub-workspace--flex{flex-direction:column;min-height:min(92dvh,900px)}.dev-hub-preview{flex:0 0 auto!important;width:100%!important;min-height:38vh;max-height:48vh}.dev-hub-preview .dev-hub-iframe-wrap{min-height:30vh}.dev-hub-panel{flex:1 1 auto!important;width:100%!important;max-height:none}.dev-hub-panel,.dev-hub-panel-inner{min-height:42vh}.dev-hub-log-view{min-height:28vh}.dev-hub-resize-handle{flex:0 0 8px;width:100%;height:8px;cursor:row-resize}.dev-hub-panel-controls .dev-hub-action-btn{min-height:44px!important;flex:1 1 30%}}.dev-hub-panel-tabs{display:flex;border-bottom:1px solid var(--border)}.dev-hub-panel-tab{flex:1 1;padding:.75rem;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;background:transparent;color:var(--text-sub);cursor:pointer;border:none;border-bottom:2px solid transparent;min-height:auto}.dev-hub-panel-tab.active{color:var(--brand);border-bottom-color:var(--brand);background:rgba(16,185,129,.05)}.dev-hub-panel-controls{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.dev-hub-panel-controls .btn{width:auto;flex:1 1;min-width:0;padding:.45rem .65rem;font-size:.72rem;min-height:36px}.dev-hub-log-view{flex:1 1 auto;height:100%;min-height:0;overflow:auto;overflow-x:auto;padding:.75rem 1rem;font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:clamp(.65rem,1.8vw,.78rem);line-height:1.5;color:#a7f3d0;background:#030303;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.dev-hub-log-line--muted{color:var(--text-sub)}.dev-hub-log-view::-webkit-scrollbar{display:block;width:6px}.dev-hub-log-line{white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;margin-bottom:.12rem}.dev-hub-terminal-input{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--border)}.dev-hub-terminal-input input{flex:1 1;min-height:40px;font-family:ui-monospace,monospace;font-size:.8rem}.dev-hub-terminal-input .btn{width:auto;min-width:72px}.dev-hub-back{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:700;color:var(--text-sub);margin-bottom:1rem}.dev-hub-back:hover{color:var(--brand)}.dev-hub-section{margin-bottom:2.75rem}.dev-hub-section--local{padding-top:.5rem;border-top:1px solid rgba(255,255,255,.06)}.dev-hub-section-head{margin-bottom:1.35rem}.dev-hub-section-eyebrow{display:inline-flex;align-items:center;gap:.4rem;font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:#10b981;margin-bottom:.5rem;padding:.35rem .65rem;border-radius:999px;background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.2)}.dev-hub-section-eyebrow--local{color:#a78bfa;background:rgba(167,139,250,.08);border-color:rgba(167,139,250,.22)}.dev-hub-section-title{font-size:clamp(1.35rem,3vw,1.75rem);font-weight:900;letter-spacing:-.035em;line-height:1.15;margin-bottom:.35rem}.dev-hub-section-desc{font-size:.9rem;color:var(--text-sub);max-width:52ch;line-height:1.55}.dev-hub-section-stat{color:#10b981;font-weight:700}.dev-hub-alert{margin-bottom:1.25rem}.dev-hub-empty{color:var(--text-sub);font-size:.9rem;padding:2rem 0}.dev-hub-prod-head-row{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1rem 1.5rem}.dev-hub-prod-summary-chips{display:flex;flex-wrap:wrap;gap:.5rem}.dev-hub-prod-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .75rem;border-radius:999px;font-size:.72rem;font-weight:700;color:var(--text-sub);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}.dev-hub-prod-chip--accent{color:#34d399;border-color:rgba(16,185,129,.35);background:rgba(16,185,129,.08)}.dev-hub-prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.dev-hub-prod-card{position:relative;display:flex;flex-direction:column;gap:0;padding:0;border-radius:16px;color:inherit;background:linear-gradient(145deg,rgba(255,255,255,.04),rgba(255,255,255,.01));border:1px solid rgba(255,255,255,.08);overflow:hidden;transition:transform .25s cubic-bezier(.34,1.2,.64,1),border-color .2s,box-shadow .25s}.dev-hub-prod-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,color-mix(in srgb,var(--prod-accent,#10b981) 12%,transparent),transparent 55%);pointer-events:none;opacity:.9}.dev-hub-prod-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--prod-accent,#10b981) 45%,transparent);box-shadow:0 20px 40px rgba(0,0,0,.35),0 0 0 1px color-mix(in srgb,var(--prod-accent,#10b981) 20%,transparent)}.dev-hub-prod-card-link{display:flex;flex-direction:column;gap:.35rem;padding:1.15rem 1.2rem .85rem;text-decoration:none;color:inherit;flex:1 1}.dev-hub-prod-register{display:flex;align-items:center;gap:.35rem;margin:0 .75rem .75rem;padding:.5rem .65rem;border-radius:10px;font-size:.72rem;font-weight:700;text-decoration:none;color:var(--prod-accent,#8b5cf6);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);transition:background .2s,border-color .2s}.dev-hub-prod-register:hover{background:color-mix(in srgb,var(--prod-accent,#8b5cf6) 12%,transparent);border-color:color-mix(in srgb,var(--prod-accent,#8b5cf6) 35%,transparent)}.dev-hub-prod-register-path{font-family:ui-monospace,monospace;font-weight:600;opacity:.85}.dev-hub-prod-card--live{border-color:rgba(16,185,129,.22)}.dev-hub-prod-card--down{opacity:.72;border-color:rgba(239,68,68,.15)}.dev-hub-prod-card-top{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}.dev-hub-prod-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;padding:.28rem .55rem;border-radius:999px}.dev-hub-prod-status--live{color:#34d399;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.3);animation:dev-hub-pulse-live 2.5s ease-in-out infinite}.dev-hub-prod-status--down{color:#f87171;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25)}@keyframes dev-hub-pulse-live{0%,to{box-shadow:0 0 0 0 rgba(16,185,129,.35)}50%{box-shadow:0 0 0 6px rgba(16,185,129,0)}}.dev-hub-prod-arrow{color:var(--text-sub);opacity:.5;transition:opacity .2s,transform .2s}.dev-hub-prod-card:hover .dev-hub-prod-arrow{opacity:1;transform:translate(2px,-2px);color:var(--prod-accent,#10b981)}.dev-hub-prod-name{position:relative;z-index:1;font-size:1.05rem;font-weight:850;letter-spacing:-.02em}.dev-hub-prod-host{position:relative;z-index:1;font-family:ui-monospace,Cascadia Code,monospace;font-size:.78rem;color:rgba(255,255,255,.75);font-weight:600}.dev-hub-prod-tagline{position:relative;z-index:1;font-size:.72rem;color:var(--text-sub);margin-bottom:.5rem}.dev-hub-prod-latency-bar{position:relative;z-index:1;height:4px;margin:.5rem 0 .25rem;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}.dev-hub-prod-latency-bar-fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--prod-accent,#10b981),rgba(255,255,255,.35));transition:width .35s ease}.dev-hub-prod-footer{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:auto;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.06)}.dev-hub-prod-metric-block{display:flex;flex-direction:column;gap:.2rem;min-width:0}.dev-hub-prod-metric-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-sub)}.dev-hub-prod-metric-value{font-family:ui-monospace,Cascadia Code,monospace;font-size:.78rem;font-weight:700;color:rgba(255,255,255,.88);white-space:nowrap}.dev-hub-prod-metric-block--accent .dev-hub-prod-metric-value--latency{color:var(--prod-accent,#10b981);font-size:.85rem}.dev-hub-prod-metric{font-size:.65rem;font-weight:700;letter-spacing:.04em;color:var(--text-sub)}.dev-hub-prod-metric--accent{color:var(--prod-accent,#10b981)}.dev-hub-metric{position:relative;overflow:hidden}.dev-hub-metric:after{content:"";position:absolute;top:0;right:0;width:60px;height:60px;background:radial-gradient(circle at top right,rgba(16,185,129,.08),transparent 70%);pointer-events:none}.dev-hub-metric-icon{margin-bottom:.65rem;opacity:.9}.dev-hub-app-card{background:linear-gradient(160deg,rgba(20,20,20,.95),rgba(12,12,12,.98));border:1px solid rgba(255,255,255,.07);border-radius:16px;padding:1.35rem;box-shadow:0 4px 24px rgba(0,0,0,.2)}.dev-hub-app-icon{width:40px;height:40px;border-radius:12px;border:1px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dev-hub-app-head-text{flex:1 1;min-width:0}.dev-hub-app-prod-link{display:flex;align-items:center;gap:.5rem;padding:.55rem .75rem;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);text-decoration:none;color:var(--text-sub);font-size:.75rem;transition:border-color .2s,background .2s}.dev-hub-app-prod-link:hover{border-color:rgba(16,185,129,.35);background:rgba(16,185,129,.06);color:var(--text-main)}.dev-hub-app-prod-link--live{border-color:rgba(16,185,129,.2)}.dev-hub-prod-dot{width:6px;height:6px;border-radius:50%;background:#6b7280;flex-shrink:0}.dev-hub-prod-dot--live{background:#10b981;box-shadow:0 0 8px rgba(16,185,129,.8)}.dev-hub-app-prod-host{flex:1 1;font-family:ui-monospace,monospace;font-weight:600;color:rgba(255,255,255,.85);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dev-hub-app-prod-meta{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.dev-hub-header{padding-bottom:1.5rem;margin-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.06)}.dev-hub-brand-mark{width:48px;height:48px;border-radius:16px;box-shadow:0 8px 24px rgba(16,185,129,.3),inset 0 1px 0 rgba(255,255,255,.15)}.dev-hub-title{font-size:clamp(1.25rem,3vw,1.5rem);background:linear-gradient(180deg,#fff 0,#9ca3af);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dev-hub-shell{max-width:1280px}.dev-hub-nav{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.dev-hub-nav-btn{gap:.4rem}.dev-hub-pill--debug{color:#fbbf24;border-color:rgba(251,191,36,.35);background:rgba(251,191,36,.08)}.dev-hub-fleet-controls{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:1rem}.dev-hub-fleet-hint{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;color:var(--text-sub);margin-left:auto}.dev-hub-resource{display:flex;flex-direction:column;gap:.35rem;padding:.65rem .75rem;border-radius:var(--radius-md);border:1px solid var(--border);background:rgba(0,0,0,.15)}.dev-hub-resource--compact{padding:.5rem .65rem;gap:.25rem}.dev-hub-resource--idle{font-size:.72rem;color:var(--text-sub)}.dev-hub-resource-row{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}.dev-hub-resource-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-sub)}.dev-hub-resource-value{font-size:.75rem;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.dev-hub-resource-bar{height:4px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}.dev-hub-resource-fill{display:block;height:100%;border-radius:999px;transition:width .4s ease;min-width:2px}