.example-loader{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1rem;margin-bottom:1rem}.example-loader-header{margin-bottom:1rem}.example-loader-header h3{margin:0;color:#495057;font-size:1.1rem;font-weight:600}.category-selector{margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.category-selector label{font-weight:500;color:#495057;font-size:.9rem}.category-select{padding:.375rem .75rem;border:1px solid #ced4da;border-radius:4px;background-color:#fff;font-size:.9rem;color:#495057;cursor:pointer;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.category-select:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.song-list{display:flex;flex-direction:column;gap:.5rem}.song-item{background:#fff;border:1px solid #dee2e6;border-radius:6px;overflow:hidden;transition:all .2s ease-in-out}.song-item:hover{border-color:#007bff;box-shadow:0 2px 4px #0000001a}.song-item.selected{border-color:#007bff;background-color:#e7f3ff}.song-button{width:100%;padding:.75rem;border:none;background:none;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-family:inherit;transition:background-color .15s ease-in-out}.song-button:hover{background-color:#f8f9fa}.song-item.selected .song-button{background-color:transparent}.song-title{font-weight:500;color:#212529;font-size:.95rem}.song-description{padding:0 .75rem .75rem;font-size:.85rem;color:#6c757d;line-height:1.4}.difficulty-badge{padding:.2rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.difficulty-beginner{background-color:#d4edda;color:#155724}.difficulty-intermediate{background-color:#fff3cd;color:#856404}.difficulty-advanced{background-color:#f8d7da;color:#721c24}.empty-message{text-align:center;padding:2rem;color:#6c757d;font-style:italic}@media (max-width: 768px){.example-loader{padding:.75rem}.category-selector{flex-direction:column;align-items:flex-start;gap:.25rem}.song-button{padding:1rem .75rem}.song-button{flex-direction:column;align-items:flex-start;gap:.5rem}.difficulty-badge{align-self:flex-start}}.song-button:focus{outline:2px solid #007bff;outline-offset:2px}.category-select:focus{outline:2px solid #007bff;outline-offset:2px}.song-item{position:relative}.song-item.selected:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:#007bff}.example-loader.loading{opacity:.7;pointer-events:none}.example-loader.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.notification-container{position:fixed;z-index:1000;max-width:400px;pointer-events:none}.notification-container.notification-top{top:20px;right:20px}.notification-container.notification-bottom{bottom:20px;right:20px}.notification{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-bottom:12px;padding:16px;pointer-events:auto;position:relative;transform:translate(100%);animation:slideIn .3s ease-out forwards;border-left:4px solid #e2e8f0}.notification.notification-hiding{animation:slideOut .3s ease-in forwards}.notification-error{border-left-color:#e53e3e;background:#fed7d7}.notification-warning{border-left-color:#d69e2e;background:#fefcbf}.notification-success{border-left-color:#38a169;background:#c6f6d5}.notification-info{border-left-color:#3182ce;background:#bee3f8}.notification-content{display:flex;align-items:flex-start;gap:12px}.notification-icon{font-size:18px;line-height:1;flex-shrink:0}.notification-text{flex:1;min-width:0}.notification-title{font-weight:600;font-size:14px;line-height:1.4;margin-bottom:4px;color:#2d3748}.notification-message{font-size:13px;line-height:1.4;color:#4a5568;white-space:pre-line}.notification-dismiss{position:absolute;top:8px;right:8px;background:none;border:none;font-size:18px;line-height:1;color:#a0aec0;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.notification-dismiss:hover{background:#0000001a;color:#718096}.notification-actions{margin-top:12px;display:flex;gap:8px;justify-content:flex-end}.notification-action{padding:6px 12px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.notification-action-primary{background:#3182ce;color:#fff}.notification-action-primary:hover{background:#2c5282}.notification-action-secondary{background:#e2e8f0;color:#4a5568}.notification-action-secondary:hover{background:#cbd5e0}.notification-action-danger{background:#e53e3e;color:#fff}.notification-action-danger:hover{background:#c53030}.error-highlighter-container{position:relative;display:inline-block;width:100%}.error-highlighter-textarea{position:relative;z-index:2;background:transparent}.error-highlighter-textarea.with-line-numbers{padding-left:60px}.error-highlight-overlay{position:absolute;inset:0;pointer-events:none;z-index:1;overflow:hidden;font-family:inherit;font-size:inherit;line-height:inherit;white-space:pre-wrap;word-wrap:break-word}.error-highlight{position:absolute;pointer-events:auto;cursor:pointer;border-radius:2px;transition:all .2s}.error-highlight-error{background:#e53e3e33;border:1px solid rgba(229,62,62,.4)}.error-highlight-error:hover{background:#e53e3e4d}.error-highlight-warning{background:#d69e2e33;border:1px solid rgba(214,158,46,.4)}.error-highlight-warning:hover{background:#d69e2e4d}.error-highlight-gutter{position:absolute;top:0;left:0;width:50px;height:100%;background:#f7fafc;border-right:1px solid #e2e8f0;z-index:3;overflow:hidden;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px}.error-gutter-item{position:absolute;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:0 8px;cursor:pointer;transition:background .2s}.error-gutter-item:hover{background:#0000000d}.error-gutter-error{background:#e53e3e1a}.error-gutter-warning{background:#d69e2e1a}.line-number{font-size:11px;color:#a0aec0;font-weight:400}.gutter-icon{font-size:12px;line-height:1}.error-highlight-tooltip{position:fixed;background:#2d3748;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;line-height:1.4;max-width:300px;z-index:1001;box-shadow:0 4px 12px #0000004d;white-space:pre-line;word-wrap:break-word}.tooltip-error{background:#e53e3e}.tooltip-warning{background:#d69e2e}.error-highlight-tooltip:before{content:"";position:absolute;top:100%;left:12px;border:6px solid transparent;border-top-color:#2d3748}.tooltip-error:before{border-top-color:#e53e3e}.tooltip-warning:before{border-top-color:#d69e2e}.validation-messages{min-height:24px;margin-top:8px;padding:0 4px}.validation-message{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:4px;font-size:13px;line-height:1.4;margin-bottom:4px}.validation-message-error{background:#fed7d7;color:#c53030;border:1px solid #feb2b2}.validation-message-warning{background:#fefcbf;color:#b7791f;border:1px solid #f6e05e}.validation-message-success{background:#c6f6d5;color:#2f855a;border:1px solid #9ae6b4}.validation-message-icon{font-size:14px;flex-shrink:0}.validation-message-text{flex:1}.error-handling-loading{opacity:.6;pointer-events:none;position:relative}.error-handling-loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid #e2e8f0;border-top-color:#3182ce;border-radius:50%;animation:spin 1s linear infinite}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.notification-container{left:20px;right:20px;max-width:none}.notification{transform:translateY(-100%);animation:slideInMobile .3s ease-out forwards}.notification.notification-hiding{animation:slideOutMobile .3s ease-in forwards}.error-highlight-tooltip{max-width:250px;font-size:11px}.error-highlighter-textarea.with-line-numbers{padding-left:45px}.error-highlight-gutter{width:40px}}@keyframes slideInMobile{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideOutMobile{0%{transform:translateY(0);opacity:1}to{transform:translateY(-100%);opacity:0}}@media (prefers-contrast: high){.notification{border-width:2px;border-style:solid}.notification-error{border-color:#e53e3e;background:#fff;color:#e53e3e}.notification-warning{border-color:#d69e2e;background:#fff;color:#d69e2e}.notification-success{border-color:#38a169;background:#fff;color:#38a169}.notification-info{border-color:#3182ce;background:#fff;color:#3182ce}.error-highlight-error{background:#e53e3e66;border-width:2px}.error-highlight-warning{background:#d69e2e66;border-width:2px}}@media (prefers-reduced-motion: reduce){.notification,.notification.notification-hiding,.error-highlight,.notification-dismiss,.notification-action,.error-gutter-item{animation:none;transition:none}.error-handling-loading:after{animation:none}}.notification-dismiss:focus,.notification-action:focus,.error-highlight:focus,.error-gutter-item:focus{outline:2px solid #3182ce;outline-offset:2px}.loading-overlay,.loading-spinner,.notification,.error-highlight{will-change:transform,opacity;transform:translateZ(0)}canvas{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;transform:translateZ(0);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:auto}.loading-spinner{animation:spin 1s linear infinite;border:4px solid transparent;border-top:4px solid #3498db;border-radius:50%}.input-area,.preview-area,.notification-text{text-rendering:optimizeSpeed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.notification{transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s cubic-bezier(.4,0,.2,1)}.notification.entering{transform:translateY(-100%);opacity:0}.notification.entered{transform:translateY(0);opacity:1}.notification.exiting{transform:translateY(-100%);opacity:0}.app-container{display:flex;contain:layout style}.input-section,.preview-section{contain:layout style paint;transform:translateZ(0)}.scrollable-content{-webkit-overflow-scrolling:touch;overflow-anchor:none;contain:layout style paint}@media (max-width: 768px){.loading-overlay{backdrop-filter:none;background:#fffffff2}.touch-target{min-height:44px;min-width:44px;touch-action:manipulation}.loading-spinner{animation-duration:2s}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){canvas{image-rendering:-webkit-optimize-contrast;image-rendering:pixelated}}@media (prefers-reduced-motion: reduce){.loading-spinner{animation:none}.notification{transition:none}*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.performance-monitor{position:fixed;top:10px;left:10px;background:#000c;color:#fff;padding:8px 12px;border-radius:4px;font-family:monospace;font-size:11px;z-index:10001;pointer-events:none;opacity:.7;transition:opacity .2s ease}.performance-monitor:hover{opacity:1;pointer-events:auto}.performance-monitor.warning{background:#ffc107e6;color:#000}.performance-monitor.critical{background:#dc3545e6;color:#fff}.memory-usage-bar{width:100px;height:4px;background:#333;border-radius:2px;overflow:hidden;margin:2px 0}.memory-usage-fill{height:100%;background:linear-gradient(90deg,#28a745,#ffc107,#dc3545);transition:width .3s ease}@media print{.performance-monitor,.loading-overlay,.notification{display:none!important}canvas{image-rendering:auto;max-width:100%;height:auto}}@container (max-width: 600px){.performance-monitor{font-size:10px;padding:6px 8px}}.focus-visible{outline:2px solid #007bff;outline-offset:2px}button:focus,input:focus,textarea:focus{outline:none}button:focus-visible,input:focus-visible,textarea:focus-visible{box-shadow:0 0 0 2px #007bff;transition:box-shadow .15s ease}button{transform:translateZ(0);touch-action:manipulation;user-select:none}button:active{transform:translateZ(0) scale(.98)}input,textarea{will-change:contents;backface-visibility:hidden}.loading{pointer-events:none;cursor:wait}.loading *{pointer-events:none}.error-state{animation:errorPulse .5s ease-in-out}@keyframes errorPulse{0%,to{background-color:transparent}50%{background-color:#dc35451a}}.success-state{animation:successFlash .3s ease-out}@keyframes successFlash{0%,to{background-color:transparent}50%{background-color:#28a7451a}}*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-primary: #3182ce;--color-primary-hover: #2c5aa0;--color-primary-light: rgba(49, 130, 206, .1);--color-secondary: #4a5568;--color-text: #2d3748;--color-text-muted: #718096;--color-text-light: #a0aec0;--color-background: #f8f9fa;--color-surface: #ffffff;--color-border: #e2e8f0;--color-border-hover: #cbd5e0;--color-error: #c53030;--color-error-bg: #fed7d7;--color-error-border: #feb2b2;--color-warning: #744210;--color-warning-bg: #fefcbf;--color-warning-border: #f6e05e;--color-success: #38a169;--color-success-bg: #c6f6d5;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--space-3xl: 30px;--space-4xl: 40px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 4px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 6px rgba(0, 0, 0, .1);--shadow-focus: 0 0 0 3px var(--color-primary-light);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--breakpoint-sm: 480px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1200px;--touch-target-min: 44px;color:var(--color-text);background-color:var(--color-background)}body{margin:0;min-height:100vh;background-color:var(--color-background);overflow-x:hidden}#app{min-height:100vh;display:flex;flex-direction:column}.app-container{max-width:1400px;margin:0 auto;padding:var(--space-xl);flex:1;display:flex;flex-direction:column;width:100%}.app-header{text-align:center;margin-bottom:var(--space-3xl);padding-bottom:var(--space-xl)}.app-header h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:600;color:var(--color-text);margin:0 0 var(--space-md) 0;letter-spacing:-.025em}.app-header .app-description{font-size:clamp(1rem,2.5vw,1.1rem);color:var(--color-text-muted);margin:0 0 var(--space-md) 0;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6}.app-header .instructions{margin-top:var(--space-md)}.app-header .instructions p{font-size:clamp(.875rem,2vw,1rem);color:var(--color-text-light);margin:0;font-style:italic}.app-main{display:flex;flex-direction:column!important;gap:var(--space-3xl);align-items:stretch;min-height:0}@media (max-width: 768px){.app-main{gap:var(--space-xl)}}.input-section{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-md);border:1px solid var(--color-border);position:relative;transition:box-shadow var(--transition-normal)}.input-section:hover{box-shadow:var(--shadow-lg)}.input-section h2{font-size:clamp(1.25rem,3vw,1.5rem);font-weight:600;color:var(--color-text);margin:0 0 var(--space-lg) 0;display:flex;align-items:center;gap:var(--space-sm)}@media (max-width: 768px){.input-section{padding:var(--space-xl)}.input-section h2{cursor:pointer;user-select:none;padding:var(--space-sm);margin:calc(-1 * var(--space-sm)) calc(-1 * var(--space-sm)) var(--space-lg);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.input-section h2:hover{background-color:var(--color-background)}.input-section h2:after{content:"▼";margin-left:auto;font-size:.8em;transition:transform var(--transition-normal)}.input-section.collapsed h2:after{transform:rotate(-90deg)}.input-section.collapsed .input-content{display:none}}.title-input-container{margin-bottom:var(--space-lg)}.song-title-input{width:100%;padding:var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:16px;line-height:1.5;outline:none;transition:border-color var(--transition-normal),box-shadow var(--transition-normal),background-color var(--transition-normal);background-color:var(--color-background)}.song-title-input:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus);background-color:var(--color-surface)}.song-title-input:hover:not(:focus){border-color:var(--color-border-hover)}.song-title-input::placeholder{color:var(--color-text-light);font-style:italic}@media (max-width: 768px){.song-title-input{font-size:16px;padding:var(--space-lg)}}.text-input-container{position:relative;margin-bottom:var(--space-lg)}.input-label,.textarea-label{display:block;font-weight:500;color:var(--color-text);margin-bottom:var(--space-sm);font-size:14px}.input-help{font-size:13px;color:var(--color-text-muted);margin-top:var(--space-sm);line-height:1.4}.song-textarea{width:100%;min-height:200px;padding:var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-md);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;line-height:1.5;resize:vertical;outline:none;transition:border-color var(--transition-normal),box-shadow var(--transition-normal),background-color var(--transition-normal);background-color:var(--color-background)}.song-textarea:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus);background-color:var(--color-surface)}.song-textarea:hover:not(:focus){border-color:var(--color-border-hover)}.song-textarea::placeholder{color:var(--color-text-light);font-style:italic}@media (max-width: 768px){.song-textarea{min-height:150px;font-size:16px;padding:var(--space-lg)}}.input-controls{display:flex;gap:var(--space-md);justify-content:flex-end;flex-wrap:wrap}@media (max-width: 768px){.input-controls{justify-content:stretch;gap:var(--space-sm)}.input-controls .btn{flex:1;min-height:var(--touch-target-min)}}@media (max-width: 480px){.input-controls{flex-direction:column}}.preview-section{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-md);border:1px solid var(--color-border);position:relative;transition:box-shadow var(--transition-normal)}.preview-section:hover{box-shadow:var(--shadow-lg)}.preview-section h2{font-size:clamp(1.25rem,3vw,1.5rem);font-weight:600;color:var(--color-text);margin:0 0 var(--space-lg) 0;display:flex;align-items:center;gap:var(--space-sm)}.canvas-container{position:relative;min-height:300px;display:flex;align-items:center;justify-content:center;background-color:var(--color-background);border-radius:var(--radius-md);border:2px dashed var(--color-border);transition:border-color var(--transition-normal),background-color var(--transition-normal);overflow:hidden}.canvas-container:hover{border-color:var(--color-border-hover)}.canvas-container.has-content{border-style:solid;background-color:var(--color-surface)}.preview-controls{margin-top:var(--space-lg);display:flex;justify-content:center;gap:var(--space-md)}@media (max-width: 768px){.preview-controls{justify-content:stretch}.preview-controls .btn{flex:1}}.chart-canvas{max-width:100%;max-height:100%;height:auto;border-radius:var(--radius-sm);transition:transform var(--transition-normal)}.chart-canvas:hover{transform:scale(1.02)}@media (max-width: 768px){.preview-section{padding:var(--space-xl)}.canvas-container{min-height:250px}.preview-section h2{cursor:pointer;user-select:none;padding:var(--space-sm);margin:calc(-1 * var(--space-sm)) calc(-1 * var(--space-sm)) var(--space-lg);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.preview-section h2:hover{background-color:var(--color-background)}.preview-section h2:after{content:"▼";margin-left:auto;font-size:.8em;transition:transform var(--transition-normal)}.preview-section.collapsed h2:after{transform:rotate(-90deg)}.preview-section.collapsed .preview-content{display:none}}@media (max-width: 480px){.canvas-container{min-height:200px}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-lg);font-size:14px;font-weight:500;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-normal);text-decoration:none;min-width:80px;min-height:var(--touch-target-min);position:relative;overflow:hidden;white-space:nowrap;user-select:none}.btn:before{content:"";position:absolute;inset:0;background:currentColor;opacity:0;transition:opacity var(--transition-fast)}.btn:focus{outline:none;box-shadow:var(--shadow-focus)}.btn:active:before{opacity:.1}.btn-primary{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);border-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-primary:disabled{background-color:var(--color-text-light);border-color:var(--color-text-light);cursor:not-allowed;opacity:.6;transform:none;box-shadow:none}.btn-secondary{background-color:var(--color-surface);color:var(--color-secondary);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background-color:var(--color-background);border-color:var(--color-border-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}@media (hover: none) and (pointer: coarse){.btn{min-height:48px;padding:var(--space-md) var(--space-xl)}.btn:hover{transform:none}.btn:active{transform:scale(.98)}}.validation-errors,.validation-warnings{margin-top:var(--space-sm)}.validation-error,.validation-warning{padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-xs);border-radius:var(--radius-sm);font-size:13px;line-height:1.4;border-left:4px solid;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.validation-error{background-color:var(--color-error-bg);border-color:var(--color-error);color:var(--color-error)}.validation-warning{background-color:var(--color-warning-bg);border-color:var(--color-warning);color:var(--color-warning)}.validation-success{background-color:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.app-footer{text-align:center;margin-top:var(--space-3xl);padding-top:var(--space-xl);border-top:1px solid var(--color-border)}.app-footer p{color:var(--color-text-muted);font-size:14px;margin:0;line-height:1.6}@media (max-width: 768px){.app-footer{margin-top:var(--space-2xl);padding-top:var(--space-lg)}.app-footer p{font-size:13px}}@media (min-width: 1200px){.app-container{padding:var(--space-4xl)}.app-main{gap:var(--space-4xl);flex-direction:column}}@media (max-width: 1024px) and (min-width: 769px){.app-container{padding:var(--space-2xl)}.app-main{gap:var(--space-2xl)}}@media (max-width: 768px){.app-container{padding:var(--space-lg)}.app-main{gap:var(--space-xl)}}@media (max-width: 480px){.app-container{padding:var(--space-md)}.app-header{margin-bottom:var(--space-2xl)}.app-main{gap:var(--space-lg)}}@media (max-width: 360px){.app-container{padding:var(--space-sm)}.input-section,.preview-section{padding:var(--space-lg)}}@media (prefers-contrast: high){:root{--color-border: #000000;--color-text: #000000;--color-background: #ffffff}.song-textarea,.btn{border-width:3px}.input-section,.preview-section{border-width:2px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.chart-canvas:hover,.btn:hover{transform:none}}@media (prefers-color-scheme: dark){:root{--color-text: #f7fafc;--color-text-muted: #a0aec0;--color-text-light: #718096;--color-background: #1a202c;--color-surface: #2d3748;--color-border: #4a5568;--color-border-hover: #718096}.song-textarea{background-color:var(--color-background);color:var(--color-text)}.song-textarea:focus{background-color:var(--color-surface)}}@media print{.app-header,.app-footer,.input-controls{display:none}.app-main{gap:0}.input-section,.preview-section{box-shadow:none;border:1px solid #000;break-inside:avoid}.chart-canvas{max-width:100%;height:auto}}.skip-link{position:absolute;top:-40px;left:6px;background:var(--color-primary);color:#fff;padding:8px;text-decoration:none;border-radius:var(--radius-sm);z-index:1000}.skip-link:focus{top:6px}.loading{position:relative;pointer-events:none}.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid var(--color-border);border-top:2px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;z-index:10}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-state{border-color:var(--color-error)!important;background-color:var(--color-error-bg)}.success-state{border-color:var(--color-success)!important;background-color:var(--color-success-bg)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.keyboard-shortcuts-hint{margin-top:var(--space-sm);opacity:.8}.keyboard-shortcuts-hint kbd{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px 6px;font-family:monospace;font-size:.85em;box-shadow:0 1px 2px #0000001a}.skip-link{position:absolute;top:-40px;left:6px;background:var(--color-primary);color:#fff;padding:8px 12px;text-decoration:none;border-radius:var(--radius-sm);z-index:1000;font-weight:500;border:2px solid transparent;transition:all var(--transition-fast)}.skip-link:focus{top:6px;border-color:var(--color-surface);box-shadow:var(--shadow-focus)}.skip-link:hover:focus{background-color:var(--color-primary-hover)}.update-notification{animation:slideInFromRight .3s ease-out}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.update-content{font-size:14px}.update-content .btn-sm{padding:6px 12px;font-size:12px;min-height:auto}.app-container{transform:translateZ(0);will-change:auto}@font-face{font-family:System;src:local("-apple-system"),local("BlinkMacSystemFont"),local("Segoe UI"),local("Roboto");font-display:swap}.input-section,.preview-section{contain:layout style paint}.chart-canvas{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}@media (prefers-reduced-motion: no-preference){.btn,.file-drop-zone,.input-section,.preview-section{transition-property:transform,opacity,box-shadow,border-color,background-color}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.chart-canvas{image-rendering:-webkit-optimize-contrast}}@supports (backdrop-filter: blur(10px)){.notification-container .notification{backdrop-filter:blur(10px);background-color:#ffffffe6}}@supports not (display: flex){.app-main{display:block}.input-section,.preview-section{margin-bottom:var(--space-3xl)}@media (max-width: 768px){.input-section,.preview-section{margin-bottom:var(--space-xl)}}}.validation-messages{min-height:0;transition:min-height var(--transition-normal)}.validation-messages:not(:empty){min-height:2rem;margin-top:var(--space-sm)}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
