@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;600;700;800&display=swap";:root{--bg: #f5f7f3;--surface: rgba(255, 255, 255, .92);--surface-solid: #ffffff;--surface-soft: #f8faf5;--text: #111827;--muted: #667085;--line: #dfe5dc;--line-strong: #cbd5c9;--ink: #172033;--accent: #1e88e5;--accent-soft: #e8f3ff;--danger: #b42318;font-family:Noto Sans KR,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#fbfcf8,#eef3ed)}body{overflow-x:hidden}button,input,select{font:inherit}.app-shell{min-height:100vh;padding:30px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:20px;margin:0 auto 24px;max-width:1480px}.app-header h1{margin:0;font-size:42px;line-height:1;letter-spacing:0;color:var(--ink)}.app-header p{margin:10px 0 0;color:var(--muted);font-size:16px;font-weight:600}.header-status{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.header-status span{min-height:30px;display:inline-flex;align-items:center;border:1px solid rgba(30,136,229,.18);border-radius:999px;background:#ffffffb8;color:#245a8f;font-size:12px;font-weight:900;padding:0 11px;box-shadow:0 8px 20px #1f29370d}.workspace{display:grid;grid-template-columns:360px minmax(0,1fr);gap:22px;max-width:1480px;margin:0 auto}.sidebar,.main-column{display:grid;gap:18px;align-content:start}.panel,.viewer-panel,.viewer-empty,.error-panel,.warnings-panel{background:var(--surface);border:1px solid rgba(203,213,201,.82);border-radius:8px;box-shadow:0 18px 45px #1f293714;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.upload-panel{padding:16px}.drop-zone{min-height:148px;border:1px dashed #93a7b8;border-radius:8px;display:grid;place-items:center;gap:10px;padding:20px;text-align:center;color:#26364a;background:linear-gradient(180deg,#ffffffd6,#f7faf5eb);cursor:pointer;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.drop-zone:hover{border-color:var(--accent);box-shadow:inset 0 0 0 1px #1e88e524,0 12px 28px #1e88e514;transform:translateY(-1px)}.drop-zone svg{color:var(--accent)}.drop-zone span{max-width:260px;overflow-wrap:anywhere;font-size:15px;font-weight:900}.drop-zone input{position:absolute;opacity:0;pointer-events:none}.control-grid{display:grid;gap:14px;margin-top:18px}.control-grid label{display:grid;gap:7px;color:#334155;font-size:13px;font-weight:700}.control-grid select,.control-grid input[type=number]{width:100%;height:44px;border:1px solid var(--line-strong);border-radius:6px;background:#ffffffe6;color:var(--text);padding:0 12px;box-shadow:0 1px #11182708}.control-grid select:focus,.control-grid input:focus,.metadata-editor input:focus,.editor-grid select:focus,.add-event-grid select:focus,.add-event-grid input:focus{border-color:#1e88e5b8;box-shadow:0 0 0 4px #1e88e51f;outline:none}.checkbox-row{grid-template-columns:auto 1fr;align-items:center}.checkbox-row input{width:18px;height:18px;accent-color:var(--accent)}.primary-button,.download-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:6px;border:0;text-decoration:none;font-weight:800}.primary-button{width:100%;height:48px;margin-top:18px;background:var(--ink);color:#fff;cursor:pointer;box-shadow:0 14px 24px #1120332e;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.primary-button:not(:disabled):hover{background:#0d1524;box-shadow:0 18px 32px #11203338;transform:translateY(-1px)}.primary-button:disabled{opacity:.45;cursor:not-allowed}.legend-panel{padding:16px}.legend-panel h2,.viewer-toolbar h2,.editor-panel h2{margin:0;font-size:18px}.legend-grid{display:grid;gap:8px;margin-top:14px}.legend-item{display:grid;grid-template-columns:24px 34px 1fr;align-items:center;gap:8px;font-size:14px;min-height:28px}.swatch{width:20px;height:20px;border-radius:5px;border:1px solid rgba(17,24,39,.12)}.rest-swatch{background:#e0e0e0}.editor-panel{padding:16px}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.editor-grid{display:grid;gap:12px;margin-top:14px}.editor-grid label{display:grid;gap:7px;color:#374151;font-size:13px;font-weight:700}.editor-grid select,.metadata-editor input,.add-event-grid select,.add-event-grid input{width:100%;min-height:40px;border:1px solid var(--line-strong);border-radius:6px;background:#ffffffeb;color:var(--text);padding:0 10px}.metadata-editor{border:1px solid rgba(203,213,201,.9);border-radius:8px;padding:12px;background:var(--surface-soft)}.editor-section-title{display:inline-flex;align-items:center;gap:7px;color:var(--ink);font-size:13px;font-weight:900}.metadata-editor label,.part-name-list label{display:grid;gap:6px;color:#334155;font-size:12px;font-weight:800}.part-name-list{display:grid;gap:8px}.metadata-save-button{width:100%}.add-event-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.add-event-grid label{display:grid;gap:6px;color:#374151;font-size:12px;font-weight:800}.add-event-grid select:disabled{color:#9ca3af;background:#f9fafb}.editor-event-select select{min-height:44px}.event-detail{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;color:#374151;font-size:12px;font-weight:700}.event-detail span{border:1px solid var(--line);border-radius:999px;padding:5px 8px;background:#fff}.editor-section{display:grid;gap:8px;margin-top:14px}.add-event-section{border-top:1px solid var(--line);padding-top:14px}.editor-label{color:#374151;font-size:13px;font-weight:800}.button-row{display:flex;flex-wrap:wrap;gap:7px}.tool-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:34px;border:1px solid var(--line-strong);border-radius:6px;background:#fff;color:var(--text);cursor:pointer;font-size:12px;font-weight:800;padding:0 10px;transition:transform .14s ease,border-color .14s ease,background .14s ease}.tool-button.strong{background:var(--accent-soft);border-color:#1e88e52e;color:#185f9e}.tool-button.danger{border-color:#fecaca;color:var(--danger)}.tool-button:not(:disabled):hover,.download-button:hover,.direct-edit-button:not(:disabled):hover{transform:translateY(-1px);border-color:#1e88e56b}.tool-button:disabled{cursor:not-allowed;opacity:.45}.viewer-panel{overflow:hidden;min-width:0}.viewer-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:1px solid var(--line);background:#ffffffbd}.eyeline{margin:0 0 4px;color:#6f7a89;font-size:12px;font-weight:800;text-transform:uppercase}.download-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.download-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:38px;padding:0 12px;color:var(--text);background:#fff;border:1px solid var(--line-strong);font-size:13px;box-shadow:0 8px 18px #1f29370d}.mode-button{cursor:pointer;font-weight:800}.mode-button.active{background:var(--ink);border-color:var(--ink);color:#fff}.direct-edit-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:9px;padding:12px 16px;border-bottom:1px solid var(--line);background:#f8faf5}.direct-edit-field{display:inline-flex;align-items:center;gap:7px;min-height:34px;color:#374151;font-size:12px;font-weight:800}.direct-edit-field select{min-height:34px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#111827;font:inherit;padding:0 28px 0 9px}.direct-edit-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:34px;border:1px solid var(--line-strong);border-radius:6px;background:#fff;color:var(--text);cursor:pointer;font-size:12px;font-weight:800;padding:0 10px}.direct-edit-button.danger{border-color:#fecaca;color:#991b1b}.direct-edit-button:disabled,.direct-edit-field select:disabled{cursor:not-allowed;opacity:.5}.direct-edit-hint{color:#6b7280;font-size:12px;font-weight:700}.svg-scroll{overflow:scroll;padding:16px;background:linear-gradient(180deg,#fdfefb,#f5f8f2);max-height:calc(100vh - 230px);min-height:420px;scrollbar-gutter:stable both-edges;overscroll-behavior:contain}.svg-scroll svg{display:block;max-width:none;min-width:max-content}.direct-edit-scroll{cursor:crosshair}.direct-edit-svg{font-family:Noto Sans KR,Noto Sans CJK KR,Malgun Gothic,Apple SD Gothic Neo,NanumGothic,Arial Unicode MS,sans-serif;-webkit-user-select:none;user-select:none;touch-action:none}.svg-scroll svg text{font-family:Noto Sans KR,Noto Sans CJK KR,Malgun Gothic,Apple SD Gothic Neo,NanumGothic,Arial Unicode MS,sans-serif!important}.measure-hit-area{fill:transparent;pointer-events:all}.editable-event{cursor:grab}.editable-event:active{cursor:grabbing}.editable-event text{pointer-events:none}.selection-ring{fill:none;stroke:#111827;stroke-width:2;pointer-events:none}.resize-handle{fill:#111827d1;cursor:ew-resize}.viewer-empty{min-height:560px;display:grid;place-items:center;padding:28px;text-align:center;color:var(--muted);position:relative;overflow:hidden}.staff-lines{position:absolute;top:34%;right:8%;bottom:34%;left:8%;background:repeating-linear-gradient(to bottom,transparent 0,transparent 18px,rgba(30,41,59,.14) 19px,rgba(30,41,59,.14) 20px)}.viewer-empty p{position:relative;margin:0;max-width:360px;font-size:18px;font-weight:700}.error-panel,.warnings-panel{padding:14px 16px}.error-panel{border-color:#fecaca;background:#fff1f2;color:#991b1b;font-weight:700}.error-panel p{margin:0}.error-help{display:grid;gap:8px;margin-top:10px;color:#7f1d1d;font-size:14px;font-weight:600;line-height:1.4}.error-help code{display:block;width:fit-content;max-width:100%;overflow-x:auto;border-radius:6px;background:#fff;border:1px solid #fecaca;padding:8px 10px;color:#111827;font-size:13px;font-weight:700}.warnings-panel{border-color:#fde68a;background:#fffbeb;color:#92400e}.warnings-panel p{margin:4px 0}.app-shell{padding:0;background:#f7f8f5}.workspace{display:grid;grid-template-columns:344px minmax(0,1fr);gap:0;max-width:none;min-height:100vh;margin:0}.sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;align-content:start;gap:0;background:#ffffffeb;border-right:1px solid #e4e8e1;box-shadow:18px 0 40px #1f29370a}.sidebar-brand{height:74px;display:flex;align-items:center;padding:0 22px;border-bottom:1px solid #e4e8e1}.brand-lockup{display:inline-flex;align-items:center;gap:10px}.brand-lockup h1{margin:0;color:#172033;font-size:28px;line-height:1;letter-spacing:0}.brand-mark{width:28px;height:28px;display:inline-grid;grid-template-columns:repeat(4,1fr);align-items:end;gap:3px}.brand-mark span{width:5px;border-radius:999px}.brand-mark span:nth-child(1){height:13px;background:#8e24aa}.brand-mark span:nth-child(2){height:21px;background:#e53935}.brand-mark span:nth-child(3){height:17px;background:#43a047}.brand-mark span:nth-child(4){height:25px;background:#1e88e5}.sidebar .panel{border:0;border-radius:0;box-shadow:none;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border-bottom:1px solid #e8ece5}.upload-panel,.editor-panel,.legend-panel{padding:20px 22px}.step-heading{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:7px;color:#3b4656;font-size:15px;font-weight:900;margin-bottom:14px}.step-heading span{color:#5f6b7a;font-weight:900}.step-heading svg{color:#667085}.step-heading.compact{margin-bottom:12px}.settings-heading,.editor-tools-heading{margin-top:20px;padding-top:20px;border-top:1px solid #e8ece5}.drop-zone{min-height:118px;border-color:#c8d1dc;background:#fbfcfb}.drop-zone small{display:block;margin-top:-4px;color:#667085;font-size:12px;font-weight:700}.file-chip{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;margin-top:14px;color:#172033;font-size:13px;font-weight:800}.file-chip svg{color:#43a047}.file-chip span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-chip button{min-height:34px;border:1px solid #dfe5dc;border-radius:6px;background:#fff;color:#172033;cursor:pointer;font-size:12px;font-weight:900;padding:0 12px}.control-grid{margin-top:0}.control-grid label:not(.checkbox-row){grid-template-columns:minmax(92px,1fr) minmax(0,156px);align-items:center}.control-grid label>span,.editor-grid label>span,.metadata-editor label>span,.part-name-list label>span,.add-event-grid label>span{color:#596579}.control-grid select,.control-grid input[type=number],.editor-grid select,.metadata-editor input,.add-event-grid select,.add-event-grid input{border-color:#dfe5dc;background:#fff;box-shadow:inset 0 1px 2px #1f293708}.checkbox-row{display:grid;grid-template-columns:minmax(0,1fr) auto}.checkbox-row input{order:2;width:36px;height:22px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:999px;background:#172033;position:relative;cursor:pointer}.checkbox-row input:after{content:"";position:absolute;top:3px;left:17px;width:16px;height:16px;border-radius:999px;background:#fff;transition:left .14s ease}.checkbox-row input:not(:checked){background:#cbd5e1}.checkbox-row input:not(:checked):after{left:3px}.primary-button{height:42px;margin-top:16px}.metadata-editor{padding:0;border:0;background:transparent}.metadata-editor label,.part-name-list label{grid-template-columns:76px minmax(0,1fr);align-items:center}.metadata-save-button{margin-top:4px}.editor-grid{margin-top:0}.legend-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.legend-item{grid-template-columns:1fr;gap:0;min-height:34px;border-radius:6px;color:#fff;font-weight:900;position:relative;overflow:hidden;padding:7px 10px}.legend-item .swatch{position:absolute;top:0;right:0;bottom:0;left:0;width:auto;height:auto;border:0;border-radius:6px}.legend-item span:not(.swatch),.legend-item strong{position:relative;z-index:1}.legend-item span:not(.swatch){font-size:12px}.legend-item strong{justify-self:end;margin-top:-18px}.legend-item:last-child{color:#172033}.main-column{min-width:0;gap:0;align-content:stretch;background:#f7f8f5}.topbar{height:74px;display:grid;grid-template-columns:minmax(220px,360px) 1fr auto;align-items:center;gap:18px;padding:0 22px;background:#ffffffe0;border-bottom:1px solid #e4e8e1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.title-control{min-width:0;height:42px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;border:1px solid #dfe5dc;border-radius:7px;background:#fff;color:#172033;font-size:14px;font-weight:800;padding:0 12px}.title-control span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.title-control svg{color:#667085}.topbar-center,.topbar-actions{display:flex;align-items:center;justify-content:center;gap:10px}.topbar-actions{justify-content:flex-end}.download-dropdown{position:relative;display:inline-flex;justify-content:flex-end}.save-state{display:inline-flex;align-items:center;gap:6px;color:#4b7562;font-size:13px;font-weight:800}.topbar-divider,.toolbar-divider{width:1px;height:28px;background:#e4e8e1}.icon-button{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #dfe5dc;border-radius:7px;background:#fff;color:#667085;cursor:pointer}.icon-button.active,.icon-button:not(:disabled):hover{color:#172033;border-color:#cfd8cf;box-shadow:0 8px 18px #1f29370f}.icon-button:disabled{cursor:not-allowed;opacity:.55}.topbar-download-secondary{min-height:30px;display:inline-flex;align-items:center;border:1px solid #dfe5dc;border-radius:999px;color:#245a8f;background:#fff;font-size:11px;font-weight:900;text-decoration:none;padding:0 10px}.download-menu{min-height:44px;display:inline-flex;align-items:center;gap:8px;border:0;border-radius:8px;background:#101828;color:#fff;cursor:pointer;font-size:15px;font-weight:900;padding:0 18px;box-shadow:0 12px 24px #1018282e}.download-menu:disabled{background:#98a2b3;box-shadow:none;cursor:not-allowed}.download-popover{position:absolute;top:calc(100% + 10px);right:0;z-index:30;min-width:196px;padding:8px;border:1px solid #dfe5dc;border-radius:10px;background:#fffffff5;box-shadow:0 22px 50px #1018282e;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.download-popover a{min-height:48px;display:flex;align-items:center;justify-content:space-between;gap:18px;border-radius:8px;color:#172033;text-decoration:none;padding:0 12px}.download-popover a:hover{background:#f4f7f1}.download-popover span{color:#245a8f;font-size:14px;font-weight:950;letter-spacing:0}.download-popover small{color:#667085;font-size:11px;font-weight:800}.viewer-panel{border:0;border-radius:0;box-shadow:none;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.viewer-toolbar{min-height:64px;display:grid;grid-template-columns:auto 1fr;gap:20px;padding:14px 22px;background:#ffffffb3;border-bottom:1px solid #e9ede6}.mode-segment,.canvas-tools{display:inline-flex;align-items:center;gap:6px}.mode-chip{min-height:40px;display:inline-flex;align-items:center;gap:8px;border:1px solid #dfe5dc;border-radius:7px;background:#fff;color:#344054;cursor:pointer;font-size:14px;font-weight:900;padding:0 14px}.mode-chip.active{background:#101828;border-color:#101828;color:#fff;box-shadow:0 12px 22px #10182824}.spacing-control{display:inline-flex;align-items:center;justify-self:end;gap:10px;color:#596579;font-size:13px;font-weight:900}.spacing-control select{height:40px;min-width:92px;border:1px solid #dfe5dc;border-radius:7px;background:#fff;color:#172033;font-weight:800;padding:0 12px}.svg-scroll{margin:20px 22px 0;border:1px solid #e1e7de;border-radius:10px;background:linear-gradient(0deg,#ffffffc7,#ffffffc7),repeating-linear-gradient(90deg,transparent 0,transparent 79px,rgba(31,41,55,.025) 80px),repeating-linear-gradient(0deg,transparent 0,transparent 31px,rgba(31,41,55,.018) 32px);box-shadow:0 22px 60px #1f293712;min-height:calc(100vh - 224px);max-height:calc(100vh - 224px)}.svg-scale-layer{transform-origin:0 0}.svg-scale-layer>svg{display:block;max-width:none;min-width:0;transform:scale(var(--score-zoom, 1));transform-origin:0 0}.direct-edit-toolbar{margin:0 22px;border:1px solid #e1e7de;border-top:0;border-radius:0 0 10px 10px;background:#fff}.viewer-empty{margin:20px 22px;min-height:calc(100vh - 184px);border:1px solid #e1e7de;box-shadow:0 22px 60px #1f293712}.viewer-statusbar{min-height:44px;display:flex;align-items:center;justify-content:flex-end;gap:18px;margin:0 22px 18px;padding:0 4px;color:#667085;font-size:13px;font-weight:800}.zoom-stepper{height:34px;display:inline-grid;grid-template-columns:38px 70px 38px;align-items:center;border:1px solid #dfe5dc;border-radius:7px;overflow:hidden;background:#fff;color:#172033}.zoom-stepper button{height:100%;border:0;background:#fff;color:#344054;cursor:pointer;font-size:16px;font-weight:900}.zoom-stepper button:disabled{color:#b5bdc8;cursor:not-allowed}.zoom-stepper button+strong,.zoom-stepper strong+button{border-left:1px solid #dfe5dc}.zoom-stepper strong{height:100%;display:inline-flex;align-items:center;justify-content:center;font-size:13px}@media (max-width: 860px){.app-shell{padding:0}.workspace{grid-template-columns:1fr}.sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid #e4e8e1}.topbar{height:auto;grid-template-columns:1fr;padding:14px 18px}.topbar-center,.topbar-actions{justify-content:flex-start;flex-wrap:wrap}.viewer-toolbar{display:flex;align-items:flex-start;flex-direction:column}.svg-scroll,.viewer-empty{margin:16px 18px;min-height:520px;max-height:70vh}.control-grid label:not(.checkbox-row),.metadata-editor label,.part-name-list label{grid-template-columns:1fr}.legend-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
