@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&display=swap";:root{--bg-color: #0f1115;--bg-color-secondary: #16181d;--card-bg: rgba(26, 29, 36, .7);--card-border: rgba(255, 255, 255, .08);--text-primary: #f8f9fa;--text-secondary: #a0a6b1;--accent-primary: #e87500;--accent-hover: #d96a00;--accent-glow: rgba(232, 117, 0, .2);--brand-blue: #4da3ff;--brand-blue-muted: rgba(77, 163, 255, .14);--stitch-surface-highest: #353439;--stitch-primary: #ffd0a5;--stitch-primary-deep: #f1b06f;--stitch-on-primary: #2c1600;--stitch-amber-glow: rgba(241, 176, 111, .4);--border-radius-sm: 8px;--border-radius-md: 12px;--border-radius-lg: 16px;--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .2);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .3);--shadow-glow: 0 0 20px var(--accent-glow);--transition-fast: .15s ease-out;--transition-normal: .25s ease-out}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-color);background-image:radial-gradient(circle at 15% 45%,rgba(232,117,0,.055),transparent 28%),radial-gradient(circle at 82% 22%,var(--brand-blue-muted),transparent 26%),radial-gradient(circle at 50% 100%,rgba(15,17,21,.9),transparent 45%);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}button{font-family:"Inter",inherit}.app{max-width:1200px;margin:0 auto;padding:2rem;display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;flex-direction:column;align-items:stretch;margin-bottom:1.5rem;gap:1rem}.header-banner{position:relative;width:100%;margin-left:-2rem;margin-right:-2rem;padding:0 2rem}.site-logo{width:100%;height:auto;max-height:240px;object-fit:contain;object-position:center;display:block}.site-logo-btn{display:block;width:100%;padding:0;margin:0;border:none;background:transparent;cursor:pointer;border-radius:var(--border-radius-sm)}.site-logo-btn:hover .site-logo{opacity:.92}.site-logo-btn:focus-visible{outline:2px solid var(--accent, #3b82f6);outline-offset:2px}.hamburger-wrap{position:absolute;top:.75rem;right:1rem;z-index:1000}.hamburger-btn{position:relative;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--border-radius-sm);padding:.4rem .6rem;cursor:pointer;color:var(--text-primary);transition:background .15s}.hamburger-btn:hover{background:#fff3}.hamburger-icon{font-size:1.3rem;line-height:1}.hamburger-backdrop{position:fixed;inset:0;z-index:999}.hamburger-menu{position:absolute;top:calc(100% + .5rem);right:0;min-width:220px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-md);box-shadow:0 8px 24px #0006;z-index:1001;overflow:hidden}.hamburger-item{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.9rem;color:var(--text-primary);width:100%;border:none;background:none;text-align:left;cursor:default}.hamburger-user-info{border-bottom:1px solid var(--card-border);padding-bottom:.75rem}.hamburger-action{cursor:pointer;transition:background .15s}.hamburger-action:hover{background:#ffffff14}.hamburger-admin-block{border-top:1px solid var(--card-border);padding-top:.25rem}.hamburger-admin-heading{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);padding:.5rem 1rem .35rem;cursor:default}.hamburger-submenu-item{padding-left:1.5rem}.header-content h1{font-size:3rem;font-weight:700;background:linear-gradient(135deg,#f8f9fa,#a0a6b1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem;letter-spacing:-.02em}.subtitle{color:var(--text-secondary);font-size:1.1rem;font-weight:500}.header-actions{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;justify-content:center}.auth-loading{font-size:.9rem;color:var(--text-secondary);display:inline-flex;align-items:center;gap:.5rem}.auth-user{display:flex;align-items:center;gap:.75rem}.auth-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.auth-email{font-size:.9rem;color:var(--text-secondary);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-tabs{display:flex;gap:.5rem;background:#0003;padding:.4rem;border-radius:100px;border:1px solid var(--card-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tab-btn{background:transparent;color:var(--text-secondary);border:none;padding:.6rem 1.5rem;border-radius:100px;font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.tab-btn:hover{color:var(--text-primary);background:#ffffff0d}.tab-btn.active{background:var(--accent-primary);color:#fff;box-shadow:0 4px 12px var(--accent-glow)}.tab-content-area{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.search-container{width:100%;max-width:500px;position:relative}.search-input{width:100%;padding:1rem 1.5rem;border-radius:100px;background:var(--card-bg);border:1px solid var(--card-border);color:var(--text-primary);font-size:1rem;font-family:Inter,sans-serif;box-shadow:var(--shadow-sm);transition:all var(--transition-normal);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #e8750033,var(--shadow-md);background:#1e2128cc}.search-input::placeholder{color:#6c7281}.action-btn,.google-sign-in-btn{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1.5rem;border-radius:var(--border-radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);border:none}.scan-btn{background:var(--accent-primary);color:#fff;box-shadow:0 4px 12px var(--accent-glow)}.scan-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 16px var(--accent-glow)}.scan-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.google-sign-in-btn{background:#fff;color:#3c4043;border:1px solid #dadce0;box-shadow:0 1px 2px #3c40434d;font-weight:500;min-height:44px}.google-sign-in-btn:hover{transform:translateY(-2px);box-shadow:0 2px 8px #3c40434d;background:#fdfdfd}.google-sign-in-icon{width:18px;height:18px;flex-shrink:0}.icon-btn{background:#ffffff0d;border:1px solid var(--card-border);color:var(--text-primary);border-radius:var(--border-radius-sm);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.icon-btn:hover{background:#ffffff1a;transform:scale(1.05)}.sign-in-card,.setup-card,.empty-state,.create-form-card{max-width:480px;margin:2rem auto;padding:3rem 2rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-lg);text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-md)}.sign-in-icon,.empty-icon{font-size:3rem;margin-bottom:1rem}.sign-in-card h2,.setup-card h2,.empty-state h3{margin-bottom:1rem;color:var(--text-primary)}.sign-in-card p,.setup-card p,.empty-state p{color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.choose-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1rem}.setup-card pre{background:#0000004d;padding:1rem;border-radius:var(--border-radius-sm);font-size:.9rem;overflow-x:auto;margin-bottom:1.5rem;border:1px solid var(--card-border);color:#a8b2d1}.error-banner{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#ef4444;padding:1rem;border-radius:var(--border-radius-md);margin:1.5rem 0;text-align:center}.library-container{display:flex;flex-direction:column;gap:2rem}.actions-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem}.tune-list-container{display:flex;flex-direction:column;gap:.5rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-md);overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tune-list-item{border-bottom:1px solid rgba(255,255,255,.04);transition:background-color var(--transition-fast)}.tune-list-item:last-child{border-bottom:none}.tune-item-row{padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;cursor:pointer;transition:background-color var(--transition-fast)}.tune-item-row:hover{background-color:#ffffff08}.tune-list-item.expanded{background-color:#ffffff05;border-left:3px solid var(--accent-primary)}.tune-item-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.setlist-thumbnail-slot{flex-shrink:0;border-radius:var(--border-radius-sm);display:flex;align-items:center;justify-content:center;overflow:hidden;box-sizing:border-box;background:#ffffff0f;border:1px solid rgba(255,255,255,.08)}.setlist-thumbnail-slot--filled{border-color:#ffffff1f;padding:0}.setlist-thumbnail-img{width:100%;height:100%;object-fit:cover;display:block;border-radius:calc(var(--border-radius-sm) - 1px)}.setlist-picker-row-info{min-width:0}.tune-icon{opacity:.5;font-size:1.1rem}.tune-icon-spinner{width:1.1rem;height:1.1rem;opacity:.8}.tune-title-wrap{display:flex;align-items:center;gap:.75rem}.tune-name{font-size:1.05rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.parts-badge{font-size:.75rem;font-weight:600;background:#e8750033;color:#f5a962;padding:.2rem .5rem;border-radius:100px;white-space:nowrap}.setlist-demo-pill{display:inline-flex;align-items:center;font-size:.72rem;font-weight:600;letter-spacing:.02em;padding:.2rem .55rem;border-radius:999px;border:1px solid rgba(59,130,246,.45);color:var(--text-primary);background:#3b82f624;white-space:nowrap;flex-shrink:0}.setlist-demo-pill--on{background:#3b82f661;border-color:#60a5fabf;color:#e8f0fe}button.setlist-demo-pill{font:inherit;font-size:.72rem;font-weight:600;cursor:pointer;margin:0}button.setlist-demo-pill:hover:not(:disabled){filter:brightness(1.08)}button.setlist-demo-pill:focus-visible{outline:2px solid var(--accent-primary, #60a5fa);outline-offset:2px}.tune-actions{display:flex;gap:.5rem;flex-shrink:0}.text-btn{width:auto;padding:.4rem .8rem;font-size:.85rem;font-weight:500;border-radius:var(--border-radius-sm)}.action-btn.primary-btn{background:var(--accent-primary);color:#fff;border:1px solid transparent;box-shadow:0 2px 10px var(--accent-glow)}.action-btn.primary-btn:hover:not(:disabled){background:var(--accent-hover)}.action-btn.primary-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.sync-btn{padding:.35rem .65rem;font-size:.8rem}.library-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem 1rem;padding:.55rem .75rem;border-radius:var(--border-radius-sm, 8px);border:1px solid var(--card-border, rgba(255, 255, 255, .08));background:var(--surface-elevated, rgba(0, 0, 0, .15))}.library-toolbar__group{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem .5rem}.library-toolbar__legend{font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);margin-right:.15rem;flex-shrink:0}.library-toolbar__sep{width:1px;align-self:stretch;min-height:1.85rem;background:var(--card-border, rgba(255, 255, 255, .1));flex-shrink:0}.library-toolbar .library-toolbar__upload{font-size:.82rem;font-weight:600;padding:.4rem .85rem}@media(max-width:520px){.library-toolbar__sep{display:none}}.sync-upload-scope{margin-top:.65rem;padding-top:.65rem;border-top:1px solid var(--card-border)}.sync-upload-scope-toggle{display:flex;align-items:flex-start;gap:.5rem;font-size:.8rem;color:var(--text-primary);cursor:pointer;line-height:1.35}.sync-upload-scope-toggle input{margin-top:.15rem;flex-shrink:0}.sync-upload-scope-hint{margin:.35rem 0 0 1.6rem;font-size:.72rem;color:var(--text-secondary);line-height:1.4}.sync-upload-scope-folders{margin-top:.5rem;margin-left:1.6rem;display:flex;flex-direction:column;gap:.25rem;max-height:200px;overflow-y:auto}.sync-upload-scope-folder-actions{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.25rem}.sync-upload-scope-folder-row{font-size:.78rem}.primary-text-btn{background:var(--accent-primary);color:#fff;border-color:transparent}.primary-text-btn:hover{background:var(--accent-hover);border-color:transparent;transform:translateY(-1px)}.tune-author-column{width:25%;flex-shrink:0;color:var(--text-secondary);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right;padding-right:1rem}.active-media-btn{background:#10b9811a!important;border-color:#10b9814d!important}.inline-media-player-container{padding:1rem 1.5rem;background:#0000004d;border-top:1px solid rgba(255,255,255,.04)}.media-player-wrapper{width:100%}.inline-audio-player{width:100%;height:40px;outline:none;border-radius:var(--border-radius-sm)}.inline-video-player{width:100%;max-width:600px;border-radius:var(--border-radius-sm);display:block;margin:0 auto;box-shadow:var(--shadow-md)}.tune-preview-container{border-top:1px solid var(--card-border);background:#0003}.inline-part-selector{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none}.inline-part-selector::-webkit-scrollbar{display:none}.inline-part-pill{background:#ffffff0d;border:1px solid var(--card-border);color:var(--text-secondary);padding:.2rem .6rem;border-radius:100px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.inline-part-pill:hover{background:#ffffff1a;color:var(--text-primary)}.inline-part-pill.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:0 0 10px #e875004d}.tune-preview{padding:1.5rem;display:flex;flex-direction:row;align-items:stretch;gap:1rem;min-height:200px}.tune-preview-subfolder-label{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);padding:.5rem .5rem .5rem 0;font-size:.75rem;color:var(--text-secondary);border-right:2px solid var(--card-border);align-self:stretch;white-space:nowrap}.tune-preview-content{flex:1;display:flex;justify-content:center;align-items:center;min-width:0}.first4-preview-image{width:100%;max-width:none;border-radius:4px;opacity:.85;display:block}.first4-preview-crop-shell{position:relative;width:100%}.first4-preview-overlay{position:absolute;inset:0;cursor:crosshair;-webkit-user-select:none;user-select:none}.first4-preview-box{position:absolute;border:2px solid rgba(16,185,129,.95);background:#10b98129;box-sizing:border-box;pointer-events:none}.first4-preview-box-drawing{border-style:dashed;border-color:#60a5faf2;background:#60a5fa1f}.first4-window-control-row{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:.4rem}.first4-window-control-label{font-size:.8rem;color:var(--text-secondary);font-weight:600}.first4-window-input{width:4.2rem;padding:.2rem .45rem;font-size:.8rem}.first4-window-control-suffix{font-size:.8rem;color:var(--text-secondary)}.pdf-meta-editor{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.6rem}.pdf-meta-editor-title-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.85rem}.pdf-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.5rem}.pdf-meta-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.5rem}.pdf-meta-grid label{display:grid;gap:.25rem;font-size:.75rem;color:var(--text-secondary)}.pdf-meta-grid .search-input,.pdf-meta-row .search-input{padding:.3rem .45rem;font-size:.8rem}.pdf-meta-row label{display:grid;gap:.25rem;font-size:.75rem;color:var(--text-secondary)}.pdf-meta-actions{display:flex;gap:.45rem;flex-wrap:wrap}.pdf-meta-error{color:#ef4444;font-size:.8rem}.subfolder-filter-wrap{position:relative}.library-filter-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.25rem}.library-filter-left-icons{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.library-filter-icon{height:1.6rem;min-width:1.6rem;padding:0 .5rem;border:1px solid var(--card-border);border-radius:999px;font-size:.72rem;line-height:1;color:var(--text-secondary);white-space:nowrap}.library-filter-icon.active{color:var(--accent-primary);border-color:var(--accent-primary)}.library-filter-right-dropdown{margin-left:auto}.subfolder-toggle-btn{padding:.25rem .5rem;font-size:.8rem;border-radius:var(--border-radius-sm);transition:background .15s,color .15s;white-space:nowrap}.subfolder-toggle-btn.active{background:var(--accent-primary);color:var(--text-on-accent, #fff)}.subfolder-filter-backdrop{position:fixed;inset:0;z-index:50}.subfolder-filter-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);padding:.75rem 1rem;min-width:180px;max-height:280px;overflow-y:auto;z-index:100}.subfolder-filter-header{font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem;font-weight:600}.subfolder-filter-item{display:flex;align-items:center;gap:.5rem;padding:.35rem 0;cursor:pointer;font-size:.9rem}.subfolder-filter-item input{cursor:pointer}.preview-loading,.preview-error{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-secondary)}.preview-error{color:#ef4444}.notation-image{width:100%;max-width:100%;height:auto;border-radius:var(--border-radius-sm);background:#fff;padding:.5rem;box-shadow:inset 0 0 0 1px #0000001a}.spinner{width:1.25rem;height:1.25rem;border:2px solid rgba(255,255,255,.2);border-radius:50%;border-top-color:currentColor;animation:spin .8s linear infinite;flex-shrink:0}.spinner-lg{width:2.5rem;height:2.5rem;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.progress-bar{width:100%;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.global-loading-strip{position:fixed;top:0;left:0;right:0;z-index:9999;pointer-events:none}.app:has(.global-loading-strip){padding-top:2.65rem}.global-loading-caption,.global-loading-caption-row{font-size:.78rem;line-height:1.35;padding:.4rem .75rem .55rem;text-align:center;color:var(--text-secondary);background:var(--card-bg, var(--bg-secondary, rgba(20, 20, 24, .92)));border-bottom:1px solid var(--border-color, rgba(255, 255, 255, .08));box-shadow:0 1px #0000000f}.global-loading-caption-row{display:flex;align-items:center;justify-content:center;gap:.65rem;flex-wrap:wrap;pointer-events:auto}.global-loading-caption-text{flex:1 1 12rem;min-width:0;text-align:center}.global-loading-cancel{flex-shrink:0;font-size:.78rem!important;padding:.22rem .6rem!important}.progress-bar-global{position:relative;width:100%;height:3px;border-radius:0}.progress-bar-fill{height:100%;width:40%;background:var(--accent-primary);border-radius:2px;animation:progressIndeterminate 1.5s ease-in-out infinite;transition:width .2s ease-out}.progress-bar-fill.determinate{animation:none;transform:none}@keyframes progressIndeterminate{0%{transform:translate(-100%);width:40%}50%{transform:translate(150%);width:40%}to{transform:translate(-100%);width:40%}}.set-pdf-viewer-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}.set-pdf-viewer-modal{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-width:95vw;max-height:95vh;width:900px;height:85vh}.create-pdf-modal{width:auto;height:auto;padding:1.5rem}.set-pdf-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--card-border);flex-shrink:0}.set-pdf-viewer-header h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.set-pdf-viewer-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.set-pdf-viewer-content{flex:1;min-height:0;overflow:hidden}.set-pdf-iframe{width:100%;height:100%;border:none;background:#fff}.set-pdf-canvas-wrapper{position:relative;overflow:auto;max-height:100%;background:#525252;display:flex;flex-direction:column;align-items:center}.set-pdf-canvas-wrapper .set-pdf-page-wrapper{width:100%}.set-pdf-page-wrapper{position:relative;display:inline-block}.set-pdf-page-wrapper canvas{display:block;max-width:100%;height:auto}.set-pdf-remove-preview{position:absolute;left:0;right:0;border:2px dashed #ef4444;background:#ef444433;pointer-events:none;box-sizing:border-box}.set-pdf-remove-hint{margin:0 1.5rem .75rem;font-size:.9rem;color:var(--text-secondary)}.set-pdf-remove-overlay{position:absolute;left:0;right:0;border:2px solid #ef4444;background:#ef444426;pointer-events:none;box-sizing:border-box}.set-pdf-continuous{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding-bottom:1rem;width:100%}.set-pdf-view-mode{display:flex;gap:.25rem}.set-tunes-per-page{display:flex;align-items:center}.set-tunes-per-page-select{padding:.35rem .6rem;font-size:.9rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-sm);color:var(--text-primary);cursor:pointer}.set-pdf-page-nav{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary)}.set-pdf-viewer-actions .active{background:#10b98133;color:var(--accent-primary)}.setlist-page-modal{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-width:95vw;max-height:95vh;width:700px;height:90vh;overflow:hidden}.setlist-page-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--card-border);flex-shrink:0}.setlist-page-header h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.setlist-page-content{flex:1;overflow:auto;padding:.75rem 1.5rem 1.5rem}.setlist-page-items{display:flex;flex-direction:column;gap:1rem}.setlist-page-item{display:flex;gap:1rem;align-items:flex-start;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.08)}.setlist-page-item:last-child{border-bottom:none}.setlist-page-item-body{flex:1;min-width:0}.setlist-page-item-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.setlist-page-item-firstline{background:#2a2a2a;border-radius:var(--border-radius-sm);padding:.5rem .75rem;max-width:100%}.setlist-page-item-firstline img{width:100%;max-height:min(22vh,180px);object-fit:contain;display:block}.setlist-page-item-note{font-style:italic;color:var(--accent-primary);font-size:.95rem}@media print{body{background:#fff}.set-pdf-viewer-overlay{background:#fff!important;padding:0}.setlist-page-modal{box-shadow:none!important;border:none!important;max-width:none!important;max-height:none!important;width:100%!important;height:auto!important;background:#fff!important}.setlist-page-header{border-bottom-color:#ccc}.setlist-page-header h3{color:#111}.setlist-page-header button{display:none!important}.setlist-page-content{overflow:visible;padding:1rem}.setlist-page-item-title{color:#111!important}.setlist-page-item{border-bottom-color:#ddd}.setlist-page-item-firstline{background:#f5f5f5!important}.setlist-page-item-firstline img{max-height:160px!important}.setlist-page-item-note{color:#333!important}}.set-merge-editor{display:flex;flex-direction:column;height:100%;min-height:0}.set-merge-editor-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.set-merge-editor-header h2{margin:0;font-size:1.5rem;flex:1;min-width:120px}.set-merge-editor-actions{display:flex;gap:.75rem}.set-merge-editor-grid{display:grid;grid-template-columns:minmax(320px,1fr) 320px;gap:2rem;flex:1;min-height:0}.set-merge-editor-main{display:flex;flex-direction:column;min-height:0}.set-merge-editor-main h3{margin:0 0 .25rem;font-size:1.1rem}.set-merge-editor-hint{margin:0 0 1rem;font-size:.9rem;color:var(--text-secondary)}.set-merge-editor-main .tune-list-container{flex:1;overflow-y:auto;max-height:60vh}.set-merge-item{align-items:center}.set-merge-part-select{margin-left:.75rem;padding:.25rem .5rem;font-size:.85rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-sm);color:var(--text-primary);cursor:pointer}.set-merge-editor-add-panel{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-md);padding:1.25rem;display:flex;flex-direction:column;max-height:70vh}.set-merge-editor-add-panel h3{margin:0 0 1rem;font-size:1.1rem}.set-merge-editor-add-panel .search-input{margin-bottom:1rem;flex-shrink:0}.set-merge-editor-add-panel .search-results{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.set-merge-add-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;background:#ffffff0d;border-radius:var(--border-radius-sm);cursor:pointer;transition:background .15s}.set-merge-add-item:hover{background:#ffffff1a}.set-merge-add-item .add-badge{font-size:.8rem;color:var(--accent-primary);font-weight:600}@media(max-width:768px){.app{padding:.5rem}.header-banner{margin-left:-.5rem;margin-right:-.5rem;padding:0 .5rem}.site-logo{max-height:160px}.tune-grid{grid-template-columns:1fr}.tune-item-row{flex-wrap:wrap;padding:.6rem .75rem;gap:.4rem}.tune-item-info{width:100%;gap:.5rem}.tune-title-wrap{flex-wrap:wrap;gap:.4rem}.tune-name{font-size:.95rem;white-space:normal;word-break:break-word}.tune-author-column{display:none}.tune-actions{flex-wrap:wrap;gap:.3rem;width:100%}.tune-actions .icon-btn,.tune-actions .text-btn{font-size:.75rem;padding:.25rem .5rem}.library-filter-toolbar{align-items:flex-start}.inline-part-selector{gap:.25rem}.inline-part-pill{font-size:.7rem;padding:.15rem .45rem}.parts-badge{font-size:.65rem;padding:.15rem .4rem}}.custom-scrollbar::-webkit-scrollbar{width:6px}.custom-scrollbar::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.auth-signin-modal{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md),var(--shadow-glow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);display:flex;flex-direction:column;max-height:min(92vh,640px);overflow:hidden;width:100%}.auth-signin-modal-topbar{height:3px;flex-shrink:0;background:linear-gradient(90deg,var(--accent-primary),rgba(232,117,0,.35),rgba(30,58,95,.45))}.auth-signin-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.2rem 1.5rem 1rem;border-bottom:1px solid var(--card-border);background:linear-gradient(180deg,rgba(232,117,0,.07),transparent);flex-shrink:0}.auth-signin-header-text h3{margin:0 0 .3rem;font-size:1.35rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.auth-signin-tagline{margin:0;font-size:.8rem;color:var(--accent-primary);font-weight:600;letter-spacing:.04em;text-transform:uppercase}.auth-signin-body{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.auth-signin-body .google-sign-in-btn{width:100%;justify-content:center}.auth-signin-divider{display:flex;align-items:center;gap:1rem;font-size:.72rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.auth-signin-divider:before,.auth-signin-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(232,117,0,.25),transparent)}.auth-mode-toggle{display:flex;padding:3px;border-radius:var(--border-radius-md);background:#00000038;border:1px solid var(--card-border);gap:2px}.auth-mode-toggle button{flex:1;border:none;background:transparent;color:var(--text-secondary);padding:.55rem .65rem;border-radius:var(--border-radius-sm);font-size:.88rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.auth-mode-toggle button:hover:not(:disabled){color:var(--text-primary)}.auth-mode-toggle button.active{background:#e8750029;color:var(--accent-primary);font-weight:600;box-shadow:inset 0 0 0 1px #e8750066}.auth-mode-toggle button:disabled{opacity:.55;cursor:not-allowed}.auth-field{display:flex;flex-direction:column;gap:.35rem;text-align:left}.auth-field label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.auth-signin-error{margin:0;padding:.65rem .85rem;border-radius:var(--border-radius-sm);background:#ef44441a;border:1px solid rgba(239,68,68,.28);color:#fecaca;font-size:.875rem;line-height:1.45}.auth-signin-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.6rem;padding-top:.25rem}.auth-signin-hint{margin:0;font-size:.82rem;color:var(--text-secondary);line-height:1.5;text-align:left}button.action-btn.auth-outline-btn{background:#ffffff0a;border:1px solid var(--card-border);color:var(--text-primary);box-shadow:none}button.action-btn.auth-outline-btn:hover:not(:disabled){background:#e875001a;border-color:#e8750073;color:var(--text-primary);transform:translateY(-1px)}.sign-in-landing-wrap{max-width:520px;margin:0 auto 2rem;padding:0 .75rem}.sign-in-landing-hero{text-align:center;padding:2.5rem 1.75rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-md),0 0 40px #e875000f;position:relative;overflow:hidden}.sign-in-landing-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-primary),rgba(232,117,0,.35),var(--brand-blue, #4da3ff))}.sign-in-landing-logo{width:auto;max-width:min(100%,340px);height:auto;max-height:76px;object-fit:contain;object-position:center;margin:0 auto .85rem;display:block;filter:drop-shadow(0 6px 24px rgba(0,0,0,.45))}.stitch-first4-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.625rem 1.15rem;margin:0;border:none;border-radius:4px;background:var(--stitch-surface-highest);color:#fff;font-family:Space Grotesk,Inter,system-ui,sans-serif;font-size:.875rem;font-weight:600;letter-spacing:.03em;line-height:1.2;cursor:pointer;transition:box-shadow var(--transition-fast),color var(--transition-fast),background var(--transition-fast),transform var(--transition-fast)}.stitch-first4-btn:hover:not(:disabled):not(.stitch-first4-btn--active){box-shadow:0 0 15px 2px var(--stitch-amber-glow);color:var(--stitch-primary)}.stitch-first4-btn:focus-visible{outline:2px solid var(--stitch-primary);outline-offset:2px}.stitch-first4-btn--active{background:linear-gradient(135deg,var(--stitch-primary) 0%,var(--stitch-primary-deep) 100%);color:var(--stitch-on-primary);box-shadow:0 0 28px #ffd0a559;transform:scale(.98)}.stitch-first4-btn--active:hover:not(:disabled){color:var(--stitch-on-primary);box-shadow:0 0 32px #ffd0a573}.stitch-first4-clef{height:1.25rem;width:auto;object-fit:contain;flex-shrink:0;display:block;transition:opacity var(--transition-fast),filter var(--transition-fast)}.stitch-first4-btn:not(.stitch-first4-btn--active) .stitch-first4-clef{filter:invert(1) brightness(1.35);opacity:.48}.stitch-first4-btn:hover:not(:disabled):not(.stitch-first4-btn--active) .stitch-first4-clef{opacity:.68}.stitch-first4-btn--active .stitch-first4-clef{filter:drop-shadow(0 0 10px var(--stitch-primary));opacity:.78}.stitch-first4-btn--compact{padding:.3rem .55rem;gap:.28rem;font-size:.72rem}.stitch-first4-btn--compact .stitch-first4-clef{height:.95rem}.stitch-first4-label{white-space:nowrap}.stitch-tool-btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.55rem 1rem;margin:0;border:none;border-radius:4px;background:var(--stitch-surface-highest);color:#fff;font-family:Inter,system-ui,sans-serif;font-size:.8125rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:box-shadow var(--transition-fast),color var(--transition-fast),background var(--transition-fast),transform var(--transition-fast)}.stitch-tool-btn:hover:not(:disabled):not(.stitch-tool-btn--active){box-shadow:0 0 15px 2px var(--stitch-amber-glow);color:var(--stitch-primary)}.stitch-tool-btn:focus-visible{outline:2px solid var(--stitch-primary);outline-offset:2px}.stitch-tool-btn:disabled{opacity:.55;cursor:not-allowed}.stitch-tool-btn--active{background:linear-gradient(135deg,var(--stitch-primary) 0%,var(--stitch-primary-deep) 100%);color:var(--stitch-on-primary);box-shadow:0 0 24px #ffd0a559;transform:scale(.98)}.stitch-tool-btn--active:hover:not(:disabled){color:var(--stitch-on-primary)}.sign-in-landing-hero h2{margin:0 0 .5rem;font-size:1.45rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.sign-in-landing-lead{color:var(--text-secondary);font-size:.98rem;line-height:1.6;margin:0 auto 1.65rem;max-width:26rem}.sign-in-landing-actions{display:flex;flex-direction:column;gap:.75rem;align-items:stretch}@media(min-width:480px){.sign-in-landing-actions{flex-direction:row;flex-wrap:wrap;justify-content:center}.sign-in-landing-actions .action-btn{min-width:12rem}}.sign-in-card--accent-top{position:relative;overflow:hidden}.sign-in-card--accent-top:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-primary),rgba(232,117,0,.3));border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}
