:root{--bg: #faf7f2;--ink: #2a2622;--muted: #7a726a;--accent: #e26d4f;--accent-ink: #fff;--card: #fff;--border: #e6dfd5;--danger: #e63946;--radius: 12px;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg)}*{box-sizing:border-box}body{margin:0;transition:background .2s ease}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;background:var(--accent);color:var(--accent-ink);border:none;padding:.55rem 1rem;border-radius:var(--radius);cursor:pointer}button.secondary{background:var(--card);color:var(--ink);border:1px solid var(--border)}button.secondary.danger-active{background:var(--danger);color:#fff;border-color:var(--danger)}button:disabled{opacity:.5;cursor:not-allowed}input,textarea{font:inherit;width:100%;padding:.55rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);color:var(--ink)}textarea{min-height:6rem;resize:vertical}.app{max-width:1100px;margin:0 auto;padding:1.5rem;overflow-x:clip}.app header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1.5rem;position:relative}.app h1{margin:0;font-size:1.6rem}.app h1 a,.app h1 a:hover{text-decoration:none;color:inherit}.app .brand{color:var(--accent)}.app.mode-tunes{--accent: #7a4ed1;--accent-ink: #fff}.header-brand{display:flex;align-items:baseline;gap:1rem}.app header:has(.header-brand-dual){justify-content:center}.header-brand-dual{gap:1.25rem}.header-brand-dual h1[data-target=book] .brand{color:#e26d4f}.header-brand-dual h1[data-target=tunes] .brand{color:#7a4ed1}.header-brand-divider{align-self:stretch;width:1px;background:var(--border)}.mode-switch-link{color:var(--ink);text-decoration:none;font-weight:600;font-size:1rem}.mode-switch-link:hover{text-decoration:none;opacity:.75}.mode-switch-link[data-target=book] .brand{color:#e26d4f}.mode-switch-link[data-target=tunes] .brand{color:#7a4ed1}.app-switch-inline{display:flex;align-items:baseline}.header-nav-app-switch{display:none;color:var(--ink);text-decoration:none;font-weight:600;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);width:100%}.header-nav-app-switch:hover{text-decoration:none;border-color:var(--muted)}.header-nav-app-switch[data-target=book] .brand{color:#e26d4f}.header-nav-app-switch[data-target=tunes] .brand{color:#7a4ed1}.tune-editor,.tune-viewer{display:flex;flex-direction:column;gap:1rem}.tune-editor-topbar,.tune-viewer-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.tune-viewer-header>div:first-child{flex:1}.tune-title-input{flex:1;font-size:1.2rem;font-weight:600}.tune-privacy-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;color:var(--muted)}.tune-privacy-toggle input{width:auto}.tune-cover-control{display:flex;align-items:center;gap:.25rem}.tune-cover-control>button:first-child{display:flex;align-items:center;padding:.3rem .6rem}.tune-cover-control img{width:1.6rem;height:1.6rem;object-fit:cover;border-radius:4px;display:block}.tune-cover-clear{padding:.25rem .5rem;line-height:1}.tune-transport{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;padding:.75rem 1rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);position:sticky;top:.5rem;z-index:10;box-shadow:0 4px 12px #0000000f}.tune-play-btn{min-width:6rem;font-weight:600}.tune-transport-control{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--muted)}.tune-transport-control input[type=range]{width:8rem}.tune-transport-value{min-width:2.5rem;text-align:right;color:var(--ink);font-variant-numeric:tabular-nums}.tune-transport-more{display:none;padding:.35rem .7rem;font-size:.85rem}.tune-transport-extra{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}.tune-bars-input{width:3.5rem;text-align:center}.tune-transport select,.tune-editor select,.tune-viewer select{appearance:none;-webkit-appearance:none;-moz-appearance:none;font:inherit;color:var(--ink);background-color:var(--card);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%237a726a' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right .6rem center;border:1px solid var(--border);border-radius:var(--radius);padding:.35rem 1.7rem .35rem .6rem;cursor:pointer}.tune-transport select:focus-visible,.tune-editor select:focus-visible,.tune-viewer select:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.tune-transport select:disabled,.tune-viewer select:disabled{opacity:.6;cursor:default}.instrument-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem 1rem;display:flex;flex-direction:column;gap:.6rem}.instrument-panel.is-muted .sequencer,.instrument-panel.is-muted .sample-palette,.instrument-panel.is-muted .sample-grid{opacity:.45}.instrument-panel-header{display:flex;align-items:center;gap:.5rem}.instrument-add-row{display:flex;font-size:.9rem;color:var(--muted)}.instrument-add-row label{display:inline-flex;align-items:center;gap:.5rem}.sequencer{display:flex;flex-direction:column;gap:.35rem}.sequencer-row{display:flex;align-items:center;gap:.5rem}.sequencer-row.is-muted{opacity:.45}.sequencer-row-controls{display:flex;align-items:center;gap:.2rem;width:6.5rem;flex:0 0 6.5rem}.sequencer-row-label{flex:1;font-size:.8rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sequencer-row-label-input{flex:1;font-size:.8rem;padding:.25rem .4rem;min-width:0}.sequencer-row-btn{padding:.15rem .35rem;font-size:.7rem;flex:0 0 auto}.matrix-scroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding:5px 6px}.sequencer-cells{display:grid;grid-template-columns:repeat(var(--sequencer-steps, 16),minmax(20px,1fr));gap:4px;flex:1}.sequencer-cell{aspect-ratio:1;min-width:0;padding:0;border:1px solid var(--border);border-radius:6px;background:var(--bg);cursor:pointer;transition:background 80ms ease,transform 80ms ease}.sequencer[data-kind=pitched],.sequencer[data-kind=pitched] .sequencer-cells{gap:2px}.sequencer[data-kind=pitched] .sequencer-cell{aspect-ratio:auto;height:1.1rem;border-radius:4px}.sequencer[data-kind=pitched] .sequencer-row-label{font-size:.8rem;font-variant-numeric:tabular-nums;text-align:right}.sequencer[data-kind=pitched] .sequencer-row-btn{padding:.15rem .4rem;font-size:.75rem}.sequencer-cell:hover:not(:disabled){border-color:var(--accent)}.sequencer-cell.is-measure-alt:not(.is-on),.sample-grid-cell.is-measure-alt:not(.is-on){background:#ebe4d6}.sequencer-cell.is-on{background:var(--accent);border-color:var(--accent)}.sequencer-cell.is-playing{transform:scale(1.08);box-shadow:0 0 0 2px var(--accent)}.sequencer-cell:disabled{cursor:default}.tune-viewer-actions,.tune-viewer-mod-actions{display:flex;gap:.5rem;flex-wrap:wrap}.tune-viewer-mod-actions{border-top:1px solid var(--border);padding-top:1rem;margin-top:.5rem}.instrument-kind-badge{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:.15rem .5rem;border:1px solid var(--border);border-radius:999px}.pitched-controls{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.85rem;color:var(--muted)}.pitched-controls label{display:inline-flex;align-items:center;gap:.4rem}.pitched-controls input[type=range],.sample-controls input[type=range]{width:7rem}.velocity-value{min-width:2.5rem;text-align:right;font-variant-numeric:tabular-nums;color:var(--ink)}.add-instrument-bar{display:flex;gap:.5rem;align-items:center;padding:.75rem 0;color:var(--muted);font-size:.9rem}.remix-banner{display:flex;align-items:center;gap:.5rem;padding:.6rem .9rem;background:var(--card);border:1px solid var(--accent);border-radius:var(--radius);font-size:.95rem}.remix-icon{font-size:1.1rem;color:var(--accent)}.remix-link{color:var(--ink)}.remix-deleted-note{color:var(--muted);font-style:italic}.library-card-remix{margin-top:.25rem;font-size:.8rem;color:var(--muted)}.sample-controls{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.85rem;color:var(--muted)}.sample-controls label{display:inline-flex;align-items:center;gap:.4rem}.sample-palette{display:flex;flex-wrap:wrap;gap:.5rem}.sample-palette-empty{color:var(--muted);font-size:.85rem;font-style:italic}.sample-palette-item{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .5rem .25rem .25rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);color:var(--ink);cursor:pointer;font:inherit}.sample-palette-item:hover{border-color:var(--muted)}.sample-palette-item.is-selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.sample-palette-swatch{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:50%;color:#fff;font-weight:600;font-size:.75rem;text-transform:uppercase}.sample-palette-label{font-size:.85rem;max-width:8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sample-palette-remove-btn{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;padding:0;border-radius:999px;background:var(--card);border:1px solid var(--border);color:var(--muted);font-size:.85rem;line-height:1;cursor:pointer}.sample-palette-remove-btn:hover{color:var(--danger);border-color:var(--danger)}.sample-recorder{display:flex;flex-direction:column;gap:.5rem}.sample-recorder-recording{background:var(--danger);color:#fff}.sample-recorder-preview{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.sample-recorder-preview audio{max-width:16rem}.sample-recorder-label-input{width:8rem}.sample-recorder-error{font-size:.85rem}.sample-grid{display:flex;flex-direction:column;gap:4px;margin-left:7rem}.sample-grid-slot-row{display:grid;grid-template-columns:repeat(var(--sequencer-steps, 16),minmax(20px,1fr));gap:4px}.sample-grid-cell{aspect-ratio:1;min-width:0;padding:0;border:1px solid var(--border);border-radius:6px;background:var(--bg);cursor:pointer;font-size:.7rem;color:#fff;font-weight:600;text-transform:uppercase;transition:background 80ms ease,transform 80ms ease}.sample-grid-cell:hover:not(:disabled){border-color:var(--accent)}.sample-grid-cell.is-playing{transform:scale(1.08);box-shadow:0 0 0 2px var(--accent)}.sample-grid-cell:disabled{cursor:default}.sample-grid-cell-label{pointer-events:none;color:transparent;-webkit-background-clip:text;background-clip:text}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.library-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.library-card .cover{aspect-ratio:4 / 3;background:var(--bg);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--muted)}.library-card .cover img{width:100%;height:100%;object-fit:cover}.library-card .cover-button{padding:0;border:none;cursor:pointer;font:inherit}.library-card .cover-button:hover{filter:brightness(1.05)}.library-card .cover-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.library-section-heading{margin:1.25rem 0 .6rem;font-size:1rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;opacity:.85}.library-section-heading:first-of-type{margin-top:.5rem}.library-card .title{font-weight:600}.library-card .actions{display:flex;flex-wrap:wrap;gap:.4rem}.library-card .actions button{flex:1;padding:.4rem .5rem;font-size:.85rem}.editor-toolbar{display:flex;gap:.5rem;align-items:center;margin-bottom:1.25rem}.link-button{display:inline-block;padding:.55rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);color:var(--ink);text-decoration:none}.link-button:hover{text-decoration:none}.editor{display:grid;grid-template-columns:220px 1fr;gap:1.5rem;align-items:start}.editor .page-list{display:flex;flex-direction:column;gap:.5rem}.editor .page-thumb{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:.5rem;cursor:pointer;text-align:left;color:var(--ink);font-size:.85rem}.editor .page-thumb.active{border-color:var(--accent)}.editor .page-thumb .num{color:var(--muted);font-size:.75rem}.book-stage{display:flex;justify-content:center;padding:1.5rem 0;width:100%}.book-page{position:relative;width:min(560px,100%);aspect-ratio:3 / 4;container-type:inline-size;background:linear-gradient(180deg,#fffdf7,#fbf6e9);border-radius:4px 14px 14px 4px;box-shadow:0 1px #0000000a,0 12px 30px -10px #00000059,inset 12px 0 18px -16px #00000073;border:1px solid #e8dec5;overflow:hidden}.book-page:before{content:"";position:absolute;left:0;top:0;bottom:0;width:14px;background:linear-gradient(90deg,rgba(0,0,0,.18),transparent);pointer-events:none;z-index:1}.book-page.cover{color:var(--cover-ink, #fff7e8);padding:5cqw;display:flex;flex-direction:column;gap:2.86cqw;border:1px solid rgba(0,0,0,.4);box-shadow:0 2px #00000014,0 18px 40px -10px #00000080,inset 12px 0 18px -16px #0000008c,inset 0 0 0 8px #ffffff0a,inset 0 0 0 9px #00000040}.book-page.cover:before{background:linear-gradient(90deg,rgba(0,0,0,.35),transparent)}.image-slot{background:color-mix(in srgb,var(--cover-ink, #fff) 8%,transparent);border:1px dashed color-mix(in srgb,var(--cover-ink, #fff) 35%,transparent);border-radius:6px;display:flex;align-items:center;justify-content:center;color:color-mix(in srgb,var(--cover-ink, #fff) 70%,transparent);overflow:hidden;cursor:pointer;flex:1;min-height:0}.image-slot img{width:100%;height:100%;object-fit:cover}.cover-title,.cover-author{background:transparent;border:1px dashed transparent;color:inherit;text-align:center;padding:1.14cqw 1.71cqw;border-radius:4px}.cover-title{font-family:Georgia,Times New Roman,serif;font-size:5.71cqw;font-weight:700;letter-spacing:.02em}.cover-author{font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:3.14cqw;opacity:.92}.cover-title:hover,.cover-author:hover,.cover-title:focus,.cover-author:focus{border-color:color-mix(in srgb,var(--cover-ink, #fff) 45%,transparent);outline:none}.cover-title::placeholder,.cover-author::placeholder{color:color-mix(in srgb,var(--cover-ink, #fff) 55%,transparent)}.cover-color{display:flex;align-items:center;justify-content:center;gap:1.43cqw;font-size:2.43cqw;opacity:.9}.cover-color input[type=color]{width:5.71cqw;height:5cqw;padding:0;border:1px solid color-mix(in srgb,var(--cover-ink, #fff) 50%,transparent);border-radius:6px;cursor:pointer;background:none}.book-page .reset-btn{font-size:2.43cqw;padding:.36cqw 1.07cqw;border-radius:1.07cqw}.book-page .pattern-picker{gap:.71cqw}.book-page .pattern-swatch{width:4.29cqw;height:4.29cqw;border-radius:1.07cqw}.reset-btn{background:transparent;border:1px solid var(--border);color:inherit;padding:.1rem .4rem;font-size:.95rem;border-radius:6px;cursor:pointer;line-height:1}.reset-btn.on-cover{border-color:color-mix(in srgb,var(--cover-ink, #fff) 50%,transparent)}.pattern-picker{display:inline-flex;gap:4px}.pattern-swatch{width:24px;height:24px;padding:0;border:1px solid var(--border);border-radius:6px;cursor:pointer;background-color:transparent}.pattern-swatch.active{outline:2px solid var(--accent);outline-offset:1px}.cover-image-static{width:100%;flex:1;min-height:0;object-fit:cover;border-radius:6px}.cover-title-static{font-family:Georgia,serif;font-size:5.71cqw;font-weight:700;text-align:center;margin-top:1.43cqw}.cover-author-static{font-family:Georgia,serif;font-style:italic;font-size:2.86cqw;text-align:center;opacity:.92}.line-element{position:absolute;display:flex;align-items:center;gap:.25rem;z-index:2;pointer-events:none}.line-element>*{pointer-events:auto}.line-input{flex:1;display:block;box-sizing:border-box;background:transparent;border:none;border-bottom:.36cqw solid #6a5b3e;border-radius:0;padding:.7cqw 1.4cqw 0;font-family:Georgia,Times New Roman,serif;font-size:3.14cqw;line-height:1.4;color:#2a2622;width:auto;min-height:0;resize:none;overflow:hidden;vertical-align:top;field-sizing:content}.line-input:focus{outline:none;border-bottom-color:var(--accent)}.line-input:disabled,.line-input[readonly]{color:#2a2622;-webkit-text-fill-color:#2a2622;opacity:1;cursor:default;border-bottom:none}.image-element{position:absolute;border:1px dashed rgba(0,0,0,.25);background:#0000000a;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;z-index:2}.image-element img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.image-placeholder{color:var(--muted);font-size:2.43cqw;pointer-events:none}.image-pick-btn{position:absolute;top:.71cqw;right:.71cqw;background:#ffffffeb;color:var(--ink);border:1px solid var(--border);border-radius:4px;padding:.43cqw 1.29cqw;font-size:2.14cqw;cursor:pointer}.image-delete-btn{position:absolute;bottom:.71cqw;left:.71cqw;background:#ffffffeb;color:var(--danger);border:1px solid var(--border);border-radius:4px;padding:.14cqw 1.14cqw;font-size:2.14cqw;cursor:pointer;line-height:1.2}.image-delete-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.handle{width:3.93cqw;height:3.93cqw;display:inline-flex;align-items:center;justify-content:center;background:#ffffffeb;border:1px solid var(--border);border-radius:4px;font-size:2.43cqw;-webkit-user-select:none;user-select:none;touch-action:none;color:var(--ink)}.handle-move{cursor:grab}.handle-resize-line{cursor:ew-resize}.handle-move-box{position:absolute;top:.71cqw;left:.71cqw;cursor:grab}.handle-resize-box{position:absolute;bottom:.71cqw;right:.71cqw;cursor:nwse-resize}.handle-delete{cursor:pointer;color:var(--danger);padding:0}.handle-delete:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.page-number{position:absolute;bottom:2.14cqw;right:2.86cqw;font-family:Georgia,serif;font-style:italic;color:var(--muted);font-size:2.57cqw;z-index:1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:10}.modal{background:var(--card);border-radius:var(--radius);padding:1.25rem;width:min(720px,92vw);max-height:86vh;display:flex;flex-direction:column;gap:.75rem}.modal .results{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem;overflow-y:auto;padding:.25rem}.modal .results button{padding:0;background:none;border:1px solid var(--border);border-radius:8px;overflow:hidden;aspect-ratio:1;cursor:pointer}.modal .results img{width:100%;height:100%;object-fit:cover;display:block}.viewer{display:flex;flex-direction:column;align-items:center;gap:1rem}.viewer .nav{display:flex;gap:1rem;align-items:center}.viewer .nav .count{color:var(--muted)}.header-nav{display:flex;align-items:baseline;gap:1rem;font-size:.9rem}.header-menu-toggle{display:none;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;padding:.4rem .7rem}.header-user-name{color:inherit;text-decoration:none}.header-user-name:hover{text-decoration:underline}.role-badge{display:inline-block;margin-left:.4rem;padding:.05rem .4rem;border-radius:999px;background:var(--accent);color:var(--accent-ink);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.library-controls{display:flex;gap:.75rem;align-items:center}.library-bg-label{display:flex;align-items:center;gap:.4rem;font-size:.9rem}.library-bg-label input[type=color]{width:32px;height:28px;padding:0;border:1px solid var(--border);border-radius:6px}.library-card.is-delisted{opacity:.7}.badge{display:inline-block;margin-left:.4rem;padding:.05rem .4rem;border-radius:999px;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;vertical-align:middle}.badge-private{background:#4a3f6a;color:#fff}.badge-delisted{background:var(--danger);color:#fff}.badge-pinned{background:#b8742a;color:#fff}.badge-draft{background:#6b7280;color:#fff}.save-status{font-size:.85rem;color:var(--muted);align-self:center;white-space:nowrap}.banner{border-radius:var(--radius);padding:.7rem 1rem;margin-bottom:1rem;font-size:.9rem}.banner-delisted{background:#e639461f;border:1px solid rgba(230,57,70,.4);color:#6a1d24}.banner-admin{background:#e26d4f26;border:1px solid rgba(226,109,79,.5);color:#5a3826}.banner-draft{background:#6b72801f;border:1px solid rgba(107,114,128,.45);color:#3f4654}.auth-card{max-width:380px;margin:2rem auto;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.auth-card h2{margin-top:0}.auth-card form{display:flex;flex-direction:column;gap:.75rem}.auth-card label{display:flex;flex-direction:column;gap:.3rem;font-size:.9rem}.auth-card button{margin-top:.5rem}.auth-aside{color:var(--muted);font-size:.9rem;margin-top:1rem}.form-error{color:var(--danger);background:#e6394614;border:1px solid rgba(230,57,70,.3);border-radius:8px;padding:.5rem .75rem;font-size:.9rem}.form-success{color:#1a6b3a;background:#228b5814;border:1px solid rgba(34,139,88,.3);border-radius:8px;padding:.5rem .75rem;font-size:.9rem}.profile-page{max-width:560px;margin:1rem auto;display:flex;flex-direction:column;gap:1rem}.profile-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem}.profile-card h3{margin:0 0 .75rem}.profile-card form{display:flex;flex-direction:column;gap:.75rem}.profile-card label{display:flex;flex-direction:column;gap:.3rem;font-size:.9rem}.profile-card button{align-self:flex-start;margin-top:.25rem}.profile-meta{margin:0;display:grid;grid-template-columns:max-content 1fr;gap:.4rem 1rem;font-size:.95rem}.profile-meta dt{color:var(--muted)}.profile-meta dd{margin:0}.profile-hint{color:var(--muted);font-size:.85rem}.page-loading{color:var(--muted);padding:1rem}.admin{display:grid;grid-template-columns:180px minmax(0,1fr);gap:1.5rem}.admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-nav{display:flex;flex-direction:column;gap:.25rem}.admin-nav-toggle{display:none}.admin-nav a{padding:.5rem .75rem;border-radius:8px;color:var(--ink);border:1px solid transparent}.admin-nav a.active{background:var(--card);border-color:var(--border);color:var(--accent)}.admin-body{min-width:0}.admin-row{display:flex;gap:.75rem;align-items:center;margin-bottom:.75rem}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem;background:var(--card);border-radius:var(--radius);overflow:hidden}.admin-table th,.admin-table td{text-align:left;padding:.55rem .75rem;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table th{background:var(--bg);font-weight:600}.admin-table tr:last-child td{border-bottom:none}.row-actions{white-space:nowrap}.row-actions>*+*{margin-left:.4rem}.filter-bar{display:flex;gap:.4rem;flex-wrap:wrap;margin:.5rem 0 .75rem}.filter-chip{background:var(--card);color:var(--ink, inherit);border:1px solid var(--border);border-radius:999px;padding:.25rem .75rem;font-size:.85rem;cursor:pointer}.filter-chip.active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.status-banned{color:var(--danger);font-weight:600}.status-pwreset{color:var(--muted);font-size:.85rem}.audit-meta{font-size:.75rem;color:var(--muted);white-space:pre-wrap;word-break:break-word}.modal-tabs{display:flex;gap:.4rem;align-items:center}.modal-tab{background:transparent;color:var(--muted);border:1px solid transparent;padding:.4rem .75rem;border-radius:8px}.modal-tab.active{background:var(--card);border-color:var(--border);color:var(--ink)}.upload-pane{display:flex;flex-direction:column;gap:.75rem;padding:1rem 0}.privacy-toggle{display:flex;gap:.4rem;align-items:center;font-size:.85rem;color:var(--ink);margin-top:.75rem;padding:.5rem;border:1px solid var(--border);border-radius:8px;background:var(--card)}.privacy-toggle input[type=checkbox]{width:auto}.layout-picker{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;padding:.5rem;background:var(--card);border:1px solid var(--border);border-radius:8px;margin-top:.25rem}.layout-picker button{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.4rem .25rem;background:transparent;color:var(--ink);border:1px solid var(--border);border-radius:6px;font-size:.7rem;text-align:center}.layout-picker button:hover{background:var(--bg)}.layout-thumb{position:relative;width:36px;aspect-ratio:3 / 4;background:#fffdf7;border:1px solid var(--border);border-radius:2px;overflow:hidden}.layout-thumb:before,.layout-thumb:after{content:"";position:absolute;pointer-events:none}.layout-thumb.layout-image-top:before{top:8%;right:8%;bottom:30%;left:8%;background:#d8d2c3;border-radius:1px}.layout-thumb.layout-image-top:after{left:12%;right:12%;bottom:18%;height:1.5px;background:#6a5b3e}.layout-thumb.layout-three-lines{background:linear-gradient(#6a5b3e,#6a5b3e) no-repeat 12% 32% / 76% 1.5px,linear-gradient(#6a5b3e,#6a5b3e) no-repeat 12% 52% / 76% 1.5px,linear-gradient(#6a5b3e,#6a5b3e) no-repeat 12% 72% / 76% 1.5px,#fffdf7}.layout-thumb.layout-full-image:before{top:0;right:0;bottom:0;left:0;background:#d8d2c3}.print-only{display:none}@media print{body *{visibility:hidden}.print-only,.print-only *{visibility:visible}.print-only{display:block;position:absolute;top:0;right:0;bottom:0;left:0}@page{margin:0}}.invite-print{width:100%;min-height:100vh;box-sizing:border-box;padding:2.5cm 2cm;background:var(--bg);color:var(--ink);font-family:Georgia,Times New Roman,serif;display:flex;flex-direction:column}.invite-print-letterhead{text-align:center;border-bottom:2px solid var(--accent);padding-bottom:1rem;margin-bottom:2rem}.invite-print-letterhead h1{margin:0;font-size:3rem;letter-spacing:.02em}.invite-print-letterhead .brand{color:var(--accent)}.invite-print-tagline{margin:.4rem 0 0;color:var(--muted);font-style:italic;letter-spacing:.08em;text-transform:lowercase}.invite-print-body{flex:1;font-size:1.05rem;line-height:1.55}.invite-print-body h2{font-size:2rem;margin:0 0 1rem;color:var(--accent)}.invite-print-body p{margin:0 0 1rem}.invite-print-code-block{margin:2rem 0;padding:1.25rem 1.5rem;border:1px dashed var(--accent);border-radius:var(--radius);text-align:center;background:var(--card)}.invite-print-code-label{font-family:system-ui,sans-serif;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem}.invite-print-code{font-family:Courier New,Courier,monospace;font-size:1.6rem;font-weight:700;letter-spacing:.04em;word-spacing:.2em;color:var(--ink)}.invite-print-qr-row{display:flex;gap:1.5rem;align-items:center;margin-top:1.5rem}.invite-print-qr{width:160px;height:160px;flex-shrink:0;border:1px solid var(--border);background:#fff;padding:6px}.invite-print-qr-copy{flex:1;min-width:0}.invite-print-qr-heading{font-weight:700;margin:0 0 .4rem}.invite-print-link{font-family:Courier New,Courier,monospace;font-size:.85rem;word-break:break-all;margin:0 0 .6rem;color:var(--ink)}.invite-print-fine{font-size:.85rem;color:var(--muted);margin:0}.invite-print-footer{margin-top:3rem;text-align:center;border-top:1px solid var(--border);padding-top:1rem;color:var(--muted);font-style:italic}.app-footer{margin-top:3rem;padding:1.5rem 0 .5rem;border-top:1px solid var(--border);text-align:center;font-size:.85rem;color:var(--muted)}.app-footer a{color:inherit;text-decoration:underline}.app-footer a:hover{color:var(--accent)}.contact-captcha{margin:.5rem 0}@media (max-width: 768px){.app{padding:1rem}.app header{gap:.6rem 1rem;margin-bottom:1rem}.app h1{font-size:1.3rem}.header-menu-toggle{display:inline-flex}.header-nav{display:none}.header-nav.is-open{display:flex;flex-direction:column;align-items:flex-start;position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;gap:.85rem;box-shadow:0 8px 24px #0000001f;z-index:30}.app-switch-inline{display:none}.header-nav-app-switch{display:block}.header-brand-dual{flex-wrap:wrap;justify-content:center}.editor{grid-template-columns:1fr;gap:1rem}.editor-toolbar{flex-wrap:wrap}.book-stage{padding:.75rem 0}.library-controls{flex-wrap:wrap}.library-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.admin{display:block}.admin-nav-toggle{display:inline-flex;margin-bottom:.75rem}.admin-nav{display:none;margin-bottom:1rem}.admin-nav.is-open{display:flex}.tune-editor-topbar .tune-title-input{flex:1 1 100%}.tune-transport{gap:.6rem 1rem;padding:.6rem .75rem}.tune-transport-more{display:inline-flex}.tune-transport-extra{display:none;flex-basis:100%}.tune-transport-extra.is-open{display:flex;flex-wrap:wrap;gap:.6rem 1rem}.tune-transport-control input[type=range],.pitched-controls input[type=range],.sample-controls input[type=range]{width:6rem}.add-instrument-bar{flex-wrap:wrap}}@media (max-width: 420px){.library-grid{grid-template-columns:1fr 1fr}}
