.color-palette{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.palette-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.palette-colors{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.color-button{width:48px;height:48px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);position:relative;display:flex;align-items:center;justify-content:center;padding:0}.color-button:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.color-button.selected{transform:scale(1.15);box-shadow:0 0 0 3px var(--accent)}.checkmark{color:#000;font-size:24px;font-weight:700;text-shadow:0 0 4px #fff}.palette-info{text-align:center;font-size:14px;color:var(--accent);font-weight:600;min-height:20px}.shape-selector{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.selector-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.selector-shapes{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.shape-button{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-sm);min-width:64px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.shape-button:hover{border-color:var(--accent);transform:translateY(-2px)}.shape-button.selected{border-color:var(--accent);background:#00ffff1a;box-shadow:0 0 10px #00ffff4d}.shape-icon{font-size:24px;line-height:1}.shape-label{font-size:11px;color:var(--text-secondary)}.shape-button.selected .shape-label{color:var(--accent);font-weight:600}.selector-info{text-align:center;font-size:14px;color:var(--accent);font-weight:600;min-height:20px}.controls{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.control-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.control-label{font-size:13px;color:var(--text-secondary);font-weight:500}.control-slider{width:100%}.control-buttons{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:var(--spacing-sm)}.control-buttons button{flex:1;min-width:100px;padding:var(--spacing-sm) var(--spacing-md);font-size:14px;font-weight:500}.control-buttons button.danger{background:#f003;border-color:#ff000080}.control-buttons button.danger:hover{background:#ff00004d;border-color:#f00c}.control-buttons button.accent{background:#0ff3;border-color:var(--accent);color:var(--accent);font-weight:600}.control-buttons button.accent:hover{background:#00ffff4d;box-shadow:0 0 10px #00ffff4d}.recording-panel{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.panel-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.recording-controls{display:flex;gap:var(--spacing-sm)}.record-button{flex:1;background:#f003;border-color:#ff000080;color:#f44;font-weight:600;padding:var(--spacing-md)}.record-button:hover{background:#ff00004d;border-color:#f00c}.stop-button{flex:1;background:#ffa50033;border-color:#ffa50080;color:#fa4;font-weight:600;padding:var(--spacing-md)}.stop-button:hover{background:#ffa5004d;border-color:#ffa500cc}.recording-indicator{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:#ff00001a;border-radius:var(--radius-sm);color:#f44;font-weight:600;font-size:13px}.recording-dot{width:12px;height:12px;background:#f44;border-radius:50%;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.recordings-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:300px;overflow-y:auto}.list-header{font-size:12px;color:var(--text-secondary);font-weight:600;margin-bottom:var(--spacing-xs)}.recording-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;transition:all var(--transition-fast)}.recording-item:hover{border-color:var(--accent)}.recording-item.expanded{border-color:var(--accent);box-shadow:0 0 10px #0ff3}.recording-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;-webkit-user-select:none;user-select:none}.recording-name{font-size:14px;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recording-duration{font-size:12px;color:var(--text-secondary);font-family:Courier New,monospace}.recording-info{padding:0 var(--spacing-md) var(--spacing-sm);font-size:11px;color:var(--text-secondary)}.recording-actions{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--border-color)}.action-button{flex:1;padding:var(--spacing-sm);font-size:12px;font-weight:500}.action-button.play{background:#00ff001a;border-color:#00ff004d;color:#4f4}.action-button.play:hover{background:#0f03;border-color:#00ff0080}.action-button.download{background:#0096ff1a;border-color:#0096ff4d;color:#49f}.action-button.download:hover{background:#0096ff33;border-color:#0096ff80}.empty-state{padding:var(--spacing-lg);text-align:center;color:var(--text-secondary);font-size:13px}.puzzle-mode{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);height:100%;overflow-y:auto}.puzzle-header{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.puzzle-info{flex:1}.puzzle-title-row{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.puzzle-title{font-size:24px;margin:0}.puzzle-difficulty{font-size:11px;font-weight:700;padding:4px 8px;background:#0000004d;border-radius:var(--radius-sm);letter-spacing:1px}.puzzle-description{color:var(--text-secondary);margin:0;font-size:14px}.puzzle-controls{display:flex;gap:var(--spacing-sm)}.target-button{background:#0ff3;border-color:var(--accent);color:var(--accent);font-weight:600;padding:var(--spacing-md) var(--spacing-lg)}.target-button:hover:not(:disabled){background:#00ffff4d;box-shadow:0 0 10px #00ffff4d}.target-button:disabled{opacity:.5;cursor:not-allowed}.puzzle-hints{background:#ffc8001a;border:1px solid rgba(255,200,0,.3);border-radius:var(--radius-md);padding:var(--spacing-md)}.hints-title{font-weight:600;margin-bottom:var(--spacing-sm);color:#fc4}.puzzle-hints ul{margin:0;padding-left:20px;color:var(--text-secondary)}.puzzle-hints li{margin:4px 0;font-size:14px}.puzzle-canvas{flex:1;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;min-height:400px}.puzzle-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.puzzle-actions button{flex:1;min-width:150px;padding:var(--spacing-md);font-weight:600}.record-button{background:#f003;border-color:#ff000080;color:#f44}.stop-button{background:#ffa50033;border-color:#ffa50080;color:#fa4}.play-button{background:#0f03;border-color:#00ff0080;color:#4f4}.verify-button{background:#0ff3;border-color:var(--accent);color:var(--accent)}.retry-button{background:#96969633;border-color:#96969680;color:#aaa}.puzzle-result{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.puzzle-result.passed{border-color:#4f4;background:#00ff000d}.puzzle-result.failed{border-color:#f44;background:#ff00000d}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.result-header h3{margin:0;font-size:24px}.stars{display:flex;gap:4px}.star{font-size:32px;color:#333}.star.filled{color:#fc0;text-shadow:0 0 10px rgba(255,204,0,.5)}.result-details{display:flex;flex-direction:column;gap:var(--spacing-md)}.result-score{font-size:20px;font-weight:600;text-align:center;padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.result-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm)}.metric{display:flex;flex-direction:column;gap:4px;padding:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--radius-sm);text-align:center}.metric-label{font-size:12px;color:var(--text-secondary)}.metric-value{font-size:18px;font-weight:600;color:var(--accent)}.next-button{margin-top:var(--spacing-md);width:100%;background:#0f03;border-color:#4f4;color:#4f4;padding:var(--spacing-md);font-size:16px;font-weight:600}.next-button:hover{background:#00ff004d;box-shadow:0 0 10px #00ff004d}.completion-message{margin-top:var(--spacing-md);padding:var(--spacing-lg);background:linear-gradient(135deg,#f0f3,#0ff3);border-radius:var(--radius-md);text-align:center;font-size:20px;font-weight:600}.puzzle-progress{text-align:center;color:var(--text-secondary);font-size:14px;padding:var(--spacing-sm)}@media (max-width: 768px){.puzzle-header{flex-direction:column}.result-metrics{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}:root{--color-c4: #FF0000;--color-d4: #FF7700;--color-e4: #FFFF00;--color-f4: #00FF00;--color-g4: #00FFFF;--color-a4: #0000FF;--color-b4: #FF00FF;--color-c5: #FFFFFF;--color-rest: #000000;--bg-primary: #0a0a0a;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--text-primary: #ffffff;--text-secondary: #aaaaaa;--border-color: #333333;--accent: #00ffff;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-medium: .25s ease;--transition-slow: .35s ease;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .5)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);overflow:hidden}#root{width:100vw;height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:#3a3a3a}::selection{background:var(--accent);color:var(--bg-primary)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;outline:none;background:var(--bg-tertiary);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);transition:all var(--transition-fast);border:1px solid var(--border-color)}button:hover{background:#3a3a3a;border-color:var(--accent)}button:active{transform:scale(.98)}button:disabled{opacity:.5;cursor:not-allowed}input[type=range]{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:var(--bg-tertiary);outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;transition:transform var(--transition-fast)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;transition:transform var(--transition-fast)}input[type=range]::-moz-range-thumb:hover{transform:scale(1.2)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.glass{background:#1a1a1acc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color)}.app{width:100vw;height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-header{background:var(--bg-secondary);border-bottom:2px solid var(--border-color);padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);box-shadow:var(--shadow-sm)}.header-content{display:flex;align-items:center;gap:var(--spacing-md)}.app-title{font-size:28px;font-weight:700;margin:0;background:linear-gradient(135deg,var(--accent),var(--color-b4));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.mode-selector{display:flex;gap:var(--spacing-sm);background:var(--bg-tertiary);padding:4px;border-radius:var(--radius-md)}.mode-btn{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;color:var(--text-secondary);font-size:14px;font-weight:500;border-radius:var(--radius-sm);transition:all var(--transition-fast);cursor:pointer}.mode-btn:hover{background:#ffffff0d;color:var(--text-primary)}.mode-btn.active{background:var(--accent);color:var(--bg-primary);box-shadow:0 0 10px #00ffff4d}.welcome-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-xl)}.welcome-screen h2{font-size:32px;margin:0}.welcome-description{font-size:18px;color:var(--text-secondary)}.start-button{font-size:18px;padding:16px 48px;background:var(--accent);color:var(--bg-primary);font-weight:700;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;box-shadow:0 4px 12px #00ffff4d}.start-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0ff6}.start-button:active{transform:translateY(0)}.welcome-features{margin-top:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-sm);text-align:center}.welcome-features p{color:var(--text-secondary);font-size:16px;margin:0}.app-workspace{flex:1;display:flex;overflow:hidden}.app-sidebar{width:320px;background:var(--bg-primary);border-right:2px solid var(--border-color);display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);overflow-y:auto}.app-canvas-area{flex:1;display:flex;flex-direction:column;padding:var(--spacing-md);overflow:hidden}.canvas-container{flex:1;background:var(--bg-secondary);border-radius:var(--radius-lg);border:2px solid var(--border-color);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}.canvas-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,transparent,rgba(0,255,255,.05),transparent);pointer-events:none}@media (max-width: 768px){.app-workspace{flex-direction:column}.app-sidebar{width:100%;max-height:40%;border-right:none;border-bottom:2px solid var(--border-color)}.app-title{font-size:20px}.app-subtitle{display:none}}
