:root{--bg: #0f0f1a;--surface: #1a1a2e;--surface2: #222236;--border: rgba(255, 255, 255, .08);--accent: #7c6bf0;--accent-light: #a897f5;--accent-glow: rgba(124, 107, 240, .25);--text: #e8e8f0;--text-muted: #7878a0;--text-dim: #4a4a6a;--paper: #f9f5ec;--paper-dark: #ede8db;--danger: #e05260;--success: #42c78a;--warning: #f0a040;--radius: 12px;--radius-sm: 8px;--shadow: 0 8px 32px rgba(0, 0, 0, .4);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--font: "Inter", system-ui, sans-serif;--font-serif: "Playfair Display", Georgia, serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font);background:radial-gradient(ellipse 80% 50% at 50% 0%,var(--theme-bg3, #1a1a35) 0%,var(--theme-bg1, #0c0c18) 65%);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}a{color:var(--accent-light);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,select,textarea{font-family:inherit;outline:none}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;transition:all .2s;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 0 20px var(--accent-glow)}.btn-primary:hover{background:var(--accent-light);transform:translateY(-1px)}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface);border-color:var(--accent)}.btn-danger{background:#e0526026;color:var(--danger);border:1px solid rgba(224,82,96,.3)}.btn-danger:hover{background:#e0526040}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.btn-lg{padding:14px 32px;font-size:1rem;border-radius:var(--radius)}.btn-sm{padding:6px 14px;font-size:.8rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:10px 14px;font-size:.875rem;width:100%;transition:border-color .2s}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.input::placeholder{color:var(--text-dim)}.label{display:block;font-size:.75rem;font-weight:600;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;margin-bottom:6px}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:100px;font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.badge-accent{background:var(--accent-glow);color:var(--accent-light)}.badge-success{background:#42c78a26;color:var(--success)}.badge-warning{background:#f0a04026;color:var(--warning)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:9999}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.navbar{position:sticky;top:0;z-index:100;background:#0f0f1ad9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;gap:16px}.navbar-brand{font-family:var(--font-serif);font-size:1.25rem;color:var(--accent-light);font-weight:700;letter-spacing:-.01em;text-decoration:none}.navbar-brand:hover{text-decoration:none;color:#fff}.navbar-actions{display:flex;align-items:center;gap:12px}.home-page{min-height:100vh}.home-hero{padding:80px 24px 60px;text-align:center}.home-hero h1{font-family:var(--font-serif);font-size:clamp(2.5rem,6vw,4rem);line-height:1.1;color:#fff;margin-bottom:16px}.home-hero p{font-size:1.1rem;color:var(--text-muted);max-width:480px;margin:0 auto 32px;line-height:1.6}.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;padding:24px;max-width:1200px;margin:0 auto}.brochure-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s;cursor:pointer;text-decoration:none;color:inherit;display:flex;flex-direction:column}.brochure-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--accent);text-decoration:none}.brochure-card-cover{aspect-ratio:3/4;background:var(--surface2);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.brochure-card-cover canvas,.brochure-card-cover img{width:100%;height:100%;object-fit:contain}.brochure-card-cover .cover-placeholder{font-size:4rem;opacity:.2}.brochure-card-body{padding:16px;flex:1;display:flex;flex-direction:column;gap:6px}.brochure-card-title{font-size:1rem;font-weight:600;color:var(--text);line-height:1.3}.brochure-card-meta{font-size:.75rem;color:var(--text-muted)}.brochure-card-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.empty-state{text-align:center;padding:80px 24px;color:var(--text-muted);grid-column:1 / -1}.empty-state h2{font-size:1.5rem;margin-bottom:8px;color:var(--text)}.cover-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:max(40px,env(safe-area-inset-top,40px)) 24px max(40px,env(safe-area-inset-bottom,40px));background:radial-gradient(ellipse at 50% 0%,rgba(124,107,240,.12) 0%,transparent 60%);text-align:center}.cover-book{position:relative;box-shadow:0 40px 80px #0009,0 0 0 1px #ffffff0d;border-radius:4px 12px 12px 4px;overflow:hidden;max-width:420px;width:100%;aspect-ratio:3/4;background:var(--paper);transform-style:preserve-3d;perspective:1000px;animation:coverFloat 4s ease-in-out infinite}@keyframes coverFloat{0%,to{transform:translateY(0) rotateY(-4deg)}50%{transform:translateY(-8px) rotateY(-2deg)}}.cover-book canvas,.cover-book img{width:100%;height:100%;object-fit:contain;display:block}.cover-spine{position:absolute;left:0;top:0;bottom:0;width:12px;background:linear-gradient(to right,#0000004d,#0000000d);z-index:2}.cover-info{text-align:center;max-width:480px;margin-top:40px}.cover-title{font-family:var(--font-serif);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;color:#fff;line-height:1.15;margin-bottom:12px}.cover-desc{font-size:1rem;color:var(--text-muted);line-height:1.65;margin-bottom:32px}.viewer-page{height:100vh;display:flex;flex-direction:column;overflow:hidden;background:#111118}.viewer-toolbar{flex-shrink:0;height:56px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:8px;z-index:10}.viewer-title{flex:1;font-size:.9rem;font-weight:600;color:var(--text);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin:0 8px}.viewer-page-info{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.viewer-body{flex:1;display:flex;overflow:hidden}.viewer-toc-sidebar{width:260px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;transition:width .3s,transform .3s}.viewer-toc-sidebar.collapsed{width:0;overflow:hidden}.viewer-canvas-area{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;background:#111118}.flipbook-wrapper{position:relative;display:flex;align-items:center;justify-content:center;gap:0;width:100%;height:100%;-webkit-user-select:none;user-select:none}.flipbook-container{position:relative;box-shadow:0 20px 60px #000000b3;border-radius:4px}.flipbook-container:after{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent,rgba(0,0,0,.3),transparent);z-index:10;pointer-events:none}.page-canvas-wrap{position:relative;background:var(--paper);overflow:hidden}.page-canvas-wrap canvas{display:block}.hotspot-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hotspot-item{position:absolute;cursor:pointer;border:none;background:transparent;border-radius:4px;pointer-events:all;transition:background .15s,outline .15s;outline:2px solid transparent;outline-offset:2px}.hotspot-item:hover{background:#0000000d;outline:2px dashed var(--accent)}.hotspot-item.qr-hotspot{border:none;background:transparent}.hotspot-item.qr-hotspot:hover{background:#0000000d;outline:2px dashed var(--accent)}@keyframes hotspotPulse{0%{background:#ffd70000}15%{background:#ffd70061}55%{background:#ffd7002e}to{background:#ffd70000}}.hotspot-item--pulse{animation:hotspotPulse 1s ease-out 3 forwards}@media (pointer: coarse){.hotspot-item:active{background:#ffd70047;transform:scale(.97);transition:background .06s,transform .06s}}.nav-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:20;background:#ffffff14;border:1px solid var(--border);color:var(--text);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:background .15s,transform .15s;cursor:pointer}.nav-arrow:hover{background:var(--accent);transform:translateY(-50%) scale(1.05)}.nav-arrow.left{left:12px}.nav-arrow.right{right:12px}.nav-arrow:disabled{opacity:.3;cursor:not-allowed}.toc-header{padding:16px;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border)}.toc-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(255,255,255,.03)}.toc-item:hover{background:var(--surface2)}.toc-item.active{background:var(--accent-glow);color:var(--accent-light)}.toc-page-num{font-size:.7rem;color:var(--text-dim);min-width:24px;font-variant-numeric:tabular-nums}.toc-label{font-size:.85rem;line-height:1.3;flex:1}.toc-empty{padding:24px 16px;text-align:center;color:var(--text-muted);font-size:.85rem}.admin-page{min-height:100vh}.admin-container{max-width:1100px;margin:0 auto;padding:32px 24px}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.admin-header h1{font-size:1.8rem;font-weight:700;color:var(--text)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;width:100%;max-width:520px;box-shadow:var(--shadow)}.modal h2{font-size:1.3rem;font-weight:700;margin-bottom:24px}.modal-footer{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.form-field{margin-bottom:16px}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;margin-bottom:16px}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:var(--accent-glow)}.drop-zone-icon{font-size:3rem;margin-bottom:8px}.drop-zone-text{color:var(--text-muted);font-size:.9rem}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{text-align:left;padding:10px 14px;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border)}.data-table td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle;color:var(--text)}.data-table tr:hover td{background:var(--surface2)}.brochure-admin-page{min-height:100vh}.brochure-admin-container{max-width:1200px;margin:0 auto;padding:32px 24px}.brochure-admin-tabs{display:flex;gap:4px;background:var(--surface2);border-radius:var(--radius);padding:4px;margin-bottom:24px;width:fit-content}.tab-btn{padding:8px 20px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;color:var(--text-muted);background:transparent;transition:all .2s}.tab-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.tab-btn:hover:not(.active){color:var(--text)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.section-header h2{font-size:1.2rem;font-weight:600}.hotspot-editor{display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:start}.hotspot-canvas-wrap{position:relative;background:var(--surface2);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);cursor:crosshair}.hotspot-canvas-wrap canvas{display:block;width:100%}.hotspot-draw-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.drawing-rect{position:absolute;border:2px solid var(--accent);background:var(--accent-glow);pointer-events:none}.hotspot-editor-sidebar h3{font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:16px}.hotspot-list-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;margin-bottom:8px;display:flex;align-items:flex-start;justify-content:space-between;gap:8px;font-size:.8rem}.hotspot-list-label{font-weight:600;color:var(--text);margin-bottom:2px}.hotspot-list-action{color:var(--text-muted);font-size:.75rem}.page-strip{display:flex;gap:8px;overflow-x:auto;padding:8px 0;margin-bottom:16px;scrollbar-width:thin}.page-thumb{flex-shrink:0;width:56px;height:80px;background:var(--surface2);border:2px solid var(--border);border-radius:4px;overflow:hidden;cursor:pointer;transition:border-color .15s;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--text-muted)}.page-thumb.active{border-color:var(--accent)}.page-thumb canvas,.page-thumb img{width:100%;height:100%;object-fit:contain}.qr-manager{display:flex;flex-direction:column;gap:16px}.qr-url-input-wrap{display:flex;gap:8px}.qr-thumbnail{width:48px;height:48px;background:var(--surface2);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.toc-editor{display:flex;flex-direction:column;gap:12px}.toc-editor-item{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px}.toc-editor-item input{flex:1;background:transparent;border:none;color:var(--text);font-size:.875rem}.toc-editor-item input[type=number]{width:60px;flex:unset;text-align:center}.toast{position:fixed;bottom:24px;right:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 20px;font-size:.875rem;z-index:9999;animation:toastIn .3s ease;box-shadow:var(--shadow)}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.zoom-controls{display:flex;align-items:center;gap:4px;background:var(--surface2);border-radius:var(--radius-sm);padding:2px}.zoom-controls button{background:transparent;color:var(--text-muted);width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:background .15s,color .15s}.zoom-controls button:hover{background:var(--surface);color:var(--text)}.zoom-val{font-size:.75rem;color:var(--text-muted);min-width:38px;text-align:center}.toolbar-divider{width:1px;height:24px;background:var(--border);margin:0 4px}.viewer-flip-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;background:transparent;overflow:hidden}.viewer-flip-toolbar{position:fixed;top:0;left:0;right:0;padding:max(8px,env(safe-area-inset-top,8px)) 12px 8px;display:flex;align-items:center;gap:6px;background:var(--theme-glass-tint, rgba(10, 10, 22, .82));backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.06);z-index:20;transition:opacity .3s ease}.viewer-flip-toolbar.hidden{opacity:0;pointer-events:none}.viewer-flip-title{flex:1;font-size:.9rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;padding:0 8px}.viewer-flip-area{position:absolute;top:0;right:0;bottom:0;left:0;padding-top:calc(44px + max(8px,env(safe-area-inset-top,8px)));display:flex;align-items:center;justify-content:center;overflow:hidden;user-select:none;-webkit-user-select:none;touch-action:none}.viewer-flip-area.is-fullscreen{padding-top:0}.flip-page-loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f0f0f0}.flip-nav-arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:80px;display:flex;align-items:center;justify-content:center;background:#00000047;color:#ffffffbf;border:none;border-radius:6px;font-size:1.6rem;cursor:pointer;z-index:10;transition:background .2s,opacity .2s;outline:none}.flip-nav-arrow:hover:not(:disabled){background:#00000080;color:#fff}.flip-nav-arrow:disabled{opacity:.15;cursor:default}.flip-nav-prev{right:12px}.flip-nav-next{left:12px}.spread-container{display:flex;justify-content:center;gap:24px}.toc-drawer-panel{width:320px}@media (max-width: 600px){.toc-drawer-panel{width:100vw}.viewer-flip-toolbar{gap:4px;padding:max(8px,env(safe-area-inset-top,8px)) 8px 8px}.viewer-flip-title{font-size:.8rem}.flip-nav-arrow{width:36px;height:64px;font-size:1.3rem}}.theme-panel{display:flex;flex-direction:column;gap:20px}.theme-mode-row{display:flex;gap:8px;flex-wrap:wrap}.theme-mode-btn{padding:8px 18px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;font-size:.85rem;transition:background .15s,border-color .15s}.theme-mode-btn.active{background:var(--accent);color:#fff;border-color:transparent}.theme-mode-btn:hover:not(.active){background:var(--surface);border-color:var(--accent)}.theme-preview-card{height:160px;border-radius:var(--radius);overflow:hidden;position:relative;box-shadow:var(--shadow);border:1px solid var(--border)}.theme-preview-toolbar{position:absolute;top:0;left:0;right:0;height:36px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);font-size:.8rem}.color-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.color-row label{min-width:80px;font-size:.85rem;color:var(--text-muted)}.color-swatch-input{width:40px;height:36px;border-radius:8px;border:2px solid var(--border);padding:0;cursor:pointer;background:none}.theme-slider-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.theme-slider-row label{min-width:80px;font-size:.85rem;color:var(--text-muted)}.theme-slider{flex:1;accent-color:var(--accent)}.theme-slider-val{font-size:.8rem;color:var(--text-muted);min-width:32px;text-align:left}.theme-upload-zone{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:16px;text-align:center;cursor:pointer;color:var(--text-muted);font-size:.85rem;transition:border-color .15s}.theme-upload-zone:hover{border-color:var(--accent);color:var(--accent-light)}.theme-section-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:10px}.theme-fit-row{display:flex;gap:8px;margin-bottom:10px}.theme-fit-btn{flex:1;padding:6px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface2);color:var(--text-muted);cursor:pointer;font-size:.82rem;text-align:center}.theme-fit-btn.active{background:var(--accent);color:#fff;border-color:transparent}.cover-actions{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:28px;flex-wrap:wrap}.cover-action-main{padding:14px 32px;font-size:1.05rem;order:0}.cover-action-side{padding:10px 20px}@media (max-width: 480px){.cover-actions{flex-direction:column;width:100%}.cover-actions .btn{width:100%;justify-content:center;text-align:center}.cover-action-main{order:-1}}.theme-auto-set{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px 6px 6px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface2);color:var(--text-muted);cursor:pointer;font-size:.82rem;transition:border-color .15s,background .15s}.theme-auto-set:disabled{opacity:.5;cursor:default}.theme-auto-set:not(:disabled):hover{border-color:var(--accent);background:var(--surface)}.theme-auto-set.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 15%,var(--surface2));color:var(--text)}.btn,.tab-btn,.flip-nav-arrow,.zoom-controls button,.theme-mode-btn,.theme-fit-btn,.theme-auto-set,.toc-item,.cover-action-main,.cover-action-side{-webkit-tap-highlight-color:rgba(0,0,0,0)}@media (pointer: coarse){.btn:active:not(:disabled),.tab-btn:active:not(:disabled),.theme-mode-btn:active:not(:disabled),.theme-fit-btn:active:not(:disabled),.theme-auto-set:active:not(:disabled),.toc-item:active{opacity:.72;transform:scale(.96);transition:opacity .06s,transform .06s}.flip-nav-arrow:active:not(:disabled){background:#ffffff38;outline:2px solid rgba(255,255,255,.45);outline-offset:2px;transition:background .06s,outline-color .06s}.zoom-controls button:active:not(:disabled){background:var(--surface);outline:1px solid var(--border);outline-offset:1px}}
