@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Sans:wght@300;400;500;600;700&display=swap";.toast-anim-enter-active[data-v-b352f018],.toast-anim-leave-active[data-v-b352f018]{transition:all .2s ease}.toast-anim-enter-from[data-v-b352f018],.toast-anim-leave-to[data-v-b352f018]{opacity:0;transform:translate(20px)}.toast-icon[data-v-b352f018]{font-weight:700;font-size:.9rem;flex-shrink:0}.toast[data-v-b352f018]{cursor:pointer}:root,[data-theme=dark]{--bg-base: #0e0e14;--bg-surface: #16161f;--bg-elevated: #1e1e2a;--bg-hover: #252533;--bg-active: #2d2d3e;--border: #2a2a3a;--border-light: #323244;--text-primary: #e8e8f0;--text-secondary:#9090aa;--text-muted: #5a5a70;--text-inverse: #0e0e14;--accent: #7c6fe0;--accent-hover: #9585f0;--accent-light: rgba(124, 111, 224, .15);--green: #4ade80;--green-bg: rgba(74, 222, 128, .12);--red: #f87171;--red-bg: rgba(248, 113, 113, .12);--amber: #fbbf24;--amber-bg: rgba(251, 191, 36, .12);--blue: #60a5fa;--blue-bg: rgba(96, 165, 250, .12);--chord-color: #a78bfa;--chord-bg: rgba(167, 139, 250, .08);--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 12px rgba(0,0,0,.5);--shadow-lg: 0 8px 32px rgba(0,0,0,.6);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--font-ui: "IBM Plex Sans", system-ui, sans-serif;--font-mono: "IBM Plex Mono", "Courier New", monospace;color-scheme:dark}[data-theme=light]{--bg-base: #f0f0f7;--bg-surface: #ffffff;--bg-elevated: #ffffff;--bg-hover: #f5f5fc;--bg-active: #ebebf8;--border: #e0e0ee;--border-light: #ececf8;--text-primary: #1a1a2e;--text-secondary:#5a5a7a;--text-muted: #9090b0;--text-inverse: #ffffff;--accent: #6355c8;--accent-hover: #7060d8;--accent-light: rgba(99, 85, 200, .1);--green: #16a34a;--green-bg: rgba(22, 163, 74, .1);--red: #dc2626;--red-bg: rgba(220, 38, 38, .1);--amber: #d97706;--amber-bg: rgba(217, 119, 6, .1);--blue: #2563eb;--blue-bg: rgba(37, 99, 235, .1);--chord-color: #6355c8;--chord-bg: rgba(99, 85, 200, .06);--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 32px rgba(0,0,0,.15);color-scheme:light}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-ui);background:var(--bg-base);color:var(--text-primary);line-height:1.6;min-height:100dvh;overflow-x:hidden;transition:background .2s,color .2s}#app,#app-root{min-height:100dvh;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}h1{font-size:1.75rem;font-weight:700;line-height:1.2}h2{font-size:1.4rem;font-weight:600;line-height:1.3}h3{font-size:1.15rem;font-weight:600}h4{font-size:1rem;font-weight:600}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}code,.mono{font-family:var(--font-mono)}.chord-sheet{font-family:var(--font-mono);font-size:var(--song-font-size, 15px);line-height:1.8;width:100%}.chord-line{color:var(--chord-color);font-weight:600;display:block;background:var(--chord-bg);border-radius:3px;padding:0 2px;margin-bottom:-2px;letter-spacing:.01em;white-space:pre}.lyric-line{color:var(--text-primary);display:block;margin-bottom:4px;white-space:pre-wrap;word-break:break-word}.section-header{color:var(--accent);font-weight:700;font-size:.8em;text-transform:uppercase;letter-spacing:.1em;margin:1em 0 .3em;display:block}.blank-line{display:block;height:.8em}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-md);font-family:var(--font-ui);font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .15s ease;white-space:nowrap;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid rgba(248,113,113,.25)}.btn-danger:hover{background:var(--red);color:#fff}.btn-icon{padding:8px;border-radius:var(--radius-sm)}.btn-sm{padding:5px 12px;font-size:.8125rem}.btn-lg{padding:12px 24px;font-size:1rem}.btn-full{width:100%;justify-content:center}.input{width:100%;padding:9px 12px;background:var(--bg-elevated);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-ui);font-size:.9rem;outline:none;transition:border-color .15s}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.input::placeholder{color:var(--text-muted)}.input-label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:5px}.input-error{border-color:var(--red)!important}.input-error-msg{font-size:.78rem;color:var(--red);margin-top:4px}textarea.input{resize:vertical;min-height:120px;font-family:var(--font-mono);line-height:1.6}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-elevated{background:var(--bg-elevated);box-shadow:var(--shadow-sm)}.card-hover{transition:all .15s;cursor:pointer}.card-hover:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:99px;font-size:.75rem;font-weight:500;border:1px solid transparent}.badge-accent{background:var(--accent-light);color:var(--accent);border-color:#7c6fe033}.badge-green{background:var(--green-bg);color:var(--green)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-amber{background:var(--amber-bg);color:var(--amber)}.badge-muted{background:var(--bg-hover);color:var(--text-muted)}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.app-layout{display:grid;grid-template-columns:240px 1fr;grid-template-rows:1fr;min-height:100dvh;width:100%}@media (max-width: 768px){.app-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100dvh;position:sticky;top:0;overflow-y:auto}.main-content{overflow-y:auto;height:100dvh;display:flex;flex-direction:column;min-width:0;width:100%}.page-header{padding:20px 24px 0;border-bottom:1px solid var(--border)}.page-body{flex:1;padding:20px 24px;max-width:1200px;width:100%;min-width:0;margin:0 auto}.offline-banner{background:var(--amber-bg);color:var(--amber);border-bottom:1px solid rgba(251,191,36,.2);padding:6px 16px;font-size:.8125rem;font-weight:500;text-align:center;z-index:50}.pwa-update-banner{background:var(--accent);color:#fff;padding:8px 16px;display:flex;align-items:center;justify-content:center;gap:12px;font-size:.875rem;z-index:100}.page-enter-active,.page-leave-active{transition:opacity .18s ease,transform .18s ease}.page-enter-from{opacity:0;transform:translateY(8px)}.page-leave-to{opacity:0;transform:translateY(-8px)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column-reverse;gap:8px;max-width:360px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);font-size:.875rem;animation:toast-in .2s ease}.toast-success{border-left:3px solid var(--green)}.toast-error{border-left:3px solid var(--red)}.toast-info{border-left:3px solid var(--accent)}.toast-warning{border-left:3px solid var(--amber)}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;max-width:560px;width:100%;box-shadow:var(--shadow-lg);animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-auto{margin-top:auto}.w-full{width:100%}.hidden{display:none}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0)}.stage-mode{position:fixed;top:0;right:0;bottom:0;left:0;background:#050508;z-index:2000;overflow:hidden;display:flex;flex-direction:column}.stage-content{flex:1;overflow-y:auto;padding:32px clamp(16px,5vw,80px);scroll-behavior:smooth}.stage-content .chord-sheet{font-size:var(--stage-font-size, 22px);line-height:2}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-surface);border-top:1px solid var(--border);z-index:100;padding:8px 0 max(8px,env(safe-area-inset-bottom))}@media (max-width: 768px){.sidebar{display:none}.mobile-nav{display:flex;justify-content:space-around}.main-content{padding-bottom:60px}.page-body{padding:16px}.toast-container{bottom:80px;right:12px;left:12px}}.sortable-ghost{opacity:.4}.sortable-chosen{background:var(--bg-active)!important}.sortable-drag{box-shadow:var(--shadow-lg)!important}.drag-handle{cursor:grab;color:var(--text-muted);touch-action:none}.drag-handle:active{cursor:grabbing}.diff-added{background:var(--green-bg);color:var(--green)}.diff-removed{background:var(--red-bg);color:var(--red);text-decoration:line-through}:root{--safe-top: env(safe-area-inset-top, 0px);--safe-right: env(safe-area-inset-right, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px)}#app,#app-root{padding-left:var(--safe-left);padding-right:var(--safe-right)}.sidebar-logo,.page-header,.detail-header,.editor-header,.stage-controls,.stage-all-controls{padding-top:calc(12px + var(--safe-top))!important}.detail-header .btn,.editor-header .btn,.stage-controls .stage-btn,.stage-all-controls .stage-btn{min-height:36px;min-width:36px;font-size:.88rem!important}.stage-btn{padding:8px 12px!important;min-height:36px}.mobile-nav{padding-bottom:max(8px,var(--safe-bottom))}.toast-container{bottom:calc(24px + var(--safe-bottom))}
