*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#f8f6f1;--color-surface:#fff;--color-primary:#1e293b;--color-primary-light:#334155;--color-accent:#c9956b;--color-accent-light:#e8d5c0;--color-accent-muted:#f5ede4;--color-text:#1a1a2e;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-success:#22c55e;--color-success-bg:#f0fdf4;--color-warning:#d97706;--color-warning-bg:#fffbeb;--color-error:#dc2626;--color-error-bg:#fef2f2;--color-info:#2563eb;--color-info-bg:#eff6ff;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--font-sans:"Pretendard", "Apple SD Gothic Neo", "Noto Sans KR", -apple-system, BlinkMacSystemFont, "Malgun Gothic", sans-serif;--font-serif:"KoPub Batang", "Apple Myungjo", "Noto Serif KR", "Batang", serif}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{color:var(--color-accent);text-decoration:none}::selection{background:var(--color-accent-light);color:var(--color-primary)}.app{flex-direction:column;width:100%;max-width:1120px;min-height:100vh;margin:0 auto;padding:0 24px;display:flex}.header{margin-bottom:8px;padding:28px 0 20px}.header-inner{align-items:center;gap:14px;display:flex}.header-icon{border-radius:var(--radius-md);background:var(--color-accent-muted);width:44px;height:44px;color:var(--color-accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.header-title{letter-spacing:-.02em;color:var(--color-primary);font-size:1.35rem;font-weight:700;line-height:1.3}.header-desc{color:var(--color-text-muted);margin-top:1px;font-size:.85rem}.main{flex-direction:column;flex:1;gap:16px;padding-bottom:40px;display:flex}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);overflow:hidden}.upload-card{box-shadow:none;background:0 0;border:none}.drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;background:var(--color-surface);padding:48px 24px;transition:all .25s}.drop-zone:hover{border-color:var(--color-accent);background:var(--color-accent-muted)}.drop-zone-active{border-color:var(--color-accent);background:var(--color-accent-muted);transform:scale(1.01)}.drop-zone-has-file{border-color:var(--color-accent-light);background:var(--color-accent-muted);padding:24px}.file-input{display:none}.drop-zone-content{flex-direction:column;align-items:center;gap:8px;display:flex}.drop-zone-icon{color:var(--color-text-muted);opacity:.6;margin-bottom:4px}.drop-zone-file-icon{color:var(--color-accent);margin-bottom:4px}.drop-zone-text{color:var(--color-text);font-size:1rem;font-weight:600}.drop-zone-hint{color:var(--color-text-muted);font-size:.85rem}.drop-zone-file-name{color:var(--color-accent);word-break:break-all;font-size:.95rem;font-weight:600}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:28px;height:28px;margin-bottom:4px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.alert{border-radius:var(--radius-md);align-items:center;gap:10px;padding:14px 16px;font-size:.9rem;line-height:1.4;display:flex}.alert-error{background:var(--color-error-bg);color:var(--color-error);border:1px solid #fecaca}.compat-bar{justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;font-size:.9rem;font-weight:600;display:flex}.compat-bar-left{align-items:center;gap:8px;min-width:0;display:flex}.compat-bar-icon{flex-shrink:0;display:flex}.compat-bar-label{white-space:nowrap}.compat-bar.compat-ok{background:var(--color-success-bg);color:#15803d}.compat-bar.compat-warn{background:var(--color-warning-bg);color:#b45309}.compat-bar.compat-error{background:var(--color-error-bg);color:#b91c1c}.compat-bar.compat-info{background:var(--color-info-bg);color:#1d4ed8}.compat-toggle{color:inherit;opacity:.7;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;align-items:center;gap:4px;padding:4px 8px;font-size:.85rem;font-weight:500;transition:opacity .15s,background .15s;display:flex}.compat-toggle:hover{opacity:1;background:#0000000d}.compat-toggle svg{transition:transform .2s}.compat-details{max-height:0;transition:max-height .3s;overflow:hidden}.compat-details-open{max-height:800px}.compat-issue{border-top:1px solid var(--color-border-light);align-items:flex-start;gap:10px;padding:10px 18px;font-size:.85rem;line-height:1.45;display:flex}.compat-issue-error{background:#fff9f9}.compat-issue-warning{background:#fffcf5}.compat-issue-info{background:#fafbff}.compat-badge{border-radius:4px;flex-shrink:0;margin-top:2px;padding:2px 7px;font-size:.7rem;font-weight:700;line-height:1.4}.compat-badge-error{color:#b91c1c;background:#fecaca}.compat-badge-warning{color:#92400e;background:#fde68a}.compat-badge-info{color:#1e40af;background:#bfdbfe}.compat-msg{color:var(--color-text-secondary);flex:1}.toolbar{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);border:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.toolbar-group{align-items:center;gap:8px;display:flex}.toolbar-label{color:var(--color-text-secondary);white-space:nowrap;font-size:.85rem;font-weight:500}.toolbar-select{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);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 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;outline:none;padding:7px 32px 7px 10px;font-size:.85rem;transition:border-color .15s}.toolbar-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #c9956b26}.toolbar-actions{gap:8px;display:flex}.btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);white-space:nowrap;align-items:center;gap:6px;padding:8px 14px;font-size:.85rem;font-weight:500;transition:all .15s;display:inline-flex}.btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-muted)}.btn:active{transform:scale(.97)}.btn-success{border-color:var(--color-success);color:#15803d;background:var(--color-success-bg)}.viewer-section{flex-direction:column;gap:16px;display:flex}.song-title{text-align:center;color:var(--color-primary);letter-spacing:-.01em;font-size:1.15rem;font-weight:600}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:40px 24px;display:flex}.empty-state-icon{opacity:.4}.empty-state-title{color:var(--color-text);font-size:1.1rem;font-weight:600}.empty-state-desc{color:var(--color-text-muted);max-width:360px;font-size:.9rem;line-height:1.6}.footer{text-align:center;color:var(--color-text-muted);border-top:1px solid var(--color-border-light);padding:16px 0 24px;font-size:.8rem}.viewer-container{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fcf9f2;border:1px solid #e8e0d0;padding:32px 24px;position:relative;overflow-x:auto}.viewer-container:before{content:"";pointer-events:none;border-radius:inherit;background:repeating-linear-gradient(0deg,#0000,#0000 40px,#e8e0d04d 40px 41px);position:absolute;inset:0}.viewer-inner{z-index:1;justify-content:flex-end;width:100%;min-height:120px;display:flex;position:relative}.viewer-grid{flex-flow:row-reverse wrap;gap:32px 14px;width:100%;display:flex}.measure{flex-direction:column;align-items:center;gap:3px;display:flex}.measure-number{color:#b8b0a0;letter-spacing:.02em;font-size:.7rem;font-weight:500}.jeonggan{background:#ffffffd9;border:1.5px solid #3a3a3a;flex-direction:column;flex-shrink:0;width:56px;display:flex;position:relative}.jeonggan+.jeonggan{margin-top:-1px}.jeonggan-item{border-bottom:1px dashed #ddd8d0;justify-content:center;align-items:center;min-height:24px;padding:2px 0;display:flex}.jeonggan-item:last-child{border-bottom:none}.yul{color:#1a1a1a;letter-spacing:.02em;font-family:KoPub Batang,Apple Myungjo,Noto Serif KR,Batang,Malgun Gothic,serif;font-size:1.15rem;font-weight:700;line-height:1.3}.yul-rest{font-family:var(--font-sans);color:#888;font-size:.9rem;font-weight:400}.yul-ext{color:#aaa;font-size:1.1rem;font-weight:300}.octave-prefix{align-items:center;margin-right:2px;font-size:.7rem;font-weight:600;line-height:1.15;display:inline-flex}.prefix-low{color:#2563eb}.prefix-high{color:#dc2626}.viewer-credit{text-align:right;color:#b8b0a0;font-size:.7rem;font-family:var(--font-sans);z-index:1;border-top:1px solid #e8e0d0;margin-top:12px;padding-top:8px;position:relative}.viewer-empty{border-radius:var(--radius-lg);color:#c8c0b0;background:#fcf9f2;border:1px solid #e8e0d0;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 24px;display:flex}.viewer-empty-icon{opacity:.5}.viewer-empty-text{color:#b8b0a0;font-size:.9rem}
