*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--spine-bg: #18181b;--spine-width: 260px;--content-bg: #fefcf8;--content-text: #1c1c1c;--accent: #c9913a;--radius: 4px;--font-ui: system-ui, -apple-system, sans-serif;--font-reading: Georgia, "Times New Roman", serif}html,body,#root{height:100%;width:100%;overflow:hidden}.import-screen{height:100%;display:flex;align-items:center;justify-content:center;background:#f5f0e8;font-family:var(--font-ui)}.import-inner{width:600px;display:flex;flex-direction:column;gap:24px}.import-logo{display:flex;flex-direction:column;gap:6px}.logo-word{font-size:2rem;font-weight:700;letter-spacing:-.03em;color:#1a1a1a;font-family:Georgia,serif}.logo-tagline{font-size:.875rem;color:#666;font-style:italic}.import-card{background:#fff;border:1px solid #e0d9ce;border-radius:8px;padding:24px;display:flex;flex-direction:column;gap:16px;box-shadow:0 2px 12px #0000000f}.import-label{font-size:.8125rem;font-weight:600;color:#444;letter-spacing:.04em;text-transform:uppercase}.import-textarea{width:100%;height:220px;resize:vertical;border:1px solid #ddd;border-radius:var(--radius);padding:12px;font-family:var(--font-ui);font-size:.875rem;color:#333;background:#fafafa;line-height:1.6;outline:none;transition:border-color .15s}.import-textarea:focus{border-color:var(--accent);background:#fff}.import-error{font-size:.8125rem;color:#c0392b;line-height:1.5}.import-warning{font-size:.8125rem;color:#92660a;background:#fef9ec;border:1px solid #f5d87a;border-radius:var(--radius);padding:8px 12px;line-height:1.5}.import-btn{align-self:flex-start;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);padding:10px 24px;font-size:.9375rem;font-weight:600;cursor:pointer;font-family:var(--font-ui);letter-spacing:.01em;transition:background .15s,opacity .15s}.import-btn:hover:not(:disabled){background:#b07d2d}.import-btn:disabled{opacity:.4;cursor:not-allowed}.import-instruction{font-size:.875rem;color:#555;line-height:1.5}.book-view{display:flex;height:100%;width:100%;background:#eae5db;font-family:var(--font-ui)}.spine{width:var(--spine-width);min-width:var(--spine-width);background:var(--spine-bg);display:flex;flex-direction:column;height:100%;overflow:hidden;border-right:3px solid #0d0d0f}.spine-header{padding:20px 16px 14px;border-bottom:1px solid #2a2a2e;flex-shrink:0}.spine-book-label{display:block;font-size:.9375rem;font-weight:700;color:#fff;letter-spacing:-.01em;font-family:Georgia,serif}.spine-count{display:block;font-size:.6875rem;color:#666;margin-top:3px;letter-spacing:.04em;text-transform:uppercase}.spine-tabs{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:#333 transparent;padding:8px 0}.spine-tab{width:100%;display:flex;align-items:stretch;border-left:3px solid var(--tab-color);transition:background .1s;margin-bottom:2px}.spine-tab:hover{background:#ffffff0d}.spine-tab--active{background:var(--content-bg);margin-right:-3px;border-radius:4px 0 0 4px}.spine-tab-btn{flex:1;display:flex;align-items:flex-start;gap:10px;padding:10px 0;background:none;border:none;cursor:pointer;text-align:left;min-width:0}.spine-tab-delete{background:none;border:none;color:#555;font-size:1rem;cursor:pointer;padding:0 10px 0 4px;flex-shrink:0;opacity:0;transition:opacity .15s,color .15s;align-self:center}.spine-tab:hover .spine-tab-delete{opacity:1}.spine-tab-delete:hover{color:#e55}.spine-tab--active .tab-index,.spine-tab--active .tab-title{color:#1a1a1a}.tab-index{font-size:.6875rem;font-weight:700;color:var(--tab-color);letter-spacing:.06em;flex-shrink:0;padding-left:12px;padding-top:2px;font-family:var(--font-ui)}.tab-title{font-size:.75rem;color:#aaa;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-family:var(--font-ui)}.content-panel{flex:1;display:flex;flex-direction:column;height:100%;background:var(--content-bg);position:relative}.content-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 28px;border-bottom:1px solid #e8e2d8;flex-shrink:0;background:#faf6ef}.topbar-back{background:none;border:none;font-size:.8125rem;color:#888;cursor:pointer;font-family:var(--font-ui);padding:4px 0;transition:color .15s}.topbar-back:hover{color:#333}.topbar-nav{display:flex;align-items:center;gap:14px}.nav-btn{background:none;border:1px solid #ddd;border-radius:var(--radius);padding:5px 12px;font-size:.8125rem;color:#555;cursor:pointer;font-family:var(--font-ui);transition:all .15s}.nav-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.nav-btn:disabled{opacity:.3;cursor:not-allowed}.nav-counter{font-size:.8125rem;color:#999;min-width:48px;text-align:center}.topbar-stickers{background:none;border:1px solid #ddd;border-radius:var(--radius);padding:5px 14px;font-size:.8125rem;color:#555;cursor:pointer;font-family:var(--font-ui);display:flex;align-items:center;gap:7px;transition:all .15s}.topbar-stickers:hover{border-color:var(--accent);color:var(--accent)}.sticker-badge{background:var(--accent);color:#fff;font-size:.625rem;font-weight:700;border-radius:99px;padding:1px 6px;line-height:1.6}.content-body{flex:1;overflow-y:auto;padding:48px 72px 64px;scrollbar-width:thin;scrollbar-color:#ccc transparent}.content-question-wrap{position:relative;max-width:720px;margin-bottom:32px}.content-question{font-family:Georgia,serif;font-size:1.5rem;font-weight:400;color:#1a1a1a;line-height:1.4;padding-bottom:24px;border-bottom:2px solid var(--accent)}.content-question-rename{position:absolute;top:0;right:0;background:none;border:none;color:#aaa;cursor:pointer;padding:4px;opacity:0;transition:opacity .15s,color .15s;display:flex;align-items:center}.content-question-wrap:hover .content-question-rename{opacity:1}.content-question-rename:hover{color:var(--accent)}.content-question-input{width:100%;font-family:Georgia,serif;font-size:1.5rem;font-weight:400;color:#1a1a1a;line-height:1.4;padding-bottom:24px;border:none;border-bottom:2px solid var(--accent);border-radius:0;background:transparent;outline:none;resize:none;min-height:4rem;box-sizing:border-box}.content-answer{font-family:var(--font-reading);font-size:1rem;color:#2a2a2a;line-height:1.8;max-width:720px;-webkit-user-select:text;user-select:text}.content-answer p{margin-bottom:1em}.content-answer h2{font-size:1.125rem;font-weight:700;margin:1.5em 0 .5em;font-family:var(--font-ui);color:#1a1a1a}.content-answer h3{font-size:1rem;font-weight:700;margin:1.25em 0 .4em;font-family:var(--font-ui);color:#1a1a1a}.content-answer li{margin-left:1.5em;margin-bottom:.4em}.content-answer strong{font-weight:700;color:#111}.content-answer code{font-family:Menlo,Monaco,Courier New,monospace;font-size:.875em;background:#f0ece4;padding:1px 5px;border-radius:3px;color:#b05c3e}.sticker-popup{position:fixed;transform:translate(-50%);display:flex;align-items:center;gap:4px;background:#1a1a1a;border-radius:6px;padding:4px;z-index:100;box-shadow:0 4px 16px #0003}.sticker-popup-btn{background:var(--accent);border:none;color:#fff;font-size:.8125rem;font-weight:600;padding:6px 12px;border-radius:4px;cursor:pointer;font-family:var(--font-ui);white-space:nowrap}.sticker-popup-dismiss{background:none;border:none;color:#888;font-size:1rem;cursor:pointer;padding:4px 6px;line-height:1;border-radius:3px}.sticker-popup-dismiss:hover{color:#fff}.sticker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:24px}.sticker-collection{background:#fff;border-radius:12px 12px 0 0;width:100%;max-width:900px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 -8px 40px #00000026}.collection-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #eee;flex-shrink:0}.collection-title{font-size:1rem;font-weight:700;color:#1a1a1a;font-family:Georgia,serif}.collection-controls{display:flex;align-items:center;gap:16px}.sort-tabs{display:flex;gap:2px;background:#f5f5f5;border-radius:6px;padding:3px}.sort-tab{background:none;border:none;font-size:.8125rem;color:#666;padding:5px 12px;cursor:pointer;border-radius:4px;font-family:var(--font-ui);transition:all .15s}.sort-tab--active{background:#fff;color:#1a1a1a;font-weight:600;box-shadow:0 1px 3px #0000001a}.collection-close{background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;line-height:1;padding:2px 6px}.collection-close:hover{color:#333}.collection-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#999;font-size:.9375rem;padding:48px;font-family:var(--font-ui)}.sticker-grid{flex:1;overflow-y:auto;padding:20px 24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;align-content:start}.sticker-card{border-radius:4px;padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:2px 3px 8px #0000001f;transform:rotate(-.5deg);transition:transform .15s,box-shadow .15s;position:relative}.sticker-card:nth-child(2n){transform:rotate(.7deg)}.sticker-card:hover{transform:rotate(0) scale(1.02);box-shadow:3px 5px 14px #00000029}.sticker-text{font-size:.875rem;color:#222;line-height:1.5;font-family:Georgia,serif;font-style:italic}.sticker-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.sticker-source{font-size:.6875rem;color:#555;font-family:var(--font-ui);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sticker-remove{background:none;border:none;color:#888;font-size:1rem;cursor:pointer;padding:0 2px;flex-shrink:0;line-height:1}.sticker-remove:hover{color:#c0392b}.library-view{height:100%;display:flex;flex-direction:column;background:#f5f0e8;font-family:var(--font-ui);overflow:hidden}.library-header{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid #e0d9ce;background:#fefcf8;flex-shrink:0}.library-brand{display:flex;flex-direction:column;gap:4px}.library-controls{display:flex;align-items:center;gap:12px}.library-search{width:220px;border:1px solid #ddd;border-radius:var(--radius);padding:8px 12px;font-family:var(--font-ui);font-size:.875rem;background:#fafafa;color:#333;outline:none;transition:border-color .15s}.library-search:focus{border-color:var(--accent);background:#fff}.library-import-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius);padding:9px 20px;font-size:.875rem;font-weight:600;cursor:pointer;font-family:var(--font-ui);letter-spacing:.01em;transition:background .15s}.library-import-btn:hover{background:#b07d2d}.library-main{flex:1;overflow-y:auto;padding:32px;scrollbar-width:thin;scrollbar-color:#ccc transparent}.library-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center}.library-empty-title{font-size:1.25rem;font-family:Georgia,serif;color:#2a2a2a}.library-empty-sub{font-size:.875rem;color:#888;max-width:360px;line-height:1.5;margin-bottom:8px}.book-shelf{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,200px));gap:20px}.book-card{background:var(--spine-bg);border:none;border-left:4px solid var(--accent);border-radius:0 6px 6px 0;padding:16px 14px 12px;cursor:pointer;text-align:left;display:flex;flex-direction:column;min-height:200px;font-family:var(--font-ui);transition:transform .15s,box-shadow .15s;box-shadow:2px 4px 12px #00000026;position:relative}.book-card:hover{transform:translateY(-3px);box-shadow:3px 8px 22px #00000038}.book-card-source{font-size:.625rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}.book-card-title{flex:1;font-family:Georgia,serif;font-size:.875rem;color:#f0ece4;line-height:1.55;overflow:hidden;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical}.book-title-input{flex:1;width:100%;background:#ffffff1a;border:1px solid var(--accent);border-radius:3px;padding:4px 6px;font-family:Georgia,serif;font-size:.875rem;color:#f0ece4;outline:none;line-height:1.55}.book-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:14px;gap:4px}.book-card-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.book-card-meta{font-size:.625rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-card-rename,.book-card-delete{background:none;border:none;color:#555;cursor:pointer;line-height:1;padding:2px;opacity:0;transition:opacity .15s,color .15s;display:flex;align-items:center}.book-card-delete{font-size:1.1rem}.book-card:hover .book-card-rename,.book-card:hover .book-card-delete{opacity:1}.book-card-rename:hover{color:var(--accent)}.book-card-delete:hover{color:#e55}.import-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.import-panel{background:#fff;border-radius:10px;width:100%;max-width:560px;display:flex;flex-direction:column;gap:16px;padding:24px;box-shadow:0 8px 40px #0003}.import-panel-header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.import-panel-title{font-size:1rem;font-weight:700;color:#1a1a1a;font-family:Georgia,serif;margin:0}.drop-zone{border:2px dashed #ddd;border-radius:8px;padding:40px 20px;text-align:center;font-size:.875rem;color:#888;cursor:pointer;transition:border-color .15s,background .15s,color .15s;font-family:var(--font-ui);line-height:1;-webkit-user-select:none;user-select:none}.drop-zone:hover,.drop-zone--over{border-color:var(--accent);background:#fef9ec;color:#555}.drop-zone--busy{pointer-events:none;color:#aaa}.import-summary{padding:4px 0;display:flex;flex-direction:column;gap:16px}.import-summary-text{font-size:.9375rem;color:#333;line-height:1.5;font-family:var(--font-ui)}.import-summary-actions{display:flex;gap:12px}.import-btn-secondary{background:none;border:1px solid #ddd;border-radius:var(--radius);padding:10px 24px;font-size:.9375rem;font-weight:600;cursor:pointer;font-family:var(--font-ui);color:#555;transition:border-color .15s,color .15s}.import-btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.library-body{flex:1;display:flex;flex-direction:row;overflow:hidden}.shelf-rail{width:168px;min-width:168px;background:#1a1a1d;border-right:1px solid #2a2a2e;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:#333 transparent;padding:10px 0 16px;flex-shrink:0}.shelf-rail-item{display:flex;align-items:center;gap:7px;padding:7px 10px 7px 12px;cursor:pointer;border:none;background:none;color:#999;font-family:var(--font-ui);font-size:.75rem;text-align:left;width:100%;border-radius:0;transition:background .12s,color .12s;position:relative;min-width:0;outline:none}.shelf-rail-item:hover{background:#ffffff0f;color:#ccc}.shelf-rail-item--active{background:#c9913a26;color:#f0ece4}.shelf-rail-item--active .shelf-rail-name{color:var(--accent)}.shelf-rail-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.shelf-rail-dot--all{background:#666}.shelf-rail-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem}.shelf-rail-count{font-size:.65rem;color:#555;flex-shrink:0;margin-left:auto;padding-left:4px}.shelf-rail-actions{display:flex;align-items:center;gap:1px;opacity:0;flex-shrink:0}.shelf-rail-item:hover .shelf-rail-actions{opacity:1}.shelf-rail-btn{background:none;border:none;color:#666;cursor:pointer;padding:2px 3px;display:flex;align-items:center;border-radius:3px;transition:color .12s}.shelf-rail-btn:hover{color:var(--accent)}.shelf-rail-btn--delete:hover{color:#e55}.shelf-rail-edit{flex:1;background:#ffffff1a;border:1px solid var(--accent);border-radius:3px;padding:2px 5px;font-size:.75rem;color:#f0ece4;font-family:var(--font-ui);outline:none;min-width:0}.shelf-rail-divider{height:1px;background:#2a2a2e;margin:6px 12px;flex-shrink:0}.shelf-rail-new{padding:8px 12px 0;flex-shrink:0}.shelf-rail-new-input{width:100%}.shelf-rail-add{background:none;border:none;color:#666;font-size:.75rem;cursor:pointer;font-family:var(--font-ui);padding:4px 0;transition:color .12s;text-align:left}.shelf-rail-add:hover{color:var(--accent)}.shelf-popover{background:#1e1e22;border:1px solid #35353a;border-radius:8px;min-width:180px;max-width:220px;padding:6px 0 8px;box-shadow:0 6px 24px #00000059;font-family:var(--font-ui)}.shelf-popover-header{font-size:.6875rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#666;padding:4px 12px 8px;border-bottom:1px solid #2e2e33;margin-bottom:4px}.shelf-popover-empty{font-size:.8125rem;color:#666;padding:8px 12px;font-style:italic}.shelf-popover-item{display:flex;align-items:center;gap:8px;padding:5px 12px;cursor:pointer;transition:background .1s}.shelf-popover-item:hover{background:#ffffff0d}.shelf-popover-check{width:14px;height:14px;accent-color:var(--accent);flex-shrink:0;cursor:pointer}.shelf-popover-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.shelf-popover-name{font-size:.8125rem;color:#ccc;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shelf-popover-new{padding:6px 12px 0;border-top:1px solid #2e2e33;margin-top:4px}.shelf-popover-new-input{width:100%;background:#ffffff14;border:1px solid #444;border-radius:3px;padding:4px 8px;font-size:.8125rem;color:#f0ece4;font-family:var(--font-ui);outline:none}.shelf-popover-new-input::placeholder{color:#555}.shelf-popover-add-btn{background:none;border:none;color:#777;font-size:.8125rem;cursor:pointer;font-family:var(--font-ui);padding:2px 0;transition:color .12s}.shelf-popover-add-btn:hover{color:var(--accent)}.book-card-shelf{background:none;border:none;color:#555;cursor:pointer;padding:2px;opacity:0;transition:opacity .15s,color .15s;display:flex;align-items:center}.book-card:hover .book-card-shelf{opacity:1}.book-card-shelf:hover{color:var(--accent)}.topbar-actions{display:flex;align-items:center;gap:8px}.topbar-export-btn{background:none;border:1px solid #ddd;border-radius:var(--radius);padding:5px 10px;font-size:.8125rem;color:#888;cursor:pointer;font-family:var(--font-ui);white-space:nowrap;transition:border-color .15s,color .15s}.topbar-export-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.topbar-export-btn:disabled{opacity:.35;cursor:not-allowed}.library-export-btn{background:none;border:1px solid #ddd;border-radius:var(--radius);padding:9px 16px;font-size:.875rem;color:#777;cursor:pointer;font-family:var(--font-ui);transition:border-color .15s,color .15s}.library-export-btn:hover{border-color:var(--accent);color:var(--accent)}.mode-tabs{display:flex;gap:2px;background:#f0ece4;border-radius:6px;padding:3px;align-self:flex-start}.mode-tab{background:none;border:none;font-size:.8125rem;color:#888;padding:6px 16px;border-radius:4px;cursor:pointer;font-family:var(--font-ui);font-weight:500;transition:all .15s}.mode-tab--active{background:#fff;color:#1a1a1a;font-weight:600;box-shadow:0 1px 3px #0000001a}
