:root{--bg-primary: #0A0A0C;--bg-secondary: #101013;--bg-tertiary: #161619;--bg-elevated: #1C1C21;--bg-hover: #232329;--bg-app: radial-gradient(900px 520px at 100% -15%, rgba(142, 123, 255, .06), transparent 62%), var(--bg-primary);--accent-primary: #8E7BFF;--accent-primary-strong: #7059E6;--accent-primary-soft: rgba(142, 123, 255, .13);--accent-secondary: #5BC8FF;--accent-gradient: linear-gradient(180deg, #9486FF 0%, #7A66F0 100%);--accent-success: #3DD68C;--accent-success-soft: rgba(61, 214, 140, .13);--accent-warning: #F5B23E;--accent-warning-soft: rgba(245, 178, 62, .14);--accent-danger: #F5566E;--accent-danger-soft: rgba(245, 86, 110, .14);--accent-info: #5BA8FF;--accent-info-soft: rgba(91, 168, 255, .13);--text-primary: #ECECF1;--text-secondary: #9A9AA6;--text-tertiary: #62626C;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 22px;--border-color: rgba(255, 255, 255, .07);--border-subtle: 1px solid rgba(255, 255, 255, .07);--border-strong: 1px solid rgba(255, 255, 255, .12);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 10px 30px rgba(0, 0, 0, .45);--shadow-lg: 0 24px 64px rgba(0, 0, 0, .6);--shadow-glow: 0 0 0 3px var(--accent-primary-soft);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.4, .5, 1);--duration-fast: .13s;--duration-normal: .22s;--sidebar-width: 248px;--header-height: 60px}[data-theme=light]{--bg-primary: #FAFAFB;--bg-secondary: #FFFFFF;--bg-tertiary: #F3F3F6;--bg-elevated: #FFFFFF;--bg-hover: #ECECF0;--bg-app: radial-gradient(900px 520px at 100% -15%, rgba(124, 108, 240, .06), transparent 62%), var(--bg-primary);--accent-primary: #6E56CF;--accent-primary-strong: #5B45BE;--accent-primary-soft: rgba(110, 86, 207, .1);--accent-gradient: linear-gradient(180deg, #7A63DB 0%, #6149C6 100%);--accent-success: #0FA968;--accent-success-soft: rgba(15, 169, 104, .12);--accent-warning: #C77A12;--accent-warning-soft: rgba(199, 122, 18, .12);--accent-danger: #DC3450;--accent-danger-soft: rgba(220, 52, 80, .11);--accent-info: #2D7DEE;--accent-info-soft: rgba(45, 125, 238, .1);--text-primary: #17171D;--text-secondary: #585866;--text-tertiary: #8C8C99;--border-color: rgba(12, 12, 24, .09);--border-subtle: 1px solid rgba(12, 12, 24, .08);--border-strong: 1px solid rgba(12, 12, 24, .14);--shadow-sm: 0 1px 2px rgba(16, 24, 40, .05);--shadow-md: 0 8px 28px rgba(16, 24, 40, .08);--shadow-lg: 0 24px 64px rgba(16, 24, 40, .14);--shadow-glow: 0 0 0 3px var(--accent-primary-soft)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}ul{list-style:none}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:6px;border:2px solid var(--bg-primary)}::selection{background:var(--accent-primary-soft);color:var(--text-primary)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:5px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.mono,.metric-value,.stat-line .v,table.data td,.kbd{font-variant-numeric:tabular-nums}.app-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;height:100vh;overflow:hidden;background:var(--bg-app);background-attachment:fixed}.app-shell.collapsed{grid-template-columns:66px 1fr}.main-col{display:flex;flex-direction:column;min-width:0;overflow:hidden}.page-body{flex:1;overflow-y:auto;padding:var(--space-xl) var(--space-2xl);animation:pageIn var(--duration-normal) var(--ease-out)}.page-body.flush{padding:0}@keyframes pageIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}@media (max-width: 1100px){.page-body{padding:var(--space-lg)}}.sidebar{background:var(--bg-secondary);border-right:var(--border-subtle);display:flex;flex-direction:column;overflow:hidden}.sidebar-brand{display:flex;align-items:center;gap:10px;height:var(--header-height);padding:0 var(--space-lg);border-bottom:var(--border-subtle);font-weight:700;font-size:14.5px;letter-spacing:-.2px;white-space:nowrap}.sidebar-brand .logo{width:28px;height:28px;border-radius:8px;background:var(--accent-gradient);display:grid;place-items:center;flex-shrink:0;box-shadow:inset 0 1px #ffffff40,0 2px 8px #7059e659}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-md) 10px;display:flex;flex-direction:column;gap:1px}.nav-section-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-tertiary);padding:var(--space-md) 10px var(--space-xs);font-weight:600}.nav-item{display:flex;align-items:center;gap:11px;padding:8px 11px;border-radius:var(--radius-sm);color:var(--text-secondary);font-weight:500;font-size:13.5px;white-space:nowrap;position:relative;transition:background var(--duration-fast),color var(--duration-fast)}.nav-item svg{opacity:.85}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--accent-primary-soft);color:var(--text-primary)}.nav-item.active svg{color:var(--accent-primary);opacity:1}.nav-item.active:before{content:"";position:absolute;left:-10px;top:7px;bottom:7px;width:3px;border-radius:0 3px 3px 0;background:var(--accent-primary)}.nav-item .kbd{margin-left:auto}.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-section-label,.sidebar.collapsed .brand-text,.sidebar.collapsed .nav-item .kbd{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.sidebar-footer{padding:var(--space-md);border-top:var(--border-subtle);font-size:11px;color:var(--text-tertiary)}.header{height:var(--header-height);border-bottom:var(--border-subtle);display:flex;align-items:center;gap:var(--space-md);padding:0 var(--space-2xl);background:color-mix(in srgb,var(--bg-primary) 70%,transparent);-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);flex-shrink:0;z-index:10}.header h1{font-size:15.5px;font-weight:650;letter-spacing:-.2px}.header-spacer{flex:1}.header-search{display:flex;align-items:center;gap:var(--space-sm);background:var(--bg-tertiary);border:var(--border-subtle);border-radius:var(--radius-sm);padding:7px var(--space-md);color:var(--text-tertiary);font-size:13px;min-width:220px;cursor:pointer;transition:border-color var(--duration-fast),background var(--duration-fast)}.header-search:hover{border-color:var(--border-color);background:var(--bg-elevated)}@media (max-width: 1100px){.header{padding:0 var(--space-lg)}.header-search{min-width:0}.header-search span:not(.kbd){display:none}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:8px 14px;border-radius:var(--radius-sm);font-weight:600;font-size:13px;background:var(--bg-elevated);color:var(--text-primary);border:var(--border-subtle);transition:transform var(--duration-fast),background var(--duration-fast),border-color var(--duration-fast),filter var(--duration-fast)}.btn:hover{background:var(--bg-hover);border-color:var(--border-color)}.btn:active{transform:scale(.985)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:disabled:active{transform:none}.btn-primary{background:var(--accent-gradient);border-color:transparent;color:#fff;box-shadow:inset 0 1px #ffffff2e}.btn-primary:hover{filter:brightness(1.07)}.btn-success{background:var(--accent-success);color:#03130b;border-color:transparent}.btn-success:hover{filter:brightness(1.05)}.btn-danger{background:var(--accent-danger);color:#fff;border-color:transparent}.btn-danger:hover{filter:brightness(1.06)}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--bg-tertiary)}.btn-sm{padding:6px 11px;font-size:12px}.btn-icon{padding:8px}.btn-block{width:100%}.card{background:var(--bg-secondary);border:var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.card.tight{padding:var(--space-md)}.card.hover{transition:transform var(--duration-fast),border-color var(--duration-fast),box-shadow var(--duration-fast);cursor:pointer}.card.hover:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent-primary) 35%,transparent);box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);gap:var(--space-md)}.card-title{font-size:13.5px;font-weight:650;display:flex;align-items:center;gap:var(--space-sm);letter-spacing:-.1px}.card-title svg{color:var(--text-tertiary)}.card-subtitle{font-size:12px;color:var(--text-secondary);font-weight:400}.grid{display:grid;gap:var(--space-lg)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(248px,1fr))}.row{display:flex;align-items:center;gap:var(--space-md)}.row.wrap{flex-wrap:wrap}.col{display:flex;flex-direction:column;gap:var(--space-md)}.gap-sm{gap:var(--space-sm)}.gap-lg{gap:var(--space-lg)}.spacer{flex:1}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-lg{margin-bottom:var(--space-lg)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-success{color:var(--accent-success)}.text-danger{color:var(--accent-danger)}.text-warning{color:var(--accent-warning)}.text-center{text-align:center}.text-right{text-align:right}.mono{font-family:var(--font-mono)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 1200px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.grid-3,.grid-2,.grid-4{grid-template-columns:1fr}.app-shell{grid-template-columns:66px 1fr}}.metric-card{background:var(--bg-secondary);border:var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform var(--duration-fast),border-color var(--duration-fast)}.metric-card:hover{transform:translateY(-2px);border-color:var(--border-color)}.metric-card .metric-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:var(--accent-primary-soft);color:var(--accent-primary)}.metric-label{font-size:12px;color:var(--text-secondary);font-weight:500}.metric-value{font-size:28px;font-weight:750;letter-spacing:-.8px;line-height:1.05}.metric-delta{font-size:12px;font-weight:600;display:flex;align-items:center;gap:4px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:7px;font-size:11.5px;font-weight:600;border:1px solid transparent;white-space:nowrap}.badge-success{background:var(--accent-success-soft);color:var(--accent-success)}.badge-danger{background:var(--accent-danger-soft);color:var(--accent-danger)}.badge-warning{background:var(--accent-warning-soft);color:var(--accent-warning)}.badge-info{background:var(--accent-info-soft);color:var(--accent-info)}.badge-neutral{background:var(--bg-tertiary);color:var(--text-secondary);border-color:var(--border-color)}.badge-primary{background:var(--accent-primary-soft);color:var(--accent-primary)}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge.pulse .dot{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}.env-badge{text-transform:uppercase;letter-spacing:.4px}.env-dev{background:var(--accent-info-soft);color:var(--accent-info)}.env-qa{background:var(--accent-warning-soft);color:var(--accent-warning)}.env-staging{background:var(--accent-primary-soft);color:var(--accent-primary)}.env-prod{background:var(--accent-danger-soft);color:var(--accent-danger)}.table-wrap{overflow-x:auto;border-radius:var(--radius-md)}table.data{width:100%;border-collapse:collapse;font-size:13px}table.data th{text-align:left;padding:10px var(--space-md);color:var(--text-tertiary);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-bottom:var(--border-subtle);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;position:sticky;top:0;background:var(--bg-secondary);z-index:1}table.data th.no-sort{cursor:default}table.data td{padding:12px var(--space-md);border-bottom:var(--border-subtle);vertical-align:middle}table.data tbody tr{transition:background var(--duration-fast)}table.data tbody tr:last-child td{border-bottom:none}table.data tbody tr:hover{background:var(--bg-tertiary)}table.data tbody tr.clickable{cursor:pointer}.th-sort{display:inline-flex;align-items:center;gap:4px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12.5px;font-weight:600;color:var(--text-secondary)}.field .hint{font-size:11.5px;color:var(--text-tertiary)}.input,.select,textarea.input{background:var(--bg-tertiary);border:var(--border-subtle);border-radius:var(--radius-sm);padding:9px 12px;font-size:13px;color:var(--text-primary);width:100%;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.input:focus,.select:focus,textarea.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.input::placeholder{color:var(--text-tertiary)}textarea.input{resize:vertical;min-height:90px;font-family:var(--font-mono)}.input-row{display:flex;gap:var(--space-sm);align-items:center}.chip{padding:7px 13px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:var(--border-subtle);font-size:12.5px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast)}.chip:hover{border-color:var(--border-color);color:var(--text-primary);background:var(--bg-elevated)}.chip.active{background:var(--accent-primary);color:#fff;border-color:transparent}.toggle{width:38px;height:22px;border-radius:999px;background:var(--bg-elevated);border:var(--border-subtle);position:relative;transition:background var(--duration-fast);flex-shrink:0;cursor:pointer}.toggle.on{background:var(--accent-success);border-color:transparent}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform var(--duration-normal) var(--ease-spring);box-shadow:var(--shadow-sm)}.toggle.on:after{transform:translate(16px)}.checkbox{width:18px;height:18px;border-radius:5px;border:var(--border-strong);display:grid;place-items:center;cursor:pointer;flex-shrink:0;transition:all var(--duration-fast)}.checkbox.on{background:var(--accent-primary);border-color:transparent;color:#fff}.segmented{display:inline-flex;background:var(--bg-tertiary);border:var(--border-subtle);border-radius:var(--radius-sm);padding:3px;gap:2px}.segmented button{padding:6px 12px;border-radius:6px;font-size:12.5px;font-weight:600;color:var(--text-secondary)}.segmented button.active{background:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-sm)}.tabs{display:flex;gap:4px;border-bottom:var(--border-subtle);margin-bottom:var(--space-lg);flex-wrap:wrap}.tab{padding:10px 14px;font-size:13px;font-weight:600;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--duration-fast);cursor:pointer}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--text-primary);border-bottom-color:var(--accent-primary)}.progress{height:7px;background:var(--bg-elevated);border-radius:999px;overflow:hidden}.progress .bar{height:100%;background:var(--accent-primary);border-radius:999px;transition:width var(--duration-normal) var(--ease-out);position:relative}.progress .bar.indeterminate{width:35%!important;animation:indet 1.2s ease-in-out infinite}@keyframes indet{0%{margin-left:-35%}to{margin-left:100%}}.game-card{background:var(--bg-secondary);border:var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-md);cursor:pointer;transition:transform var(--duration-fast),border-color var(--duration-fast),box-shadow var(--duration-fast);display:flex;flex-direction:column;gap:10px;position:relative}.game-card:hover{border-color:color-mix(in srgb,var(--accent-primary) 45%,transparent);transform:translateY(-3px);box-shadow:var(--shadow-md)}.game-card.selected{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.game-card .thumb{height:68px;border-radius:var(--radius-md);background:var(--bg-tertiary);display:grid;place-items:center;font-size:26px;position:relative;overflow:hidden}.game-card .thumb:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 28% 18%,var(--accent-primary-soft),transparent 60%)}.game-card .game-name{font-weight:650;font-size:13.5px;letter-spacing:-.1px}.game-card .game-meta{display:flex;gap:var(--space-sm);flex-wrap:wrap;font-size:11px;color:var(--text-secondary)}.fav-star{position:absolute;top:10px;right:10px;color:var(--text-tertiary);transition:color var(--duration-fast),transform var(--duration-fast);z-index:2}.fav-star:hover{transform:scale(1.2)}.fav-star.on{color:var(--accent-warning)}.log-viewer{background:var(--bg-primary);border:var(--border-subtle);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:12px;line-height:1.65;overflow-y:auto;padding:var(--space-md);color:#c2c2cc}.log-line{white-space:pre-wrap;word-break:break-word}.log-line.error{color:var(--accent-danger)}.log-line.warn{color:var(--accent-warning)}.log-line.success{color:var(--accent-success)}.log-line.info{color:var(--accent-secondary)}.log-line.progress{color:var(--accent-primary)}.gauge-wrap{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.toast-stack{position:fixed;bottom:var(--space-xl);right:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-sm);z-index:1000}.toast{background:var(--bg-elevated);border:var(--border-strong);border-radius:var(--radius-md);padding:12px 15px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--space-sm);font-size:13px;font-weight:500;min-width:270px;max-width:400px;animation:slideIn var(--duration-normal) var(--ease-spring)}.toast.success{border-left:3px solid var(--accent-success)}.toast.error{border-left:3px solid var(--accent-danger)}.toast.info{border-left:3px solid var(--accent-info)}@keyframes slideIn{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#05050999;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:900;display:flex;align-items:flex-start;justify-content:center;padding-top:11vh;animation:fade var(--duration-fast)}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:min(560px,92vw);max-height:82vh;overflow:hidden;display:flex;flex-direction:column;animation:pop var(--duration-normal) var(--ease-spring)}.modal.wide{width:min(960px,95vw)}@keyframes pop{0%{transform:scale(.97) translateY(8px);opacity:0}to{transform:scale(1);opacity:1}}.modal-header{padding:var(--space-lg);border-bottom:var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.modal-body{padding:var(--space-lg);overflow-y:auto}.modal-footer{padding:var(--space-md) var(--space-lg);border-top:var(--border-subtle);display:flex;gap:var(--space-sm);justify-content:flex-end}.palette-input{width:100%;padding:var(--space-md) var(--space-lg);background:transparent;border:none;font-size:15px;color:var(--text-primary);border-bottom:var(--border-subtle)}.palette-input:focus{outline:none}.palette-list{overflow-y:auto;padding:var(--space-sm)}.palette-item{display:flex;align-items:center;gap:var(--space-md);padding:10px var(--space-md);border-radius:var(--radius-sm);cursor:pointer;font-size:13.5px;color:var(--text-secondary)}.palette-item.active{background:var(--accent-primary-soft);color:var(--text-primary)}.palette-item .kbd{margin-left:auto}.dropzone{border:1.5px dashed var(--border-color);border-radius:var(--radius-lg);padding:var(--space-2xl);text-align:center;color:var(--text-tertiary);transition:all var(--duration-fast);cursor:pointer}.dropzone:hover,.dropzone.drag{border-color:var(--accent-primary);background:var(--accent-primary-soft);color:var(--text-secondary)}.timeline{display:flex;flex-direction:column;gap:2px}.timeline-row{display:grid;grid-template-columns:180px 1fr 96px;align-items:center;gap:var(--space-md);padding:6px 0;border-radius:var(--radius-sm)}.timeline-row:hover{background:var(--bg-tertiary)}.timeline-track{height:20px;background:var(--bg-tertiary);border-radius:6px;position:relative;overflow:hidden}.timeline-bar{position:absolute;top:0;bottom:0;border-radius:6px;background:var(--accent-primary);min-width:4px}.timeline-bar.failed{background:var(--accent-danger)}.timeline-bar.stopped{background:var(--accent-warning)}.timeline-bar.completed{background:var(--accent-success)}.timeline-bar.running{background:var(--accent-info);animation:pulse 1.6s ease-in-out infinite}.kbd{font-family:var(--font-mono);font-size:10.5px;padding:2px 6px;border-radius:5px;background:var(--bg-elevated);border:var(--border-subtle);color:var(--text-tertiary)}.heatmap{display:flex;flex-wrap:wrap;gap:6px}.heat-cell{width:26px;height:26px;border-radius:7px;cursor:pointer;transition:transform var(--duration-fast);position:relative}.heat-cell:hover{transform:scale(1.3);z-index:2;box-shadow:var(--shadow-md)}.spark{display:flex;align-items:flex-end;gap:2px;height:22px}.spark span{width:3px;background:var(--accent-primary);border-radius:2px;opacity:.8}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-2xl);color:var(--text-tertiary);text-align:center}.empty-state .icon{opacity:.35}.loader{display:grid;place-items:center;padding:var(--space-2xl);color:var(--text-tertiary)}.spinner{width:26px;height:26px;border-radius:50%;border:2.5px solid var(--bg-elevated);border-top-color:var(--accent-primary);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl);gap:var(--space-md);flex-wrap:wrap}.page-title-row h2{font-size:22px;font-weight:750;letter-spacing:-.7px}.page-title-row .subtitle{color:var(--text-secondary);font-size:13px;margin-top:3px}.divider{height:1px;background:var(--border-color);margin:var(--space-md) 0}.stat-line{display:flex;justify-content:space-between;padding:8px 0;border-bottom:var(--border-subtle);font-size:13px}.stat-line:last-child{border-bottom:none}.stat-line .k{color:var(--text-secondary)}.stat-line .v{font-weight:600;font-family:var(--font-mono)}iframe.report-frame{width:100%;height:72vh;border:var(--border-subtle);border-radius:var(--radius-md);background:#fff}.report-viewer-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:950;display:flex;flex-direction:column;background:var(--bg-primary)}.report-viewer-bar{display:flex;align-items:center;gap:var(--space-md);padding:8px var(--space-lg);border-bottom:var(--border-subtle);background:var(--bg-secondary);flex-shrink:0;min-height:52px}.report-viewer-meta{flex:1;display:flex;align-items:center;gap:var(--space-md);min-width:0;overflow:hidden;flex-wrap:wrap}.report-viewer-title{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.report-viewer-frame{flex:1;border:none;width:100%;background:#fff}.report-viewer-restore{position:fixed;top:8px;right:12px;z-index:960}.report-viewer-empty{flex:1;display:grid;place-items:center;color:var(--text-tertiary);font-size:14px}.reports-layout{display:flex;gap:var(--space-lg);align-items:flex-start}.reports-inline-panel{width:540px;flex-shrink:0;background:var(--bg-secondary);border:var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;height:calc(100vh - 196px);position:sticky;top:20px}.reports-inline-header{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:var(--border-subtle);flex-shrink:0;flex-wrap:wrap;background:var(--bg-primary);row-gap:var(--space-sm)}.reports-inline-meta{flex:1;display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;min-width:0}.reports-inline-title{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.reports-inline-frame{flex:1;border:none;width:100%;background:#fff;min-height:0;display:block}.reports-inline-empty{flex:1;display:grid;place-items:center;color:var(--text-tertiary);font-size:13px;padding:var(--space-xl);text-align:center}@media (max-width: 960px){.reports-layout.with-viewer{flex-direction:column}.reports-inline-panel{width:100%;position:static;height:62vh}}.badge-success{background:var(--accent-success-soft, rgba(34,197,94,.15));color:var(--accent-success)}.badge-danger{background:var(--accent-danger-soft, rgba(239,68,68,.15));color:var(--accent-danger)}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-elevated) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{height:112px;border-radius:var(--radius-lg)}.skeleton-line{height:12px;margin:10px 0;border-radius:6px}.login-shell{min-height:100vh;display:grid;place-items:center;padding:var(--space-xl);background:var(--bg-primary)}.login-card{width:100%;max-width:380px;display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-2xl)}.login-brand{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm);color:var(--accent-primary)}.login-brand h2{font-size:20px;font-weight:750;letter-spacing:-.5px;color:var(--text-primary)}.login-error{font-size:12.5px;color:var(--accent-danger);background:color-mix(in srgb,var(--accent-danger) 12%,transparent);border:1px solid color-mix(in srgb,var(--accent-danger) 35%,transparent);border-radius:var(--radius-sm);padding:8px 12px}.monitor-grid{display:grid;grid-template-columns:min(320px,38%) 1fr;gap:var(--space-lg);align-items:start}@media (max-width: 900px){.monitor-grid{grid-template-columns:1fr}}.progress .bar:not(.indeterminate){background:linear-gradient(90deg,var(--accent-primary),color-mix(in srgb,var(--accent-primary) 80%,var(--accent-secondary)))}.loader{min-height:200px}.input::placeholder,.select option:first-child{color:var(--text-tertiary)}.chip:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}@keyframes offlinePulse{0%,to{opacity:1}50%{opacity:.65}}.badge.badge-danger [data-icon]{animation:offlinePulse 2s ease-in-out infinite}.card.selected{border-color:var(--accent-primary)!important;box-shadow:var(--shadow-glow)}.stat-line .v{word-break:break-word;max-width:60%;text-align:right}.toast.warning{border-left:3px solid var(--accent-warning)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}@media (max-width: 600px){.page-title-row{flex-direction:column;align-items:flex-start}.page-title-row .row{width:100%}.page-title-row .btn{flex:1;justify-content:center}.grid-4{grid-template-columns:repeat(2,1fr)}}
