.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-header{padding:20px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.sidebar-logo{height:22px;width:auto;align-self:flex-start}.sidebar-header span{font-size:12px;color:var(--text-muted)}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;color:var(--text-muted);font-size:14px;transition:all .15s}.nav-item:hover{color:var(--text);background:var(--bg)}.nav-item.active{color:var(--primary);background:var(--primary-light);border-right:2px solid var(--primary)}.nav-icon{font-size:16px;width:20px;text-align:center}.nav-divider{padding:16px 20px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);opacity:.6}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--border)}.user-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px}.user-role{background:var(--bg);padding:2px 8px;border-radius:4px;font-size:11px;text-transform:uppercase;color:var(--text-muted)}.logout-btn{width:100%;padding:6px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:13px;transition:all .15s}.logout-btn:hover{border-color:var(--danger);color:var(--danger)}.main-content{flex:1;margin-left:240px;padding:24px}.sidebar-toggle{display:none;position:fixed;top:12px;left:12px;z-index:200;width:40px;height:40px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);font-size:20px;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.sidebar-overlay{display:none}@media(max-width:768px){.sidebar-toggle{display:flex}.sidebar{transform:translate(-100%);transition:transform .2s ease}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0000004d;z-index:99}.sidebar-overlay.sidebar-open{display:block}.main-content{margin-left:0;padding:60px 16px 16px}}@media(max-width:600px){.main-content{padding:56px 12px 12px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-form{width:100%;max-width:380px;padding:40px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000a}.login-header{text-align:center;margin-bottom:32px}.login-logo{height:32px;width:auto;margin-bottom:4px}.login-header p{color:var(--text-muted);font-size:14px}.login-error{padding:10px 14px;background:#dc26260f;border:1px solid rgba(220,38,38,.2);border-radius:8px;color:var(--danger);font-size:13px;margin-bottom:16px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:6px}.form-group input{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;transition:border-color .15s}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.login-btn{width:100%;padding:10px;background:var(--primary);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;margin-top:8px;transition:background .15s}.login-btn:hover:not(:disabled){background:var(--primary-hover)}.login-btn:disabled{opacity:.6}.login-form-wide{max-width:440px}.setup-instructions{margin-bottom:20px;font-size:14px;color:var(--text);line-height:1.5}.qr-container{display:flex;justify-content:center;margin-bottom:20px}.qr-code{width:200px;height:200px;border-radius:8px;border:1px solid var(--border)}.manual-secret{margin-bottom:20px;text-align:center}.manual-secret label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:6px}.secret-code{font-family:SF Mono,Fira Code,monospace;font-size:13px;background:var(--bg);padding:8px 14px;border-radius:6px;border:1px solid var(--border);word-break:break-all;-webkit-user-select:all;user-select:all}.totp-hint{font-size:14px;color:var(--text-muted);margin-bottom:20px;text-align:center}.login-back-btn{width:100%;padding:8px;background:none;border:1px solid var(--border);border-radius:8px;color:var(--text-muted);font-size:13px;margin-top:8px;cursor:pointer;transition:background .15s,color .15s}.login-back-btn:hover{background:var(--bg);color:var(--text)}.page{max-width:1200px}.page-title{font-size:22px;font-weight:600;margin-bottom:24px;color:var(--text)}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px;box-shadow:0 1px 2px #00000008}.stat-label{font-size:13px;color:var(--text-muted);margin-bottom:8px}.stat-value{font-size:32px;font-weight:700;color:var(--text)}.stat-value.danger{color:var(--danger)}.stat-value.warning{color:var(--warning)}.stat-value.success{color:var(--success)}.stat-card-clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s}.stat-card-clickable:hover{border-color:var(--primary);box-shadow:0 2px 8px #0000000f}.placeholder-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:40px;text-align:center;box-shadow:0 1px 2px #00000008}.placeholder-card p{font-size:14px;margin-bottom:8px}.text-muted{color:var(--text-muted)}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header .page-title{margin-bottom:0}.btn{padding:8px 16px;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text);font-size:13px;cursor:pointer;transition:all .15s}.btn:hover{border-color:var(--text-muted)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-danger{color:var(--danger);border-color:#dc26264d}.btn-danger:hover{background:#dc26260f;border-color:var(--danger)}.btn-small{padding:4px 10px;font-size:12px}.badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;background:var(--bg);color:var(--text-muted)}.badge-success{background:#16a34a1a;color:var(--success)}.badge-muted{background:var(--bg);color:var(--text-muted)}.badge-outline{background:transparent;border:1px solid var(--border);color:var(--text-muted);font-weight:400;text-transform:none}.badge-warning{background:#d977061a;color:var(--warning)}.badge-danger{background:#dc26261a;color:var(--danger)}.env-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;margin-bottom:12px;box-shadow:0 1px 2px #00000008}.env-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;cursor:pointer;transition:background .1s}.env-header:hover{background:var(--bg)}.env-info{display:flex;align-items:center;gap:10px;font-size:14px}.env-expand{font-size:10px;color:var(--text-muted);width:16px}.env-meta{display:flex;align-items:center;gap:8px}.env-deployments{border-top:1px solid var(--border);padding:16px 20px}.deploy-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:13px}.deploy-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}.deploy-row:last-child{border-bottom:none}.deploy-info{display:flex;flex-direction:column;gap:2px}.deploy-actions{display:flex;align-items:center;gap:8px}.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:16px;box-shadow:0 1px 2px #00000008}.form-card h3{font-size:16px;font-weight:600;margin-bottom:16px}.form-card.form-inline{padding:16px}.form-row{display:flex;gap:12px;margin-bottom:12px}.form-row .form-group{flex:1;margin-bottom:0}.form-group{margin-bottom:12px}.form-group label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:4px}.form-group input,.form-group select{width:100%;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-actions{display:flex;gap:8px;margin-top:4px}.sync-table{width:100%;border-collapse:collapse;font-size:13px}.sync-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border);color:var(--text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.sync-table td{padding:10px 12px;border-bottom:1px solid var(--border)}.sync-table tr:last-child td{border-bottom:none}.form-error{background:#dc262614;border:1px solid rgba(220,38,38,.3);border-radius:6px;padding:10px 14px;margin-bottom:16px;color:var(--danger);font-size:13px}.user-table td{vertical-align:middle}.user-table input[disabled]{opacity:.5;cursor:not-allowed}@media(max-width:768px){.page{max-width:100%}.page-header{flex-direction:column;align-items:flex-start;gap:8px}.card-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:24px}.form-row{flex-direction:column}.log-filters{flex-direction:column;align-items:stretch}.filter-group select,.filter-group input{width:100%}.stat-card{overflow-x:auto;-webkit-overflow-scrolling:touch}.log-table{min-width:600px}.env-meta{flex-wrap:wrap}}@media(max-width:480px){.card-grid{grid-template-columns:1fr}}.kpi-page{max-width:1400px}.period-toggle{display:inline-flex;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:2px;gap:2px}.period-btn{padding:6px 14px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:13px;cursor:pointer;transition:all .15s;font-weight:500}.period-btn:hover{color:var(--text)}.period-btn.active{background:var(--bg-card);color:var(--text);box-shadow:0 1px 3px #00000014}.kpi-controls{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.kpi-controls select{padding:7px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px}.kpi-controls select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.kpi-summary-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:24px}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px 20px;box-shadow:0 1px 2px #00000008}.kpi-card-clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s}.kpi-card-clickable:hover{border-color:var(--primary);box-shadow:0 2px 8px #0000000f}.kpi-card-label{font-size:12px;color:var(--text-muted);margin-bottom:8px;font-weight:500}.kpi-card-value{font-size:28px;font-weight:700;color:var(--text);line-height:1;margin-bottom:6px}.kpi-card-delta{font-size:12px;font-weight:500}.kpi-card-delta.positive{color:var(--success)}.kpi-card-delta.negative{color:var(--danger)}.kpi-card-delta.neutral{color:var(--text-muted)}.kpi-card-period{font-size:11px;color:var(--text-muted);margin-top:2px}.kpi-derived-row{margin-top:-12px}.kpi-card-derived{border-style:dashed}.kpi-card-value-small{font-size:22px}.kpi-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.kpi-chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px;box-shadow:0 1px 2px #00000008}.kpi-chart-card.full-width{grid-column:1 / -1}.kpi-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.kpi-chart-title{font-size:14px;font-weight:600;color:var(--text)}.dist-toggle{display:inline-flex;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:2px;gap:2px}.dist-btn{padding:4px 10px;border:none;border-radius:4px;background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .15s}.dist-btn.active{background:var(--bg-card);color:var(--text);box-shadow:0 1px 2px #0000000f}.top-sellers-table{width:100%;border-collapse:collapse;font-size:13px}.top-sellers-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border);color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.top-sellers-table th.text-right{text-align:right}.top-sellers-table th.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.top-sellers-table th.sortable-header:hover{color:var(--text)}.top-sellers-table th.sort-active{color:var(--primary)}.top-sellers-table td{padding:8px 12px;border-bottom:1px solid var(--border)}.top-sellers-table td.text-right{text-align:right;font-family:SF Mono,Menlo,Monaco,monospace;font-size:12px}.top-sellers-table tr:last-child td{border-bottom:none}.top-sellers-rank{width:40px;color:var(--text-muted);font-weight:600}.top-sellers-sku{color:var(--text-muted);font-family:SF Mono,Menlo,Monaco,monospace;font-size:12px}.funnel-summary{display:flex;gap:24px;margin-bottom:16px;flex-wrap:wrap}.funnel-item{text-align:center}.funnel-value{font-size:24px;font-weight:700;color:var(--text)}.funnel-label{font-size:12px;color:var(--text-muted)}.funnel-arrow{display:flex;align-items:center;color:var(--text-muted);font-size:18px}.kpi-section-header{display:flex;align-items:center;gap:12px;margin:32px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--border);flex-wrap:wrap}.kpi-section-header h3{font-size:16px;font-weight:600;color:var(--text);margin:0}.kpi-section-hint{font-size:12px;color:var(--text-muted);font-style:italic}.kpi-section-filters{display:flex;align-items:center;gap:10px;margin-left:auto}.kpi-section-filters select{padding:5px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12px}.kpi-section-filters select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}@media(max-width:768px){.kpi-section-header{flex-wrap:wrap}.kpi-section-filters{margin-left:0;width:100%}}.kpi-chart-hint{font-size:11px;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);padding:2px 8px;border-radius:4px;font-weight:500}.snapshot-bars{padding:8px 0 16px}.snapshot-bar-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}.snapshot-bar-label{width:80px;font-size:13px;color:var(--text-muted);flex-shrink:0}.snapshot-bar-track{flex:1;height:20px;background:var(--bg);border-radius:4px;overflow:hidden}.snapshot-bar-fill{height:100%;border-radius:4px;min-width:2px;transition:width .3s ease}.snapshot-bar-success{background:var(--success)}.snapshot-bar-warning{background:var(--warning)}.snapshot-bar-muted{background:var(--text-muted);opacity:.4}.snapshot-bar-primary{background:#6366f1}.snapshot-bar-value{width:60px;text-align:right;font-size:13px;font-weight:600;color:var(--text);font-family:SF Mono,Menlo,Monaco,monospace}.snapshot-total{font-size:12px;color:var(--text-muted);text-align:right;padding-top:4px;border-top:1px solid var(--border);margin-top:4px}.snapshot-single{text-align:center;padding:16px 0}.snapshot-single-value{font-size:36px;font-weight:700;color:var(--text);line-height:1}.snapshot-single-label{font-size:13px;color:var(--text-muted);margin-top:8px}@media(max-width:900px){.kpi-charts-grid{grid-template-columns:1fr}.kpi-summary-row{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}.year-select{min-width:140px}.brand-select{min-width:240px;max-width:400px}.brand-select option:disabled{color:var(--text-muted);opacity:.5}.kpi-empty{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}.date-range-picker{display:inline-flex;align-items:center;gap:8px}.date-input{padding:6px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px}.date-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.date-sep{font-size:12px;color:var(--text-muted)}.compare-deployment-chips{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:20px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px}.compare-label{font-size:13px;color:var(--text-muted);font-weight:500;margin-right:4px}.compare-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:2px solid var(--border);border-radius:20px;background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .15s;font-weight:500}.compare-chip:hover{border-color:var(--text-muted);color:var(--text)}.compare-chip.active{background:var(--bg);font-weight:600}.compare-chip-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.compare-hint{font-size:11px;color:var(--text-muted);margin-left:4px}.dashboard-section-title{font-size:16px;font-weight:600;color:var(--text);margin:24px 0 12px;padding-bottom:8px;border-bottom:2px solid var(--border)}.system-usage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;margin-bottom:24px}.system-usage-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px;box-shadow:0 1px 2px #00000008}.system-usage-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.system-usage-name{font-size:15px;font-weight:600;color:var(--text)}.system-usage-env{font-size:11px;font-weight:600;text-transform:uppercase;background:var(--bg);border:1px solid var(--border);padding:2px 8px;border-radius:4px;color:var(--text-muted)}.system-usage-section{margin-bottom:16px}.system-usage-section:last-child{margin-bottom:0}.system-usage-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:10px}.usage-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.usage-bar-label{width:100px;font-size:12px;color:var(--text-muted);flex-shrink:0}.usage-bar-track{flex:1;height:16px;background:var(--bg);border-radius:4px;overflow:hidden}.usage-bar-fill{height:100%;border-radius:4px;min-width:2px;transition:width .3s ease}.usage-bar-primary{background:#6366f1}.usage-bar-storage{background:#10b981}.usage-snapshot-date{font-size:11px;color:var(--text-muted);margin-top:6px;text-align:right}.usage-bar-value{width:60px;text-align:right;font-size:13px;font-weight:600;color:var(--text);font-family:SF Mono,Menlo,Monaco,monospace;flex-shrink:0}.usage-stats-row{display:flex;gap:16px;flex-wrap:wrap}.usage-stat{display:flex;flex-direction:column;align-items:center;min-width:60px;flex:1}.usage-stat-value{font-size:16px;font-weight:700;color:var(--text);font-family:SF Mono,Menlo,Monaco,monospace;line-height:1.2}.usage-stat-label{font-size:11px;color:var(--text-muted);margin-top:2px}.usage-empty{font-size:13px;color:var(--text-muted);font-style:italic}.donut-chart-wrapper{display:flex;justify-content:center}.donut-chart-container{display:flex;align-items:center;gap:32px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:24px 32px;box-shadow:0 1px 2px #00000008}.donut-center-label{font-size:20px;font-weight:700;fill:var(--text)}.donut-center-sub{font-size:12px;fill:var(--text-muted)}.donut-legend{display:flex;flex-direction:column;gap:8px;min-width:180px}.donut-legend-item{display:flex;align-items:center;gap:8px;font-size:13px}.donut-legend-swatch{width:12px;height:12px;border-radius:3px;flex-shrink:0}.donut-legend-label{color:var(--text);flex:1}.donut-legend-value{font-weight:600;color:var(--text);font-family:SF Mono,Menlo,Monaco,monospace;font-size:12px}.disk-history-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px 24px;box-shadow:0 1px 2px #00000008;margin-bottom:24px}.disk-history-chart svg{display:block}.chart-axis-label{font-size:10px;fill:var(--text-muted);font-family:SF Mono,Menlo,Monaco,monospace}@media(max-width:768px){.system-usage-grid{grid-template-columns:1fr}.usage-stats-row{gap:12px}.usage-stat-value{font-size:14px}.donut-chart-container{flex-direction:column;gap:16px;padding:20px}.donut-legend{min-width:unset}}.log-filters{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.filter-group select,.filter-group input{padding:7px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.filter-search{flex:1;min-width:180px}.filter-search input{width:100%}.log-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.toolbar-label{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.page-size-select{padding:4px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:5px;color:var(--text);font-size:13px}.page-size-select:focus{outline:none;border-color:var(--primary)}.sortable-header{-webkit-user-select:none;user-select:none}.sortable-header:hover{color:var(--primary)}.log-perf{text-align:center}.perf-badge{font-size:14px}.perf-yes{color:var(--warning)}.perf-no{color:var(--text-muted);opacity:.4}.log-table{width:100%;border-collapse:collapse;font-size:13px}.log-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border);color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.log-table td{padding:8px 12px;border-bottom:1px solid var(--border);vertical-align:top}.log-row{cursor:pointer;transition:background .1s}.log-row:hover{background:var(--bg)}.log-row:last-child td{border-bottom:none}.log-row-error{background:#dc262608}.log-row-error:hover{background:#dc262612}.log-row-slow{background:#d9770608}.log-row-slow:hover{background:#d9770612}.log-ts{font-family:SF Mono,Menlo,Monaco,monospace;font-size:12px;white-space:nowrap;color:var(--text-muted)}.log-page{font-family:SF Mono,Menlo,Monaco,monospace;font-size:12px;color:var(--text)}.log-message{max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.log-time{font-family:SF Mono,Menlo,Monaco,monospace;font-size:12px;text-align:right}.time-slow{color:var(--warning);font-weight:600}.log-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;padding:8px 0}.pagination-info{font-size:13px;color:var(--text-muted)}.log-detail{max-width:1200px}.log-detail-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.log-detail-header .back-link{color:var(--text-muted);text-decoration:none;font-size:13px}.log-detail-header .back-link:hover{color:var(--primary)}.log-detail-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}.meta-item{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px 16px}.meta-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.meta-value{font-size:14px;color:var(--text);word-break:break-all}.meta-value.mono{font-family:SF Mono,Menlo,Monaco,monospace;font-size:13px}.log-message-full{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:20px}.log-message-full h3{font-size:14px;font-weight:600;margin-bottom:12px;color:var(--text-muted)}.log-message-full pre,.timed-message{font-family:SF Mono,Menlo,Monaco,monospace;font-size:13px;line-height:1.6;white-space:pre-wrap;word-break:break-all;margin:0;color:var(--text)}.timed-line{min-height:1.6em}.timed-prefix{color:var(--text-muted)}.timing-badge{display:inline;padding:1px 5px;border-radius:3px;font-weight:600;font-size:12px;color:#1a1a1a}.slow-queries-section{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px}.slow-queries-section h3{font-size:14px;font-weight:600;margin-bottom:12px;color:var(--text-muted)}.slow-query-item{padding:12px 0;border-bottom:1px solid var(--border)}.slow-query-item:last-child{border-bottom:none;padding-bottom:0}.slow-query-meta{display:flex;gap:16px;margin-bottom:6px;font-size:12px}.slow-query-meta span{color:var(--text-muted)}.slow-query-meta strong{color:var(--text);font-weight:500}.sql-block{font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:11px;line-height:1.6;white-space:pre-wrap;word-break:break-word;margin:0;padding:10px 12px;background:var(--bg, #f8f9fa);border-radius:6px;border:1px solid var(--border);color:var(--text);max-height:none;overflow-y:visible}.sql-keyword{color:#0550ae;font-weight:600}@media(prefers-color-scheme:dark){.sql-keyword{color:#79c0ff}}.security-summary{grid-template-columns:repeat(4,1fr)}.security-row.security-critical{border-left:3px solid var(--danger)}.security-row.security-high{border-left:3px solid #f59e0b}.security-row.security-medium{border-left:3px solid #3b82f6}.security-row.security-low{border-left:3px solid var(--border)}.security-row-open{background:#dc262605}.security-row-open:hover{background:#dc26260d}.security-desc{max-width:350px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.badge-critical{background:#dc262626;color:var(--danger);font-weight:700}.security-evidence-row{background:var(--bg)}.security-evidence-row td{padding:0!important;border-bottom:1px solid var(--border)}.security-evidence{padding:12px 16px}.evidence-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:6px;font-weight:600}.evidence-text{font-family:SF Mono,Menlo,Monaco,monospace;font-size:12px;line-height:1.5;background:var(--bg-card);padding:10px 14px;border-radius:6px;border:1px solid var(--border);white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto;margin:0}.evidence-meta{margin-top:8px;font-size:12px;color:var(--text-muted)}.security-breakdown h3{margin:0 0 12px}.rule-breakdown{display:flex;flex-direction:column;gap:4px}.rule-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}.rule-row:last-child{border-bottom:none}.rule-label{color:var(--text)}.rule-count{font-family:SF Mono,Menlo,Monaco,monospace;font-weight:600;color:var(--text-muted)}.rule-row-clickable{cursor:pointer;transition:background .15s;border-radius:4px;padding:6px 8px;margin:0 -8px}.rule-row-clickable:hover{background:var(--bg)}.security-table input[type=checkbox]{width:14px;height:14px;cursor:pointer}.pentest-banner{background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:8px;padding:12px 16px;margin-bottom:16px;font-size:13px;color:#6366f1}.perf-page{max-width:1400px}.perf-category-tabs{display:flex;gap:0;margin-bottom:16px;border-bottom:2px solid var(--border)}.perf-cat-btn{padding:10px 24px;border:none;background:none;font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s;display:flex;align-items:center;gap:8px}.perf-cat-btn:hover{color:var(--text)}.perf-cat-btn.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.perf-cat-count{font-size:11px;background:var(--bg-hover, rgba(0,0,0,.06));padding:2px 8px;border-radius:10px;font-weight:400}.perf-cat-btn.active .perf-cat-count{background:#3b82f61a;color:var(--primary)}.perf-summary{grid-template-columns:repeat(4,1fr);margin-bottom:12px}.perf-summary-3{grid-template-columns:repeat(3,1fr)}.perf-summary-general{grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto}.perf-mssql-card{grid-row:1 / 3;grid-column:3;display:flex;flex-direction:column;justify-content:center}.perf-timeline-card{margin-bottom:24px}.perf-hint{font-size:12px;color:var(--text-muted);font-style:italic}.perf-drilldown{background:var(--bg-card);border:2px solid var(--primary);border-radius:10px;padding:20px;margin-bottom:24px;box-shadow:0 4px 12px #00000014}.perf-drilldown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.perf-drilldown-header h3{font-size:16px;font-weight:600;color:var(--text);margin:0}.perf-drilldown-content{display:flex;flex-direction:column;gap:20px}.perf-drilldown-section h4{font-size:14px;font-weight:600;color:var(--text-muted);margin:0 0 12px}.perf-empty-section{color:var(--text-muted);font-size:13px;padding:12px 0}.perf-concurrency-box{background:#3b82f60a;border:1px solid rgba(59,130,246,.15);border-radius:8px;padding:16px}.perf-concurrency-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.perf-conc-stat{display:flex;flex-direction:column;gap:4px}.perf-conc-label{font-size:12px;color:var(--text-muted)}.perf-conc-value{font-size:20px;font-weight:600;color:var(--text);font-family:SF Mono,Menlo,Monaco,monospace}.perf-conc-value.warning{color:var(--warning)}.perf-conc-value.danger{color:var(--danger)}.perf-drill-table{font-size:12px}.perf-drill-table td{padding:6px 10px}.perf-log-link{color:var(--text);text-decoration:none;font-size:12px}.perf-log-link:hover{color:var(--primary);text-decoration:underline}.stat-card-link{text-decoration:none;color:inherit;cursor:pointer;transition:border-color .2s,box-shadow .2s}.stat-card-link:hover{border-color:var(--primary);box-shadow:0 2px 8px #3b82f626}.stat-card-link:hover .stat-label:after{content:" →"}.stat-card-clickable{cursor:pointer;transition:border-color .2s,box-shadow .2s}.stat-card-clickable:hover,.stat-card-active{border-color:var(--primary);box-shadow:0 2px 8px #3b82f626}.perf-drill-row{cursor:pointer}.perf-drill-row:hover td{background:var(--bg-hover, rgba(59, 130, 246, .06))}.perf-ranking-table td.text-right,.perf-ranking-table th.text-right{text-align:right}.perf-mono{font-family:SF Mono,Menlo,Monaco,monospace;font-size:12px}.perf-page-name{font-family:SF Mono,Menlo,Monaco,monospace;font-size:12px;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.perf-bottom-grid{margin-bottom:24px}.perf-critical{color:var(--danger);font-weight:600}.pfx-status{font-size:11px;font-weight:500;padding:2px 6px;border-radius:4px}.pfx-status-completed,.pfx-status-done,.pfx-status-success{background:#22c55e1a;color:#16a34a}.pfx-status-failed,.pfx-status-error,.pfx-status-faulted{background:#ef44441a;color:#dc2626}.pfx-status-rendering,.pfx-status-processing,.pfx-status-running{background:#3b82f61a;color:#2563eb}.pfx-status-queued,.pfx-status-waiting,.pfx-status-pending{background:#f59e0b1a;color:#d97706}@media(max-width:900px){.perf-summary,.perf-summary-3{grid-template-columns:repeat(2,1fr)}.perf-bottom-grid{grid-template-columns:1fr}.perf-concurrency-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.perf-concurrency-stats{grid-template-columns:1fr 1fr}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #f8f8f8;--bg-card: #ffffff;--bg-sidebar: #ffffff;--bg-input: #f3f4f6;--border: #e5e7eb;--text: #111827;--text-muted: #6b7280;--primary: #ff5151;--primary-hover: #e84444;--primary-light: rgba(255, 81, 81, .08);--danger: #dc2626;--warning: #d97706;--success: #16a34a;--accent: #ff5151}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--primary);text-decoration:none}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit}
