*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #0a0a0b;--color-surface: #141416;--color-surface-hover: #1c1c1f;--color-border: #2a2a2e;--color-text: #fafafa;--color-text-muted: #a1a1aa;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-error: #ef4444;--color-success: #22c55e;--radius: 8px;--font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, "SF Mono", Monaco, "Courier New", monospace}html,body{height:100%;font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}#app{height:100%;display:flex;flex-direction:column}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0}.header-title{font-size:1.25rem;font-weight:600;letter-spacing:-.025em}.header-actions{display:flex;align-items:center;gap:.75rem}.language-select-label{display:inline-flex;align-items:center;gap:.5rem;color:var(--color-text-muted);font-size:.875rem}.language-select{min-width:7rem;padding:.5rem .75rem;border-radius:var(--radius);border:1px solid var(--color-border);background-color:var(--color-surface-hover);color:var(--color-text)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:500;border-radius:var(--radius);border:none;cursor:pointer;transition:background-color .15s ease,transform .1s ease;white-space:nowrap}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--color-surface-hover);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background-color:var(--color-border)}.btn-secondary.is-active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-secondary.is-active:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-icon{padding:.625rem}.main-content{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.viewer-section{flex:1;position:relative;min-height:0;background-color:var(--color-bg)}.viewer-canvas{width:100%;height:100%;display:block}.viewer-overlay-controls{position:absolute;top:50%;right:1.5rem;display:flex;flex-direction:column;gap:.75rem;transform:translateY(-50%);z-index:6;pointer-events:auto}.viewer-overlay-controls .btn{width:3rem;height:3rem;padding:0;border-radius:999px;backdrop-filter:blur(10px);background-color:#141416ad}.viewer-overlay-controls .btn:hover:not(:disabled){background-color:#2a2a2eeb}.viewer-overlay-controls .btn svg{pointer-events:none}.loading-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#0a0a0be6;gap:1rem;z-index:10}.loading-overlay.hidden{display:none}.spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--color-text-muted);font-size:.875rem}.login-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;padding:2rem;text-align:center}.login-screen h2{font-size:1.5rem;font-weight:600}.login-screen p{color:var(--color-text-muted);max-width:400px}.model-info{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background-color:var(--color-surface);border-top:1px solid var(--color-border);flex-shrink:0;gap:1rem;flex-wrap:wrap}.model-details{display:flex;flex-direction:column;gap:.25rem;min-width:0}.model-title-row{display:flex;align-items:center;gap:.5rem;min-width:0}.model-title{min-width:0;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.model-favorite-toggle{flex-shrink:0;width:2rem;height:2rem;padding:0;border-radius:999px;background-color:transparent;color:var(--color-text-muted)}.model-favorite-toggle:hover:not(:disabled){background-color:#fafafa0f;color:var(--color-text)}.model-favorite-toggle.is-active{color:var(--color-primary)}.model-favorite-toggle.is-active:hover:not(:disabled){background-color:#3b82f614;color:var(--color-primary)}.model-favorite-toggle svg{pointer-events:none}.model-meta{display:flex;align-items:center;gap:.75rem;font-size:.8125rem;color:var(--color-text-muted);flex-wrap:wrap}.model-meta a{color:var(--color-primary);text-decoration:none}.model-meta a:hover{text-decoration:underline}.model-controls{display:flex;gap:.5rem;flex-shrink:0}.model-actions{display:flex;flex-direction:column;align-items:flex-end;gap:.75rem;flex-shrink:0}.practice-grade-control{position:relative;display:flex;flex-shrink:0}.practice-grade-button{min-width:6rem;width:100%}.practice-grade-panel{position:absolute;right:0;bottom:calc(100% + .75rem);display:flex;flex-direction:column;gap:.75rem;width:min(22rem,calc(100vw - 2rem));max-height:min(32rem,calc(100vh - 7rem));padding:1rem;border:1px solid var(--color-border);border-radius:14px;background:#141416f5;box-shadow:0 18px 48px #00000047;overflow:hidden;z-index:12}.practice-grade-panel[hidden]{display:none}.practice-grade-summary{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.practice-grade-label{color:var(--color-text-muted);font-size:.75rem;line-height:1.2}.practice-grade-score{font-family:var(--font-mono);font-size:1.25rem;font-weight:600;font-variant-numeric:tabular-nums}.practice-grade-file,.practice-grade-hint,.practice-grade-error{color:var(--color-text-muted);font-size:.8125rem;line-height:1.45}.practice-grade-error{color:#fda4af}.practice-grade-actions{display:flex;gap:.5rem;flex-wrap:wrap}.practice-grade-actions .btn{flex:1 1 0}.practice-grade-overlay{width:100%;height:auto;object-fit:contain;border-radius:10px;background:#090a0ce6;border:1px solid rgba(255,255,255,.08);image-rendering:pixelated}.practice-grade-history{display:flex;flex-direction:column;gap:.5rem;min-height:0}.practice-grade-history-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.practice-grade-history-label{color:var(--color-text-muted);font-size:.75rem;line-height:1.2}.practice-grade-history-count{color:#ffffffd1;font-family:var(--font-mono);font-size:.75rem;font-variant-numeric:tabular-nums}.practice-grade-history-list{display:flex;flex-direction:column;gap:.5rem;margin:0;padding:0 .25rem 0 0;list-style:none;max-height:min(13.5rem,calc(100vh - 20rem));overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable}.practice-grade-history-list:focus-visible{outline:1px solid rgba(255,255,255,.16);outline-offset:.25rem;border-radius:12px}.practice-grade-history-item{display:grid;grid-template-columns:auto minmax(0,1fr);gap:.125rem .625rem;align-items:start;padding:.625rem .75rem;border-radius:10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.practice-grade-history-score{grid-row:1 / span 2;font-family:var(--font-mono);font-size:.9375rem;font-weight:600;font-variant-numeric:tabular-nums;line-height:1.2;padding-top:.0625rem}.practice-grade-history-model,.practice-grade-history-file{color:var(--color-text-muted);font-size:.8125rem;line-height:1.35;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-timer-control{position:relative}.session-timer-toggle{min-width:8.75rem;justify-content:flex-start;text-align:left}.session-timer-toggle svg{flex-shrink:0}.session-timer-toggle-content{display:flex;flex-direction:column;align-items:flex-start;gap:.125rem;min-width:0}.session-timer-toggle-label{color:var(--color-text-muted);font-size:.75rem;line-height:1}.session-timer-toggle.is-active .session-timer-toggle-label{color:#ffffffd1}.session-timer-toggle-value,.session-timer-panel-value{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.session-timer-panel{position:absolute;right:0;bottom:calc(100% + .75rem);display:flex;flex-direction:column;gap:.875rem;width:min(20rem,calc(100vw - 2rem));padding:1rem;border:1px solid var(--color-border);border-radius:14px;background:#141416f5;box-shadow:0 18px 48px #00000047;z-index:12}.session-timer-panel[hidden],.session-timer-panel.hidden{display:none}.session-timer-panel-header{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem}.session-timer-status{color:var(--color-text-muted);font-size:.8125rem}.session-timer-panel-value{font-size:1.25rem;font-weight:600}.session-timer-presets{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.session-timer-preset{width:100%;padding:.5rem .75rem}.session-timer-warmup-field{display:flex;align-items:center;justify-content:space-between;gap:.75rem;color:var(--color-text-muted);font-size:.875rem}.session-timer-warmup-input-row{display:flex;align-items:center;gap:.5rem}.session-timer-warmup-input{width:4.5rem;padding:.5rem .625rem;border:1px solid var(--color-border);border-radius:var(--radius);background-color:var(--color-surface-hover);color:var(--color-text);font-family:var(--font-mono);font-variant-numeric:tabular-nums}.session-timer-actions{display:flex;gap:.5rem}.session-timer-actions .btn{flex:1}.saved-models-launcher{--saved-model-foreground: var(--color-text);display:flex;flex-direction:column;align-items:flex-start;gap:.75rem;position:absolute;left:1.5rem;bottom:1.5rem;z-index:5;max-width:calc(100% - 3rem);padding:0;background:transparent}.saved-models-toolbar{display:flex;gap:.75rem;pointer-events:auto}.saved-model-trigger{position:relative;width:3rem;height:3rem;padding:0;border-radius:999px;background-color:transparent;color:var(--saved-model-foreground)}.saved-model-trigger:hover:not(:disabled){background-color:#fafafa0f}.saved-model-trigger.is-active{background-color:transparent;color:var(--color-primary)}.saved-model-trigger.is-active:hover:not(:disabled){background-color:#3b82f614}.saved-model-trigger-count{position:absolute;right:-.15rem;bottom:-.15rem;min-width:1.25rem;padding:.125rem .3rem;border-radius:999px;background-color:transparent;border:1px solid currentColor;font-size:.6875rem;line-height:1}.saved-models-panel{display:block;max-width:min(32rem,calc(100vw - 3rem));padding:1rem;border:1px solid var(--color-border);border-radius:14px;background:#141416eb;box-shadow:0 20px 50px #00000047;pointer-events:auto}.saved-models-group{min-width:0}.saved-models-heading{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;color:var(--color-text-muted)}.saved-models-heading h2{font-size:.875rem;font-weight:600;color:var(--color-text)}.saved-models-heading span{font-size:.75rem}.saved-models-list{display:flex;flex-wrap:wrap;gap:.5rem}.saved-models-empty{color:var(--color-text-muted);font-size:.8125rem}.saved-model-card{display:inline-flex;flex-direction:column;align-items:flex-start;gap:.125rem;min-width:0;max-width:100%;padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);background-color:var(--color-surface-hover);color:var(--color-text);cursor:pointer;transition:background-color .15s ease,border-color .15s ease,transform .1s ease}.saved-model-card:hover{background-color:#202026;border-color:#3b3b44}.saved-model-card:active{transform:scale(.98)}.saved-model-card.is-current{border-color:var(--color-primary)}.saved-model-card-title{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.8125rem;font-weight:600}.saved-model-card-meta{color:var(--color-text-muted);font-size:.75rem}.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;text-align:center;color:var(--color-error)}.error-message p{max-width:400px}.user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background-color:var(--color-surface-hover);border-radius:var(--radius);font-size:.875rem}.user-avatar{width:28px;height:28px;border-radius:50%;background-color:var(--color-border)}.callback-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:1rem;padding:2rem;text-align:center;color:var(--color-text-muted)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:100;display:flex;flex-direction:column;gap:.5rem}.toast{padding:.875rem 1rem;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);font-size:.875rem;box-shadow:0 4px 12px #0000004d;animation:slideIn .2s ease}.toast.error{border-color:var(--color-error)}.toast.success{border-color:var(--color-success)}@keyframes slideIn{0%{opacity:0;transform:translate(1rem)}to{opacity:1;transform:translate(0)}}@media(max-width:640px){.header{padding:.875rem 1rem}.header-title{font-size:1rem}.model-info{padding:.875rem 1rem}.model-controls{width:100%}.model-actions{width:100%;align-items:stretch}.model-controls .btn,.session-timer-control,.practice-grade-control{flex:1}.practice-grade-panel{left:0;right:auto;width:min(calc(100vw - 2rem),22rem)}.session-timer-panel{left:0;right:auto;width:min(100%,20rem)}.saved-models-launcher{left:1rem;right:1rem;bottom:1rem;max-width:none}.viewer-overlay-controls{right:1rem}}
