:root{--cream: #faf8f4;--ink: #1a1714;--ink-soft: #2c2620;--accent: #b8975a;--accent-light: #d4b47a;--accent-pale: rgba(184, 151, 90, .12);--text: #2c2620;--text-dim: #8a7d70;--border: rgba(26, 23, 20, .08);--border-strong: rgba(26, 23, 20, .16);--surface: #ffffff;--surface-alt: #f4f1eb;--font-display: "Cormorant Garamond", serif;--font-body: "DM Sans", sans-serif;--font-mono: "DM Mono", monospace;--font-magazine: "Playfair Display", serif;--font-bebas: "Bebas Neue", sans-serif;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .12);--radius-sm: 3px;--radius-md: 6px;--radius-lg: 12px;--rail-w: 260px;--settings-w: 320px;--tray-h: 112px;--topbar-h: 56px}body.theme-gold{--accent: #b8975a;--accent-light: #d4b47a;--accent-pale: rgba(184,151,90,.12)}body.theme-blush{--accent: #c48a7f;--accent-light: #e3b2a6;--accent-pale: rgba(196,138,127,.12)}body.theme-sage{--accent: #7d8f6a;--accent-light: #a8b892;--accent-pale: rgba(125,143,106,.12)}body.theme-ink{--accent: #1a1714;--accent-light: #4a4440;--accent-pale: rgba(26,23,20,.08)}body.theme-plum{--accent: #6b4a5f;--accent-light: #96728a;--accent-pale: rgba(107,74,95,.12)}body.theme-ocean{--accent: #47708a;--accent-light: #7a9bb3;--accent-pale: rgba(71,112,138,.12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;background:var(--cream)}body{background:var(--cream);color:var(--text);font-family:var(--font-body);font-size:14px;line-height:1.5;overflow:hidden;height:100vh;-webkit-font-smoothing:antialiased}button{font-family:inherit;color:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;color:inherit}.fatal{padding:32px;color:#b00020;font-family:var(--font-mono)}.kbd{font-family:var(--font-mono);font-size:10px;padding:2px 6px;border:1px solid var(--border);border-radius:3px;color:var(--text-dim);background:var(--surface)}.hr{height:1px;background:var(--border);width:100%}.spacer{flex:1}.muted{color:var(--text-dim)}.mono{font-family:var(--font-mono)}.display{font-family:var(--font-display)}.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border:1px solid var(--border);border-radius:20px;font-size:10px;font-family:var(--font-mono);color:var(--text-dim);letter-spacing:.5px;text-transform:uppercase}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:12px;font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;color:var(--text);transition:all .15s ease;white-space:nowrap}.btn:hover{border-color:var(--accent);color:var(--accent)}.btn.primary{background:var(--ink);color:var(--cream);border-color:var(--ink)}.btn.primary:hover{background:var(--accent);border-color:var(--accent);color:#fff}.btn.ghost{background:transparent;border-color:transparent}.btn.ghost:hover{background:var(--accent-pale);color:var(--accent)}.btn.small{padding:5px 10px;font-size:10px;letter-spacing:.5px}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}#app{height:100vh;width:100vw;display:grid;grid-template-rows:var(--topbar-h) 1fr var(--tray-h);grid-template-columns:var(--rail-w) 1fr;grid-template-areas:"topbar topbar" "rail   stage" "tray   tray";background:var(--cream)}.topbar{grid-area:topbar;display:flex;align-items:center;gap:16px;padding:0 20px;background:var(--surface);border-bottom:1px solid var(--border);z-index:10}.tb-brand{display:flex;align-items:baseline;gap:8px;font-family:var(--font-display);font-size:22px;font-weight:400;letter-spacing:3px;color:var(--ink)}.tb-brand span{color:var(--accent);font-style:italic;font-weight:600}.tb-sub{font-size:10px;font-family:var(--font-mono);letter-spacing:2px;color:var(--text-dim);text-transform:uppercase}.tb-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.rail{grid-area:rail;background:var(--surface-alt);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.rail-head{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px}.rail-title{font-size:10px;font-family:var(--font-mono);letter-spacing:2px;color:var(--text-dim);text-transform:uppercase}.rail-count{font-size:11px;font-family:var(--font-mono);color:var(--accent)}.rail-filters{padding:8px 14px;display:flex;flex-wrap:wrap;gap:4px;border-bottom:1px solid var(--border)}.rail-filter{padding:3px 8px;font-size:9px;font-family:var(--font-mono);letter-spacing:1px;border:1px solid var(--border);border-radius:20px;color:var(--text-dim);background:var(--surface);text-transform:uppercase;cursor:pointer}.rail-filter.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}.rail-filter:hover{border-color:var(--accent);color:var(--accent)}.rail-filter.active:hover{background:var(--accent);border-color:var(--accent);color:#fff}.rail-grid{flex:1;overflow-y:auto;padding:10px;display:grid;grid-template-columns:repeat(2,1fr);gap:8px;align-content:start}.rail-thumb{position:relative;aspect-ratio:1 / 1;border-radius:var(--radius-sm);overflow:hidden;cursor:grab;background:var(--border);border:2px solid transparent;transition:border-color .15s}.rail-thumb:hover{border-color:var(--accent-light)}.rail-thumb.selected{border-color:var(--accent)}.rail-thumb.used{opacity:.5}.rail-thumb.added{animation:rail-thumb-pulse .42s ease-out}@keyframes rail-thumb-pulse{0%{transform:scale(1);border-color:var(--accent)}40%{transform:scale(.94);border-color:var(--accent)}to{transform:scale(1);border-color:transparent}}.rail-thumb img,.rail-thumb video{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.rail-thumb .badge{position:absolute;top:4px;right:4px;background:#b8975ae6;color:#fff;font-size:8px;font-family:var(--font-mono);letter-spacing:1px;padding:2px 5px;border-radius:2px}.rail-thumb .orient-dot{position:absolute;top:4px;left:4px;width:6px;height:6px;border-radius:50%;background:#ffffffb3}.rail-thumb[data-orient=portrait] .orient-dot{background:var(--accent)}.rail-thumb[data-orient=landscape] .orient-dot{background:var(--accent-light)}.rail-empty{padding:32px 20px;text-align:center;color:var(--text-dim);font-size:12px;font-family:var(--font-mono);letter-spacing:.5px}.rail-empty .ico{font-size:28px;opacity:.3;margin-bottom:8px}.stage{grid-area:stage;display:flex;flex-direction:column;overflow:hidden;background:var(--cream);position:relative}.stage-tabs{display:flex;align-items:center;gap:4px;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--surface);overflow-x:auto;flex-shrink:0;min-height:44px}.stage-tab{padding:6px 14px;font-size:10px;font-family:var(--font-mono);letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);border:1px solid var(--border);border-radius:3px;background:transparent;cursor:pointer;white-space:nowrap;transition:all .15s}.stage-tab.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}.stage-tab:hover:not(.active){border-color:var(--accent);color:var(--accent)}.stage-tab.add{font-size:14px;padding:4px 10px;color:var(--accent);border-style:dashed}.stage-toolbar{display:flex;align-items:center;gap:6px;padding:6px 16px;border-bottom:1px solid var(--border);background:var(--surface);overflow-x:auto;flex-shrink:0}.stage-toolbar .sep{width:1px;height:18px;background:var(--border);margin:0 4px}.stage-canvas-wrap{flex:1;position:relative;overflow:hidden;background:linear-gradient(45deg,var(--border) 25%,transparent 25%),linear-gradient(-45deg,var(--border) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--border) 75%),linear-gradient(-45deg,transparent 75%,var(--border) 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,10px 0;background-color:var(--surface-alt)}.stage-scroll{position:absolute;inset:0;overflow:auto}.stage-center{min-width:100%;min-height:100%;padding:24px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;width:max-content;height:max-content}.stage-center canvas{box-shadow:var(--shadow-lg);display:block}.tray{grid-area:tray;background:var(--ink);border-top:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 16px;overflow:hidden;color:var(--cream)}.tray-title{font-family:var(--font-display);font-size:16px;letter-spacing:2px;color:var(--cream);flex-shrink:0;padding-right:12px;border-right:1px solid rgba(255,255,255,.08)}.tray-title span{color:var(--accent-light);font-style:italic}.tray-list{flex:1;display:flex;gap:6px;overflow-x:auto;height:100%;align-items:center;padding:4px 0}.tray-list::-webkit-scrollbar{height:6px}.tray-list::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}.tray-empty{font-size:11px;font-family:var(--font-mono);color:#fff6;letter-spacing:1.5px;text-transform:uppercase}.tray-chip{flex-shrink:0;width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.1);background:var(--ink-soft)}.tray-chip img,.tray-chip video{width:100%;height:100%;object-fit:cover;display:block}.tray-chip .remove{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;background:#0009;color:#fff;font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none}.tray-chip .remove:hover{background:var(--accent)}.tray-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;padding-left:12px;border-left:1px solid rgba(255,255,255,.08)}.tray .btn{background:transparent;color:#ffffffb3;border-color:#ffffff26}.tray .btn:hover{border-color:var(--accent);color:var(--accent)}.tray .btn.primary{background:var(--accent);color:var(--ink);border-color:var(--accent)}.tray .btn.primary:hover{background:var(--accent-light);border-color:var(--accent-light)}#importOverlay{position:fixed;inset:0;background:var(--cream);z-index:900;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:32px;transition:opacity .4s ease}#importOverlay.hidden{opacity:0;pointer-events:none}.imp-logo{font-family:var(--font-display);font-size:clamp(36px,7vw,64px);font-weight:300;letter-spacing:6px;color:var(--ink);text-align:center}.imp-logo span{color:var(--accent);font-style:italic}.imp-sub{font-size:11px;letter-spacing:3px;color:var(--text-dim);font-family:var(--font-mono);text-transform:uppercase}.imp-zone{width:min(560px,92vw);border:1px dashed var(--border-strong);border-radius:var(--radius-md);padding:48px 32px;text-align:center;cursor:pointer;transition:all .2s;background:var(--surface);position:relative}.imp-zone:hover,.imp-zone.drag{border-color:var(--accent);background:var(--accent-pale)}.imp-zone input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}.imp-icon{font-size:40px;opacity:.35;margin-bottom:12px}.imp-title{font-family:var(--font-display);font-size:24px;font-weight:400;color:var(--ink);margin-bottom:6px}.imp-hint{font-size:12px;color:var(--text-dim);letter-spacing:.5px}.imp-types{display:flex;gap:6px;justify-content:center;margin-top:14px;flex-wrap:wrap}.imp-divider{display:flex;align-items:center;gap:12px;width:min(560px,92vw);color:var(--text-dim);font-size:10px;font-family:var(--font-mono);letter-spacing:2px;text-transform:uppercase}.imp-divider:before,.imp-divider:after{content:"";flex:1;height:1px;background:var(--border)}.imp-folder-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;border:1px solid var(--ink);background:var(--ink);color:var(--cream);border-radius:var(--radius-sm);font-size:11px;font-family:var(--font-mono);letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:background .2s}.imp-folder-btn:hover{background:var(--accent);border-color:var(--accent)}.imp-progress{width:min(560px,92vw);display:none;flex-direction:column;gap:8px;align-items:center}.imp-progress.show{display:flex}.imp-prog-bar{width:100%;height:2px;background:var(--border);border-radius:1px;overflow:hidden}.imp-prog-fill{height:100%;background:var(--accent);width:0%;transition:width .15s}.imp-prog-label{font-size:11px;font-family:var(--font-mono);color:var(--text-dim);letter-spacing:.5px}.imp-footer{position:absolute;bottom:20px;left:0;right:0;text-align:center;font-size:10px;font-family:var(--font-mono);color:var(--text-dim);letter-spacing:2px;text-transform:uppercase}.imp-footer a{color:var(--accent);text-decoration:none}.imp-footer a:hover{text-decoration:underline}.tb-hamburger{display:none;width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:18px;align-items:center;justify-content:center}.rail-backdrop{display:none;position:fixed;inset:0;background:#1a171473;backdrop-filter:blur(3px);z-index:40}@media (max-width: 900px){:root{--rail-w: 200px;--tray-h: 92px;--topbar-h: 52px}.tb-sub{display:none}.stage-canvas-wrap{padding:16px}.tb-brand{font-size:18px;letter-spacing:2px}.btn.small{padding:4px 8px;font-size:10px}.tray-chip{width:56px;height:56px}.rail-grid{grid-template-columns:repeat(2,1fr);padding:8px}}@media (max-width: 600px){:root{--rail-w: 0px;--tray-h: 84px;--topbar-h: 52px}body{font-size:13px}#app{grid-template-rows:var(--topbar-h) 1fr var(--tray-h);grid-template-columns:1fr;grid-template-areas:"topbar" "stage" "tray"}.topbar{padding:0 10px;gap:8px;overflow-x:auto}.tb-brand{font-size:16px;letter-spacing:1.5px}.tb-brand span{font-size:.9em}.tb-actions{gap:4px}.tb-hamburger{display:inline-flex;margin-right:4px}.rail{position:fixed;top:var(--topbar-h);bottom:var(--tray-h);left:0;width:min(280px,80vw);z-index:45;transform:translate(-100%);transition:transform .22s ease;box-shadow:2px 0 16px #00000026}body.rail-open .rail{transform:translate(0)}body.rail-open .rail-backdrop{display:block}.stage-tabs,.stage-toolbar{padding:6px 8px;gap:4px;min-height:40px;flex-wrap:nowrap}.stage-tab{padding:4px 10px;font-size:9px;letter-spacing:1px}.stage-toolbar .sep{height:14px;margin:0 2px}.stage-toolbar .btn.small{padding:4px 8px;font-size:9px;letter-spacing:.5px}.font-select{min-width:110px;font-size:11px}.size-select{font-size:10px}.tb-swatch{padding:2px 4px;font-size:9px}.stage-canvas-wrap{padding:10px}.spread-meta{top:6px;right:8px;font-size:9px;padding:2px 6px}.tray{padding:0 10px;gap:8px}.tray-title{font-size:12px;letter-spacing:1px;padding-right:8px}.tray-chip{width:52px;height:52px}.tray-actions{padding-left:8px;gap:4px}.tray .btn.small{padding:4px 8px;font-size:9px}.imp-logo{letter-spacing:4px}.imp-zone{padding:32px 20px}.imp-title{font-size:18px}.imp-folder-btn{padding:12px 16px;font-size:10px;letter-spacing:1px}#settingsPanel{top:var(--topbar-h);bottom:var(--tray-h);width:min(320px,92vw)}.fx-dialog{max-height:85vh;overflow-y:auto}}@media (hover: none){.rail-thumb:hover{border-color:transparent}.btn:hover{border-color:var(--border);color:var(--text)}.btn.primary:hover{background:var(--ink);border-color:var(--ink);color:var(--cream)}}.editor-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-dim);font-family:var(--font-mono);font-size:12px;letter-spacing:1.5px;text-transform:uppercase}.editor-empty .ico{font-size:48px;opacity:.2}.stage-canvas-wrap.drag-over:before{content:"Drop to place on this spread";position:absolute;inset:16px;border:2px dashed var(--accent);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:var(--accent-pale);color:var(--accent);font-family:var(--font-mono);font-size:13px;letter-spacing:2px;text-transform:uppercase;pointer-events:none;z-index:5}.font-select,.size-select,.color-pick{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:11px;font-family:var(--font-mono);color:var(--text);outline:none}.font-select{font-family:var(--font-display);font-size:13px;font-style:italic;min-width:160px}.font-select:focus,.size-select:focus{border-color:var(--accent)}.color-pick{width:34px;height:26px;padding:1px;cursor:pointer}.tb-swatch{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-family:var(--font-mono);font-size:10px;letter-spacing:1px;color:var(--text-dim);cursor:pointer}.tb-swatch input[type=color]{width:22px;height:22px;padding:0;border:none;background:none;cursor:pointer}.tb-swatch:hover{border-color:var(--accent);color:var(--accent)}.design-pop{width:340px;max-width:calc(100vw - 16px);max-height:480px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:300;display:flex;flex-direction:column;overflow:hidden;font-family:var(--font-body)}.dp-head{display:grid;grid-template-columns:1fr auto;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border);align-items:center}.dp-title{font-family:var(--font-display);font-size:18px;letter-spacing:1.5px;grid-column:1 / 2;grid-row:1}.dp-close{grid-column:2 / 3;grid-row:1;width:26px;height:26px;border:1px solid var(--border);border-radius:50%;background:transparent;color:var(--text-dim);font-size:11px;cursor:pointer}.dp-close:hover{border-color:var(--accent);color:var(--accent)}.dp-cats{grid-column:1 / 3;grid-row:2;display:flex;gap:4px;flex-wrap:wrap}.dp-cat{padding:4px 10px;font-size:10px;font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;border:1px solid var(--border);border-radius:20px;background:var(--surface);color:var(--text-dim);cursor:pointer}.dp-cat:hover{border-color:var(--accent);color:var(--accent)}.dp-cat.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}.dp-placement{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--surface-alt)}.dp-plabel{font-size:10px;font-family:var(--font-mono);letter-spacing:1.5px;color:var(--text-dim);text-transform:uppercase;flex-shrink:0}.dp-plist{display:flex;gap:4px;flex-wrap:wrap;flex:1}.dp-p{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-dim);cursor:pointer;font-size:10px;font-family:var(--font-mono);letter-spacing:.5px;text-transform:uppercase;transition:all .15s}.dp-p:hover{border-color:var(--accent);color:var(--accent)}.dp-p.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}.dp-p.active .dp-picon{color:var(--accent-light)}.dp-picon{width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-dim)}.dp-picon svg{width:14px;height:14px}.dp-p:hover .dp-picon{color:var(--accent)}.dp-plb{display:none}@media (min-width: 400px){.dp-plb{display:inline}}.dp-grid{padding:10px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;overflow-y:auto}.dp-item{aspect-ratio:1;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-alt);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px;transition:all .15s}.dp-item:hover{border-color:var(--accent);background:var(--accent-pale);transform:translateY(-1px)}.dp-svg{flex:1;width:100%;display:flex;align-items:center;justify-content:center}.dp-svg svg{max-width:100%;max-height:100%;width:100%;height:auto}.dp-label{font-size:9px;font-family:var(--font-mono);letter-spacing:.5px;color:var(--text-dim);text-transform:uppercase}@media (max-width: 600px){.design-pop{width:calc(100vw - 16px);max-height:60vh}.dp-grid{grid-template-columns:repeat(3,1fr)}}.fx-pop{width:360px;max-width:calc(100vw - 16px);max-height:540px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:300;display:flex;flex-direction:column;overflow:hidden;font-family:var(--font-body)}.fxp-head{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border)}.fxp-title{font-family:var(--font-display);font-size:18px;letter-spacing:1.5px;color:var(--ink)}.fxp-close{width:26px;height:26px;border:1px solid var(--border);border-radius:50%;background:transparent;color:var(--text-dim);font-size:11px;cursor:pointer}.fxp-close:hover{border-color:var(--accent);color:var(--accent)}.fxp-section{padding:10px 12px;border-bottom:1px solid var(--border);max-height:180px;overflow-y:auto}.fxp-section:last-of-type{border-bottom:none}.fxp-label{font-size:10px;letter-spacing:2px;color:var(--text-dim);font-family:var(--font-mono);text-transform:uppercase;margin-bottom:8px}.fxp-presets{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.fxp-preset{padding:6px 8px;font-size:10px;font-family:var(--font-mono);letter-spacing:.5px;color:var(--text-dim);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;transition:all .15s}.fxp-preset:hover{border-color:var(--accent);color:var(--accent)}.fxp-preset.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}.fxp-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}.fxp-sl{font-size:10px;font-family:var(--font-mono);letter-spacing:.5px;color:var(--text-dim);width:80px;text-transform:uppercase;flex-shrink:0}.fxp-slider{flex:1;accent-color:var(--accent);min-width:90px}.fxp-val{font-size:10px;font-family:var(--font-mono);color:var(--accent);width:38px;text-align:right;flex-shrink:0}.fxp-footer{padding:10px 12px;display:flex;justify-content:flex-end}@media (max-width: 600px){.fx-pop{width:calc(100vw - 16px)}}.tpl-backdrop{position:fixed;inset:0;background:#1a171499;backdrop-filter:blur(6px);z-index:800;display:flex;align-items:center;justify-content:center;padding:24px}.tpl-dialog{width:min(720px,100%);max-height:85vh;background:var(--cream);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.tpl-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.tpl-title{font-family:var(--font-display);font-size:28px;font-weight:400;letter-spacing:2px;color:var(--ink)}.tpl-sub{font-size:11px;font-family:var(--font-mono);color:var(--text-dim);letter-spacing:1px;margin-top:2px}.tpl-close{width:30px;height:30px;border:1px solid var(--border);border-radius:50%;background:transparent;color:var(--text-dim);font-size:12px;cursor:pointer}.tpl-close:hover{border-color:var(--accent);color:var(--accent)}.tpl-cats{display:flex;gap:4px;padding:12px 24px;border-bottom:1px solid var(--border);background:var(--surface-alt);overflow-x:auto}.tpl-cat{padding:6px 14px;font-size:10px;font-family:var(--font-mono);letter-spacing:1.5px;text-transform:uppercase;border:1px solid var(--border);border-radius:20px;background:var(--surface);color:var(--text-dim);cursor:pointer}.tpl-cat:hover{border-color:var(--accent);color:var(--accent)}.tpl-cat.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}.tpl-grid{padding:16px 24px;display:grid;grid-template-columns:1fr;gap:12px;overflow-y:auto}.tpl-card{display:flex;align-items:center;gap:14px;padding:14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}.tpl-card:hover{border-color:var(--accent)}.tpl-swatch{width:60px;height:60px;border-radius:var(--radius-sm);flex-shrink:0;border:1px solid rgba(0,0,0,.1)}.tpl-card-body{flex:1}.tpl-card-title{font-family:var(--font-display);font-size:20px;font-weight:400;letter-spacing:1px;color:var(--ink);margin-bottom:3px}.tpl-card-desc{font-size:12px;color:var(--text-dim);line-height:1.5}.tpl-foot{display:flex;gap:14px;padding:14px 24px;border-top:1px solid var(--border);background:var(--surface-alt);flex-wrap:wrap}.tpl-mode{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text);cursor:pointer}.tpl-mode input{accent-color:var(--accent)}@media (max-width: 600px){.tpl-dialog{max-height:92vh}.tpl-card{flex-direction:row;flex-wrap:wrap}}.fx-dialog-backdrop{position:fixed;inset:0;background:#1a171499;backdrop-filter:blur(6px);z-index:800;display:flex;align-items:center;justify-content:center;padding:24px}.fx-dialog{width:min(440px,100%);background:var(--cream);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden;font-family:var(--font-body)}.fx-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border)}.fx-title{font-family:var(--font-display);font-size:24px;font-weight:400;letter-spacing:2px;color:var(--ink)}.fx-close{width:28px;height:28px;border:1px solid var(--border);border-radius:50%;background:transparent;color:var(--text-dim);font-size:12px;cursor:pointer}.fx-close:hover{border-color:var(--accent);color:var(--accent)}.fx-body{padding:16px 20px}.fx-section{margin-bottom:16px}.fx-label{font-size:10px;letter-spacing:2px;color:var(--text-dim);font-family:var(--font-mono);text-transform:uppercase;margin-bottom:10px}.fx-row{display:flex;flex-direction:column;gap:6px}.fx-radio,.fx-check{display:flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:13px;color:var(--text);cursor:pointer;transition:border-color .15s}.fx-radio:hover,.fx-check:hover{border-color:var(--accent)}.fx-radio input,.fx-check input{cursor:pointer;accent-color:var(--accent)}.fx-check{margin-bottom:6px}.fx-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-family:var(--font-display);font-size:16px;font-style:italic;color:var(--ink);outline:none}.fx-input:focus{border-color:var(--accent)}.fx-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px 18px;border-top:1px solid var(--border);background:var(--surface-alt)}.spread-meta{position:absolute;top:10px;right:16px;font-size:10px;font-family:var(--font-mono);letter-spacing:2px;color:var(--text-dim);background:var(--surface);padding:4px 10px;border-radius:20px;border:1px solid var(--border);text-transform:uppercase;z-index:2}.zoom-hud{position:absolute;right:16px;bottom:16px;display:inline-flex;align-items:center;gap:0;background:var(--ink);color:var(--cream);border-radius:999px;padding:4px;box-shadow:var(--shadow-md);z-index:4;font-family:var(--font-mono);user-select:none}.zh-btn{min-width:28px;height:28px;padding:0 10px;border:none;background:transparent;color:#ffffffbf;font-size:13px;letter-spacing:1px;border-radius:999px;cursor:pointer;transition:background .15s,color .15s}.zh-btn:hover{background:#ffffff14;color:#fff}.zh-btn.zh-pct{min-width:54px;font-size:11px}.zh-btn.zh-fit{margin-left:4px;font-size:10px;letter-spacing:2px;text-transform:uppercase}.zh-btn.zh-fit.active{background:var(--accent);color:var(--ink)}@media (max-width: 600px){.zoom-hud{right:8px;bottom:8px;padding:3px}.zh-btn{min-width:24px;height:24px;padding:0 8px;font-size:12px}.zh-btn.zh-pct{min-width:46px;font-size:10px}}.cover-edit{flex:1;display:flex;align-items:center;justify-content:center;padding:32px;overflow:auto}.cover-card{width:min(720px,90%);aspect-ratio:3 / 4;background:var(--ink);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);position:relative;overflow:hidden;color:var(--cream);display:flex;align-items:center;justify-content:center;padding:48px;text-align:center}.cover-card .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}.cover-card .content{position:relative;z-index:2;width:100%}.cover-names{font-family:var(--font-display);font-size:clamp(38px,7vw,80px);font-weight:300;letter-spacing:4px;line-height:1.1;margin-bottom:18px;outline:none;border-radius:4px;transition:background .15s;color:var(--cream)}.cover-names em{font-style:italic;color:var(--accent-light)}.cover-names:focus,.cover-date:focus,.cover-loc:focus{background:#ffffff0f}.cover-date{font-size:11px;font-family:var(--font-mono);letter-spacing:6px;color:#ffffffa6;text-transform:uppercase;outline:none;border-radius:4px}.cover-controls{position:absolute;bottom:14px;left:14px;right:14px;display:flex;flex-wrap:wrap;justify-content:center;gap:6px;z-index:3}.cover-controls .btn{background:#0006;color:#fffc;border-color:#fff3;backdrop-filter:blur(4px)}@media (max-width: 600px){.cover-controls{gap:5px;bottom:8px;left:8px;right:8px}.cover-controls .btn{padding:4px 7px;font-size:9px;letter-spacing:.3px}}.cover-controls .btn:hover{border-color:var(--accent);color:var(--accent)}#settingsPanel{position:fixed;top:var(--topbar-h);right:0;bottom:var(--tray-h);width:var(--settings-w);background:var(--surface);border-left:1px solid var(--border);z-index:50;transform:translate(100%);transition:transform .3s ease;overflow-y:auto;box-shadow:-8px 0 32px #00000014}#settingsPanel.open{transform:translate(0)}.sp-head{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sp-title{font-family:var(--font-display);font-size:20px;font-weight:400;letter-spacing:1px}.sp-close{width:28px;height:28px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-dim)}.sp-close:hover{border-color:var(--accent);color:var(--accent)}.sp-section{padding:16px 18px;border-bottom:1px solid var(--border)}.sp-label{font-size:10px;letter-spacing:2px;color:var(--text-dim);font-family:var(--font-mono);text-transform:uppercase;margin-bottom:10px}.sp-input{width:100%;padding:9px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-display);font-size:15px;font-style:italic;color:var(--ink);outline:none;transition:border-color .15s}.sp-input:focus{border-color:var(--accent)}.sp-row{display:flex;gap:6px;margin-bottom:6px;flex-wrap:wrap}.sp-btn{flex:1;min-width:52px;padding:9px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:11px;font-family:var(--font-mono);letter-spacing:.5px;color:var(--text-dim);text-align:center}.sp-btn:hover{border-color:var(--accent);color:var(--accent)}.sp-btn.active{background:var(--ink);border-color:var(--ink);color:#fff}.sp-primary{width:100%;padding:12px;background:var(--ink);border-radius:var(--radius-sm);color:#fff;font-size:12px;font-family:var(--font-mono);letter-spacing:2px;text-transform:uppercase;transition:background .2s;border:1px solid var(--ink)}.sp-primary:hover{background:var(--accent);border-color:var(--accent)}.accent-swatches{display:flex;gap:8px;flex-wrap:wrap}.accent-swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .15s;position:relative}.accent-swatch.active{border-color:var(--ink);transform:scale(1.1)}.accent-swatch:after{content:"";position:absolute;inset:3px;border-radius:50%;background:inherit}@media print{.topbar,.rail,.tray,.stage-tabs,.stage-toolbar,#settingsPanel,.cover-controls{display:none!important}body{background:#fff}#app{display:block!important;height:auto!important;grid-template:none!important}.stage,.stage-canvas-wrap{display:block!important;padding:0!important;background:#fff!important;overflow:visible!important}.stage-canvas-wrap canvas{width:100%!important;height:auto!important;box-shadow:none!important;page-break-after:always}@page{margin:0;size:letter portrait}}
