@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap";
:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-tertiary:#1a1a24;--accent-primary:#00d4aa;--accent-secondary:#00b894;--accent-glow:#00d4aa4d;--text-primary:#e8e8ed;--text-secondary:#9090a0;--text-muted:#606070;--border-color:#2a2a3a;--error-color:#ff4757;--warning-color:#ffa502;--success-color:#2ed573;--mask-fill:#00d4aa59;--mask-stroke:#0fc}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);background-image:radial-gradient(at 20% 0,#00d4aa14 0%,#0000 50%),radial-gradient(at 80% 100%,#00b8940f 0%,#0000 50%);min-height:100vh;font-family:Space Grotesk,sans-serif}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-container{flex-direction:column;gap:1.5rem;max-width:1600px;margin:0 auto;padding:1.5rem 2rem;display:flex}.header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-bottom:1rem;display:flex}.header h1{letter-spacing:-.02em;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700}.header-status{align-items:center;gap:.75rem;display:flex}.status-pill{border-radius:20px;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;display:flex}.status-pill.ready{color:var(--success-color);background:#2ed57326}.status-pill.processing{color:var(--warning-color);background:#ffa50226}.status-pill.error{color:var(--error-color);background:#ff475726}.cost-pill{color:var(--accent-primary);background:#00d4aa26;border-radius:20px;padding:.375rem .75rem;font-family:JetBrains Mono,monospace;font-size:.75rem}.main-layout{align-items:flex-start;gap:1.5rem;display:flex}.content-area{flex:1;min-width:0}@media (max-width:600px){.main-layout{flex-direction:column}.sidebar{width:100%;min-width:auto}}.upload-section{background:var(--bg-secondary);border:2px dashed var(--border-color);text-align:center;cursor:pointer;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;min-height:300px;padding:2.5rem 2rem;transition:all .3s;display:flex}.upload-section:hover,.upload-section.dragover{border-color:var(--accent-primary);background:var(--bg-tertiary);box-shadow:0 0 30px var(--accent-glow)}.upload-section input[type=file]{display:none}.upload-icon{opacity:.6;width:64px;height:64px;margin:0 auto 1rem}.upload-section h3{margin-bottom:.5rem;font-size:1.1rem}.upload-section span{color:var(--text-muted);font-size:.85rem}.canvas-container{background:var(--bg-secondary);border-radius:16px;max-width:100%;display:inline-block;position:relative;overflow:hidden;box-shadow:0 4px 24px #0000004d}.canvas-container img{vertical-align:bottom;max-width:100%;height:auto;display:block}.canvas-container canvas{cursor:crosshair;pointer-events:auto;position:absolute;top:0;left:0}.canvas-loading{color:var(--accent-primary);background:#000000d9;border-radius:8px;align-items:center;gap:.75rem;padding:1rem 2rem;font-family:JetBrains Mono,monospace;font-size:.85rem;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.spinner{border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.sidebar{flex-direction:column;gap:.75rem;width:300px;min-width:300px;max-height:calc(100vh - 8rem);display:flex;position:sticky;top:1rem;overflow-y:auto}.sidebar-tabs{background:var(--bg-secondary);border-radius:8px;gap:.25rem;padding:.25rem;display:flex}.sidebar-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:.625rem 1rem;font-family:Space Grotesk,sans-serif;font-size:.85rem;font-weight:600;transition:all .2s}.sidebar-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.sidebar-tab.active{background:var(--accent-primary);color:var(--bg-primary)}.action-buttons{flex-direction:column;gap:.5rem;display:flex}.btn-action{padding:1rem 1.25rem;font-size:.95rem}.btn-action .btn-icon{font-size:1.1rem}.btn-benchmark{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)!important}.action-row{gap:.5rem;display:flex}.action-row .btn{flex:1}.panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem}.panel-compact{border-radius:10px;padding:.875rem}.panel-header{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:600;display:flex}.panel-header:before{content:"";background:var(--accent-primary);border-radius:2px;width:8px;height:8px;display:inline-block}.panel-header-compact{color:var(--text-secondary);align-items:center;gap:.5rem;margin-bottom:0;font-size:.8rem;font-weight:600;display:flex}.panel-header-compact.clickable{cursor:pointer;border-radius:4px;margin:-.25rem 0;padding:.25rem 0;transition:color .2s}.panel-header-compact.clickable:hover{color:var(--text-primary)}.panel-header-compact .collapse-icon{color:var(--text-muted);margin-left:auto;font-size:.9rem}.header-badge{color:var(--accent-primary);background:#00d4aa26;border-radius:4px;padding:.125rem .375rem;font-family:JetBrains Mono,monospace;font-size:.7rem}.controls{flex-direction:column;gap:.75rem;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.875rem 1.25rem;font-family:Space Grotesk,sans-serif;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--bg-primary)}.btn-primary:hover:not(:disabled){box-shadow:0 8px 20px var(--accent-glow);transform:translateY(-2px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){border-color:var(--accent-primary);background:var(--bg-primary)}.btn:disabled{opacity:.4;cursor:not-allowed}.debug-grid{gap:.75rem;display:grid}.debug-item{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.debug-item:last-child{border-bottom:none}.debug-label{color:var(--text-secondary);font-size:.8rem}.debug-value{color:var(--accent-primary);font-family:JetBrains Mono,monospace;font-size:.8rem}.debug-value.error{color:var(--error-color)}.debug-value.success{color:var(--success-color)}.gpu-stats-content{flex-direction:column;gap:.625rem;display:flex}.gpu-device-name{color:var(--text-muted);background:var(--bg-tertiary);text-align:center;border-radius:4px;margin-bottom:.25rem;padding:.375rem .5rem;font-family:JetBrains Mono,monospace;font-size:.75rem}.gpu-stat-row{justify-content:space-between;align-items:center;padding:.25rem 0;display:flex}.gpu-stat-label{color:var(--text-secondary);font-size:.8rem}.gpu-stat-value{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:.8rem}.gpu-stat-value.cost-value{color:var(--accent-primary);font-weight:600}.gpu-memory-bar{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;height:20px;position:relative;overflow:hidden}.gpu-memory-fill{background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:9px;height:100%;transition:width .3s}.gpu-memory-pct{color:var(--text-primary);text-shadow:0 0 4px #000c;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:600;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.gpu-stat-row.total-row{border-top:1px solid var(--border-color);margin-top:.5rem;padding-top:.625rem}.gpu-stats-empty{color:var(--text-muted);text-align:center;padding:1rem;font-size:.8rem;font-style:italic}.panel-badge{color:var(--accent-primary);background:#00d4aa26;border-radius:4px;margin-left:auto;padding:.2rem .5rem;font-family:JetBrains Mono,monospace;font-size:.7rem}.endpoint-selector{flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.endpoint-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:.625rem .875rem;transition:all .2s;display:flex}.endpoint-btn:hover{background:var(--bg-secondary);border-color:var(--accent-primary)}.endpoint-btn.active{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow);background:#00d4aa26}.endpoint-name{color:var(--text-primary);font-size:.85rem;font-weight:500}.endpoint-btn.active .endpoint-name{color:var(--accent-primary)}.endpoint-rate{color:var(--text-muted);background:var(--bg-primary);border-radius:4px;padding:.2rem .5rem;font-family:JetBrains Mono,monospace;font-size:.75rem}.endpoint-btn.active .endpoint-rate{color:var(--accent-primary);background:#00d4aa1a}.endpoint-status{color:var(--text-muted);text-align:center;border-top:1px solid var(--border-color);padding:.5rem .75rem;font-size:.75rem}.endpoint-used{color:var(--accent-primary);font-weight:500}.error-message{border:1px solid var(--error-color);color:var(--error-color);word-break:break-word;background:#ff47571a;border-radius:8px;padding:.875rem;font-family:JetBrains Mono,monospace;font-size:.85rem}.result-section{margin-top:1.5rem}.result-preview{background:var(--bg-tertiary);border-radius:8px;margin-bottom:1rem;overflow:hidden}.result-preview img{width:100%;height:auto;display:block}.result-json{background:var(--bg-primary);border:1px solid var(--border-color);white-space:pre-wrap;word-break:break-word;border-radius:8px;max-height:300px;padding:1rem;font-family:JetBrains Mono,monospace;font-size:.75rem;line-height:1.5;overflow-y:auto}.status-indicator{border-radius:20px;align-items:center;gap:.5rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;display:inline-flex}.status-indicator.ready{color:var(--success-color);background:#2ed57326}.status-indicator.processing{color:var(--warning-color);background:#ffa50226}.status-indicator.error{color:var(--error-color);background:#ff475726}.status-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.instructions{color:var(--text-secondary);background:var(--bg-tertiary);border-left:3px solid var(--accent-primary);border-radius:8px;padding:1rem;font-size:.85rem;line-height:1.6}.instructions strong{color:var(--text-primary)}.instructions-compact{color:var(--text-secondary);text-align:center;background:var(--bg-tertiary);border-radius:8px;margin-top:.75rem;padding:.75rem 1rem;font-size:.8rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.4s ease-out fadeIn}.benchmark-table{border-collapse:collapse;width:100%;margin-bottom:1rem;font-size:.85rem}.benchmark-table th,.benchmark-table td{text-align:left;border-bottom:1px solid var(--border-color);padding:.75rem 1rem}.benchmark-table th{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-tertiary);font-size:.7rem;font-weight:600}.benchmark-table tr{transition:background .2s}.benchmark-table tr:hover{background:var(--bg-tertiary)}.benchmark-table tr.selected{border-left:3px solid var(--accent-primary);background:#00d4aa1a}.benchmark-table tr.pending{opacity:.7;background:#ffa5020d}.benchmark-table tr.pending td{color:var(--text-muted)}.benchmark-table .rank{text-align:center;width:50px;font-size:1.1rem}.benchmark-table .model-name{color:var(--text-primary);font-weight:600}.benchmark-table .provider-badge{text-transform:uppercase;border-radius:4px;padding:.25rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.benchmark-table .provider-badge.google{color:#4285f4;background:#4285f433}.benchmark-table .status-success{color:var(--success-color);font-weight:500}.benchmark-table .status-error{color:var(--error-color);cursor:help;font-weight:500}.benchmark-table .latency-value{color:var(--accent-primary);font-family:JetBrains Mono,monospace;font-weight:600}.benchmark-table .btn-sm{background:var(--bg-tertiary);border:1px solid var(--border-color);padding:.375rem .75rem;font-size:.75rem}.benchmark-table .btn-sm:hover{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}.benchmark-detail{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;margin-top:1rem;padding:1rem}.benchmark-detail .detail-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.benchmark-detail .detail-header h4{color:var(--text-primary);font-size:.9rem;font-weight:600}.benchmark-detail .latency-badge{color:var(--accent-primary);background:#00d4aa33;border-radius:4px;padding:.25rem .5rem;font-family:JetBrains Mono,monospace;font-size:.75rem}.benchmark-detail .detail-content{align-items:flex-start;gap:1rem;display:flex}@media (max-width:768px){.benchmark-detail .detail-content{flex-direction:column}.benchmark-detail .result-preview{max-width:100%!important}}.benchmark-loading{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:2rem;display:flex}.benchmark-loading .spinner{width:32px;height:32px}.benchmark-loading p{color:var(--text-secondary);font-size:.9rem}.google-gradient{background:linear-gradient(135deg,#4285f4 0%,#34a853 50%,#fbbc05 75%,#ea4335 100%)}.panel-header.clickable{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between}.panel-header.clickable:hover{color:var(--text-primary)}.collapse-icon{color:var(--text-muted);font-size:1rem;font-weight:700;transition:color .2s}.panel-header.clickable:hover .collapse-icon{color:var(--accent-primary)}.settings-content{flex-direction:column;gap:1.25rem;display:flex}.setting-item{flex-direction:column;gap:.5rem;display:flex}.setting-label{color:var(--text-primary);justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.setting-value{color:var(--accent-primary);background:var(--bg-tertiary);border-radius:4px;padding:.125rem .5rem;font-family:JetBrains Mono,monospace;font-size:.8rem}.setting-hint{color:var(--text-muted);font-size:.7rem;font-style:italic}.slider{appearance:none;background:var(--bg-tertiary);cursor:pointer;border-radius:3px;outline:none;width:100%;height:6px}.slider::-webkit-slider-thumb{appearance:none;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));cursor:pointer;width:18px;height:18px;box-shadow:0 2px 8px var(--accent-glow);border-radius:50%;transition:transform .2s,box-shadow .2s}.slider::-webkit-slider-thumb:hover{box-shadow:0 4px 12px var(--accent-glow);transform:scale(1.1)}.slider::-moz-range-thumb{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));cursor:pointer;width:18px;height:18px;box-shadow:0 2px 8px var(--accent-glow);border:none;border-radius:50%}.toggle-switch{width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:24px;transition:background-color .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:var(--text-muted);border-radius:50%;width:18px;height:18px;transition:transform .3s,background-color .3s;position:absolute;bottom:2px;left:2px}.toggle-switch input:checked+.toggle-slider{border-color:var(--accent-primary);background-color:#00d4aa4d}.toggle-switch input:checked+.toggle-slider:before{background-color:var(--accent-primary);transform:translate(20px)}.select-dropdown{background:var(--bg-tertiary);border:1px solid var(--border-color);width:100%;color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239090a0' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;border-radius:8px;outline:none;padding:.625rem 2.5rem .625rem 1rem;font-family:Space Grotesk,sans-serif;font-size:.85rem;transition:border-color .2s,box-shadow .2s}.select-dropdown:hover:not(:disabled){border-color:var(--accent-primary)}.select-dropdown:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.select-dropdown:disabled{opacity:.5;cursor:not-allowed}.select-dropdown option{background:var(--bg-secondary);color:var(--text-primary);padding:.5rem}.btn-sm{padding:.5rem .875rem;font-size:.8rem}.profiles-section{border-top:1px solid var(--border-color);margin-top:1rem;padding-top:1rem}.profiles-grid{grid-template-columns:repeat(2,1fr);gap:.5rem;display:grid}.profile-item{gap:.25rem;display:flex}.profile-btn{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;border-radius:6px;flex:1;padding:.4rem .5rem;font-size:.75rem;transition:all .2s;overflow:hidden}.profile-btn:hover{background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--text-primary)}.profile-delete{background:var(--bg-tertiary);color:var(--error-color);border:1px solid var(--border-color);cursor:pointer;border-radius:6px;padding:.4rem .5rem;font-size:.8rem;line-height:1;transition:all .2s}.profile-delete:hover{border-color:var(--error-color);background:#f663}.save-profile-dialog{flex-direction:column;gap:.5rem;margin-top:.5rem;display:flex}.profile-name-input{background:var(--bg-tertiary);border:1px solid var(--accent-primary);width:100%;color:var(--text-primary);border-radius:6px;outline:none;padding:.5rem .75rem;font-family:Space Grotesk,sans-serif;font-size:.85rem}.profile-name-input:focus{box-shadow:0 0 0 3px var(--accent-glow)}.save-dialog-buttons{gap:.5rem;display:flex}.save-dialog-buttons .btn{flex:1}.click-mode-content{flex-direction:column;gap:1rem;display:flex}.radio-group{flex-direction:column;gap:.5rem;display:flex}.radio-label{cursor:pointer;border-radius:8px;align-items:center;gap:.75rem;padding:.5rem .75rem;transition:background .2s;display:flex}.radio-label:hover{background:var(--bg-tertiary)}.radio-label input[type=radio]{appearance:none;border:2px solid var(--border-color);cursor:pointer;border-radius:50%;width:18px;height:18px;transition:border-color .2s;position:relative}.radio-label input[type=radio]:checked{border-color:var(--accent-primary)}.radio-label input[type=radio]:checked:before{content:"";background:var(--accent-primary);border-radius:50%;width:8px;height:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.radio-label span{color:var(--text-primary);font-size:.9rem}.points-list{background:var(--bg-tertiary);border-radius:8px;padding:.75rem}.points-header{border-bottom:1px solid var(--border-color);color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;font-size:.8rem;display:flex}.points-items{flex-direction:column;gap:.375rem;max-height:150px;display:flex;overflow-y:auto}.point-item{background:var(--bg-secondary);border-left:3px solid #0000;border-radius:6px;align-items:center;gap:.5rem;padding:.375rem .5rem;font-family:JetBrains Mono,monospace;font-size:.75rem;display:flex}.point-item.positive{border-left-color:#22c55e}.point-item.negative{border-left-color:#ef4444}.point-number{color:var(--text-muted);min-width:20px}.point-coords{color:var(--text-primary);flex:1}.point-type{font-size:.9rem;font-weight:700}.point-item.positive .point-type{color:#22c55e}.point-item.negative .point-type{color:#ef4444}.points-empty{color:var(--text-muted);text-align:center;padding:.5rem;font-size:.75rem;line-height:1.5}.quick-toggle{justify-content:space-between;align-items:center;gap:1rem;display:flex}.quick-label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.toggle-buttons{background:var(--bg-tertiary);border-radius:6px;padding:.125rem;display:flex}.toggle-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.375rem .75rem;font-family:Space Grotesk,sans-serif;font-size:.75rem;font-weight:600;transition:all .2s}.toggle-btn:hover{color:var(--text-secondary)}.toggle-btn.active{background:var(--accent-primary);color:var(--bg-primary)}.points-summary{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.75rem;display:flex}.points-count{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:.8rem}.btn-link{color:var(--accent-primary);cursor:pointer;background:0 0;border:none;padding:0;font-family:Space Grotesk,sans-serif;font-size:.75rem;text-decoration:none}.btn-link:hover{text-decoration:underline}.btn-link-small{color:var(--accent-primary);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0;font-family:Space Grotesk,sans-serif;font-size:.7rem}.btn-link-small:hover{text-decoration:underline}.settings-content-compact{border-top:1px solid var(--border-color);flex-direction:column;gap:.75rem;margin-top:.75rem;padding-top:.75rem;display:flex}.setting-row{grid-template-columns:70px 45px 1fr;align-items:center;gap:.5rem;display:grid}.setting-name{color:var(--text-secondary);font-size:.75rem}.setting-val{color:var(--accent-primary);text-align:right;font-family:JetBrains Mono,monospace;font-size:.7rem}.slider-compact{appearance:none;background:var(--bg-tertiary);cursor:pointer;border-radius:2px;outline:none;width:100%;height:4px}.slider-compact::-webkit-slider-thumb{appearance:none;background:var(--accent-primary);cursor:pointer;border-radius:50%;width:14px;height:14px}.slider-compact::-moz-range-thumb{background:var(--accent-primary);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.setting-row-inline{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.checkbox-label{color:var(--text-secondary);cursor:pointer;align-items:center;gap:.5rem;font-size:.75rem;display:flex}.checkbox-label input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent-primary)}.select-compact{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;border-radius:4px;outline:none;padding:.375rem .5rem;font-family:Space Grotesk,sans-serif;font-size:.75rem}.select-compact:disabled{opacity:.5;cursor:not-allowed}.profiles-compact{flex-wrap:wrap;gap:.375rem;display:flex}.profile-chip{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:12px;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.7rem;transition:all .2s;display:inline-flex}.profile-chip:hover{border-color:var(--accent-primary);color:var(--text-primary)}.profile-chip-delete{color:var(--text-muted);font-size:.8rem;line-height:1}.profile-chip-delete:hover{color:var(--error-color)}.setting-actions{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:.5rem;padding-top:.5rem;display:flex}.save-inline{flex:1;gap:.375rem;display:flex}.input-compact{background:var(--bg-tertiary);border:1px solid var(--accent-primary);color:var(--text-primary);border-radius:4px;outline:none;flex:1;padding:.375rem .5rem;font-family:Space Grotesk,sans-serif;font-size:.75rem}.btn-icon-only{background:var(--bg-tertiary);border:1px solid var(--border-color);width:24px;height:24px;color:var(--text-secondary);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;font-size:.8rem;transition:all .2s;display:flex}.btn-icon-only:hover{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}.btn-icon-only:disabled{opacity:.5;cursor:not-allowed}.status-summary{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;justify-content:space-around;padding:.75rem;display:flex}.status-item{color:var(--text-muted);align-items:center;gap:.375rem;font-size:.75rem;display:flex}.status-item.active{color:var(--success-color)}.status-icon{font-size:.7rem}.debug-compact{border-top:1px solid var(--border-color);flex-direction:column;gap:.375rem;margin-top:.75rem;padding-top:.75rem;display:flex}.debug-row{justify-content:space-between;align-items:center;font-size:.75rem;display:flex}.debug-row span{color:var(--text-muted)}.debug-row code{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:.7rem}.debug-row code.highlight{color:var(--accent-primary)}.gpu-compact{border-top:1px solid var(--border-color);margin-top:.75rem;padding-top:.75rem}.gpu-device{color:var(--text-muted);text-align:center;margin-bottom:.5rem;font-family:JetBrains Mono,monospace;font-size:.65rem}.gpu-bar-container{margin-bottom:.75rem}.gpu-bar{background:var(--bg-tertiary);border-radius:3px;height:6px;margin-bottom:.25rem;overflow:hidden}.gpu-bar-fill{background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:3px;height:100%;transition:width .3s}.gpu-bar-label{color:var(--text-muted);font-size:.65rem}.cost-grid{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.cost-item{background:var(--bg-tertiary);border-radius:4px;flex-direction:column;gap:.125rem;padding:.375rem;display:flex}.cost-item span{color:var(--text-muted);font-size:.65rem}.cost-item strong{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:.7rem}.cost-item.total{background:#00d4aa1a}.cost-item.total strong{color:var(--accent-primary)}.empty-state{color:var(--text-muted);text-align:center;padding:1rem;font-size:.75rem;font-style:italic}.points-list-compact{flex-wrap:wrap;gap:.375rem;margin-top:.5rem;display:flex}.point-chip{background:var(--bg-tertiary);color:var(--text-secondary);border-left:2px solid #0000;border-radius:4px;align-items:center;gap:.375rem;padding:.25rem .5rem;font-family:JetBrains Mono,monospace;font-size:.65rem;display:inline-flex}.point-chip.positive{border-left-color:#22c55e}.point-chip.negative{border-left-color:#ef4444}.point-sign{font-weight:700}.point-chip.positive .point-sign{color:#22c55e}.point-chip.negative .point-sign{color:#ef4444}@media (max-width:768px){.app-container{padding:1rem}.header{text-align:center;flex-direction:column;gap:.75rem}.header h1{font-size:1.25rem}.main-layout{gap:1rem}.sidebar{max-height:none;position:static}.panel{padding:1rem}.setting-label{font-size:.8rem}.slider::-webkit-slider-thumb{width:22px;height:22px}.toggle-switch{width:50px;height:28px}.toggle-slider:before{width:22px;height:22px}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}}@supports (padding:max(0px)){body{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right));padding-bottom:max(0px,env(safe-area-inset-bottom))}}button,a,.btn,input[type=button],input[type=submit],[role=button]{min-width:44px;min-height:44px}button:active,.btn:active,a:active{transform:scale(.98)}button,.btn{-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth}body{overscroll-behavior-y:none}@media (prefers-contrast:high){:root{--border-color:#4a4a5a}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media print{body{color:#000;background:#fff}.btn,button,.sidebar,.header-status{display:none!important}}.admin-layout{background:var(--bg-primary);min-height:100vh;display:flex}.admin-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:100;flex-direction:column;width:260px;height:100vh;display:flex;position:fixed;top:0;left:0}.admin-sidebar .sidebar-header{border-bottom:1px solid var(--border-color);padding:1.5rem}.admin-sidebar .sidebar-logo{align-items:center;gap:.75rem;text-decoration:none;display:flex}.admin-sidebar .logo-icon{font-size:1.5rem}.admin-sidebar .logo-text{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.1rem;font-weight:700}.admin-sidebar .sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:1rem 0;display:flex;overflow-y:auto}.admin-sidebar .sidebar-footer{border-top:1px solid var(--border-color);padding:1rem}.admin-sidebar .nav-item{color:var(--text-secondary);align-items:center;gap:.75rem;padding:.75rem 1.5rem;font-size:.9rem;text-decoration:none;transition:all .2s;display:flex}.admin-sidebar .nav-item:hover{color:var(--text-primary);background:#00d4aa1a}.admin-sidebar .nav-item.active{color:var(--accent-primary);border-right:3px solid var(--accent-primary);background:#00d4aa26}.admin-sidebar .nav-item svg{stroke:currentColor;flex-shrink:0;width:20px;height:20px}.admin-sidebar .nav-item span{flex:1}.admin-sidebar .back-link{color:var(--text-muted);font-size:.85rem}.admin-main{background:var(--bg-primary);flex:1;min-height:100vh;margin-left:260px}@media (max-width:768px){.admin-sidebar{width:100%;height:auto;position:relative}.admin-main{margin-left:0}.admin-layout{flex-direction:column}}.admin-dashboard{max-width:1400px;padding:2rem}.admin-dashboard .dashboard-header{margin-bottom:2rem}.admin-dashboard .dashboard-header h1{color:var(--text-primary);margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.admin-dashboard .dashboard-header p{color:var(--text-secondary);margin:0;font-size:.95rem}.admin-dashboard .dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.admin-dashboard .stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;align-items:center;gap:1rem;padding:1.5rem;display:flex}.admin-dashboard .stat-icon{border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.admin-dashboard .stat-icon svg{stroke:currentColor;width:28px;height:28px}.admin-dashboard .stat-icon.scans{color:var(--accent-primary);background:#00d4aa26}.admin-dashboard .stat-icon.confidence{color:var(--success-color);background:#22c55e26}.admin-dashboard .stat-icon.plants{color:#3b82f6;background:#3b82f626}.admin-dashboard .stat-icon.escalated{color:var(--warning-color);background:#f59e0b26}.admin-dashboard .stat-content{flex-direction:column;gap:.25rem;display:flex}.admin-dashboard .stat-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.admin-dashboard .stat-label{color:var(--text-secondary);font-size:.85rem}.admin-dashboard .dashboard-info{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.admin-dashboard .info-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.admin-dashboard .info-card h2{color:var(--text-primary);border-bottom:1px solid var(--border-color);margin:0 0 1rem;padding-bottom:.75rem;font-size:1rem;font-weight:600}.admin-dashboard .info-card ul{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.admin-dashboard .info-card li{color:var(--text-secondary);font-size:.9rem}.admin-dashboard .info-card li strong{color:var(--text-primary)}.admin-dashboard .status-list{flex-direction:column;gap:.75rem;display:flex}.admin-dashboard .status-item{color:var(--text-secondary);align-items:center;gap:.75rem;font-size:.9rem;display:flex}.admin-dashboard .status-dot{border-radius:50%;width:8px;height:8px}.admin-dashboard .status-dot.online{background:var(--success-color);box-shadow:0 0 8px #22c55e80}.admin-dashboard .status-dot.offline{background:var(--error-color)}@media (max-width:768px){.admin-dashboard{padding:1rem}.admin-dashboard .dashboard-header h1{font-size:1.5rem}}
