:root{--color-bg: #ffffff;--color-surface: #fafafa;--color-border: #e5e5e5;--color-text: #111111;--color-text-secondary: #666666;--color-text-tertiary: #999999;--color-accent: #111111;--color-accent-bg: #111111;--color-accent-text: #ffffff;--color-tag-bg: #f0f0f0;--color-tag-text: #444444;--color-link: #0066cc;--font-sans: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", "Fira Code", monospace;--max-width: 900px;--nav-height: 56px}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.5;min-height:100vh}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}nav{position:sticky;top:0;z-index:100;height:56px;background:#b31b1b;padding:0 24px;display:flex;align-items:center;justify-content:space-between}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;gap:5px;flex-direction:column;justify-content:center;align-items:center}.hamburger-line{display:block;width:24px;height:2px;background:#fff;transition:all 0.3s ease}.nav-toggle.active .hamburger-line:nth-child(1){transform:rotate(45deg) translate(5px, 5px)}.nav-toggle.active .hamburger-line:nth-child(2){opacity:0}.nav-toggle.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(5px, -5px)}.nav-menu{display:flex;gap:24px}.nav-menu a{font-size:15px;font-weight:500;color:rgba(255,255,255,0.7);text-decoration:none;padding:8px 0;border-bottom:2px solid transparent;transition:all 0.15s}.nav-menu a:hover{color:#fff;text-decoration:none}.nav-menu a.active{color:#fff;border-bottom-color:#fff}.nav-brand{font-family:'Lucida Grande', Helvetica, Arial, Verdana, sans-serif;font-size:24px;font-weight:normal;letter-spacing:-0.02em}.nav-brand a{text-decoration:none;color:#fff;display:flex;align-items:center;gap:6px}.nav-brand a:hover{text-decoration:none}.nav-logo{width:32px;height:43px;vertical-align:middle}.nav-links{display:flex;align-items:center;gap:24px}.nav-links a{font-size:14px;font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:color 0.15s}.nav-links a:hover{color:var(--color-text);text-decoration:none}.nav-links a.active{color:var(--color-text)}.container{max-width:var(--max-width);margin:0 auto;padding:0 24px}.page-header{padding:24px 0 16px}.page-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.page-title{font-size:24px;font-weight:600;letter-spacing:-0.02em;margin:0;border:none;padding:0}.filters-section{padding:20px 0;border-bottom:1px solid var(--color-border)}.category-filters{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:12px}.category-btn{padding:6px 14px;font-size:14px;font-weight:500;border:none;border-radius:6px;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all 0.15s}.category-btn:hover{background:var(--color-surface);color:var(--color-text)}.category-btn.active{background:var(--color-accent-bg);color:var(--color-accent-text)}.tag-filters{display:flex;gap:6px;flex-wrap:wrap}.tag-btn{padding:4px 10px;font-size:13px;border:1px solid var(--color-border);border-radius:4px;background:transparent;color:var(--color-text-tertiary);cursor:pointer;transition:all 0.15s}.tag-btn:hover{border-color:var(--color-text-secondary);color:var(--color-text-secondary)}.tag-btn.active{background:var(--color-surface);border-color:var(--color-text);color:var(--color-text)}.papers-count{font-size:13px;color:var(--color-text-tertiary);padding:16px 0 8px}.papers-list{list-style:none}.paper-item{padding:16px 0;border-bottom:1px solid var(--color-border);display:none}.paper-item.visible{display:block}.paper-item:hover{background:var(--color-surface);margin:0 -24px;padding:16px 24px}.paper-row{display:flex;align-items:baseline;gap:12px;margin-bottom:4px}.paper-title{font-family:'Lucida Grande', Helvetica, Arial, Verdana, sans-serif;font-size:15px;font-weight:bold;letter-spacing:normal;flex:1;color:var(--color-text)}.paper-title a:hover{text-decoration:underline}.paper-meta{display:flex;align-items:center;gap:8px;font-family:'Lucida Grande', Helvetica, Arial, Verdana, sans-serif;font-size:12px;font-weight:normal;color:#666;white-space:nowrap}.paper-year{color:#555;font-weight:normal}.paper-link{color:#0066cc;font-size:12px}.paper-link:hover{text-decoration:underline}.paper-authors{font-size:13px;color:var(--color-text-secondary);margin-bottom:6px}.paper-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.paper-tag,.tag-badge{font-size:11px;font-weight:500;color:#555;background:#e8e8e8;padding:3px 8px;border-radius:3px}.paper-tag::before,.tag-badge::before{content:""}.paper-detail{padding:32px 0}.paper-detail .paper-title{font-family:'Lucida Grande', Helvetica, Arial, Verdana, sans-serif;font-size:26px;font-weight:bold;letter-spacing:normal;margin-bottom:8px;line-height:1.3;word-wrap:break-word}@media (max-width: 900px){.paper-detail .paper-title{font-size:22px}.paper-summary{font-size:16px}}.paper-code-top{font-family:var(--font-mono);font-size:12px;font-weight:600;color:#888;margin-bottom:8px}.paper-code-top a{color:#888;text-decoration:none}.paper-code-top a:hover{color:#0066cc}.paper-detail .paper-authors{font-family:'Lucida Grande', Helvetica, Arial, Verdana, sans-serif;font-size:14px;font-weight:normal;color:#444;margin-bottom:12px}.paper-detail .paper-meta{font-family:'Lucida Grande', Helvetica, Arial, Verdana, sans-serif;font-size:13px;font-weight:normal;margin-bottom:24px;gap:16px;color:#666;display:flex;flex-wrap:wrap;align-items:center}.paper-detail .paper-meta a{color:#0066cc;white-space:nowrap}.paper-detail .paper-tags{margin-bottom:24px}.paper-detail .paper-tag,.paper-detail .tag-badge{font-size:12px;color:#555;background:#e8e8e8;padding:4px 10px;border-radius:3px}.paper-summary{font-family:'Lucida Grande', Helvetica, Arial, Verdana, sans-serif;font-size:17px;font-weight:400;line-height:1.55;color:#000}.paper-code{font-family:var(--font-mono);font-size:13px;color:var(--color-text-tertiary);margin-bottom:16px}.paper-code a{color:#0066cc}.paper-actions{margin-bottom:16px}.btn-delete{padding:8px 14px;font-family:var(--font-sans);font-size:13px;font-weight:500;border:1px solid #cc0000;border-radius:6px;background:#fff;color:#cc0000;cursor:pointer;transition:all 0.15s}.btn-delete:hover{background:#cc0000;color:#fff}.btn-edit{padding:8px 14px;font-family:var(--font-sans);font-size:13px;font-weight:500;border:1px solid #ddd;border-radius:6px;background:#fff;color:#333;cursor:pointer;transition:all 0.15s}.btn-edit:hover{background:#f5f5f5}.modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);align-items:center;justify-content:center;z-index:1001;padding:20px;padding-bottom:80px;overflow-y:auto}.modal-content{background:#fff;padding:24px;border-radius:8px;max-width:400px;width:100%;box-shadow:0 4px 20px rgba(0,0,0,0.15);max-height:calc(100vh - 100px);overflow-y:auto;margin:auto}.modal-wide{max-width:700px}@media (max-height: 600px){.modal-content{max-height:calc(100vh - 60px)}}.edit-form-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:20px}@media (min-width: 600px){.edit-form-grid{grid-template-columns:1fr 1fr;gap:20px}}.edit-form-left{display:flex;flex-direction:column;gap:16px}.edit-form-right{display:flex;flex-direction:column;gap:12px}.modal-content h3{margin:0 0 12px;font-size:18px;font-weight:600}.modal-content p{color:#666;margin-bottom:20px;font-size:14px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}.modal-actions button{flex:1;min-width:100px}@media (max-width: 480px){.modal-content{padding:16px;border-radius:8px 8px 0 0;max-height:90vh}.modal-wide{max-width:100%}.edit-form-left,.edit-form-right{gap:12px}}.modal-actions .btn-primary,.modal-actions .btn-cancel,.modal-actions .btn-delete{padding:10px 20px;font-family:var(--font-sans);font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;transition:all 0.15s}.modal-actions .btn-primary{background:#111;color:#fff;border:none}.modal-actions .btn-primary:hover{background:#333}.modal-actions .btn-cancel{background:#fff;color:#333;border:1px solid #ddd}.modal-actions .btn-cancel:hover{background:#f5f5f5}.modal-actions .btn-delete{background:#fff;color:#cc0000;border:1px solid #cc0000}.modal-actions .btn-delete:hover{background:#cc0000;color:#fff}.btn-cancel{padding:8px 14px;font-family:var(--font-sans);font-size:13px;font-weight:500;border:1px solid #ddd;border-radius:6px;background:#fff;color:#333;cursor:pointer;transition:all 0.15s}.btn-cancel:hover{background:#f5f5f5}.no-results{text-align:center;padding:48px 24px;color:var(--color-text-tertiary)}.add-page{max-width:640px;padding:32px 0}.add-page h1{font-size:24px;font-weight:600;margin-bottom:24px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--color-text-secondary);margin-bottom:6px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;font-family:var(--font-sans);font-size:14px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-text);transition:border-color 0.15s}.form-group input[type="file"]{padding:8px 12px;background:#fafafa}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-text-secondary)}.form-group textarea{min-height:100px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-hint{display:block;font-size:12px;color:var(--color-text-tertiary);margin-top:4px}.label-hint{font-weight:normal;color:var(--color-text-tertiary);font-size:12px}.label-required{color:#cc0000;font-size:12px}.category-input-row{display:flex;gap:8px}.category-input-row select{flex:1;padding:10px 12px;font-family:var(--font-sans);font-size:14px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-text);cursor:pointer}.category-input-row input{flex:1}.btn{padding:10px 16px;font-family:var(--font-sans);font-size:14px;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all 0.15s}.btn-primary{background:var(--color-accent-bg);color:var(--color-accent-text)}.btn-primary:hover{opacity:0.9}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-border)}.button-row{display:flex;gap:12px;margin-bottom:16px}.output-box{background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;padding:16px;font-family:var(--font-mono);font-size:13px;white-space:pre-wrap;word-break:break-all;margin-top:16px}.status{font-size:13px;margin-left:12px}.status.loading{color:var(--color-text-tertiary)}.status.error{color:#cc0000}.status.success{color:#008800}hr{border:none;border-top:1px solid var(--color-border);margin:24px 0}.main-content{padding-bottom:60px}.back-to-top{position:fixed;bottom:80px;right:24px;width:44px;height:44px;background:#b31b1b;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,0.15);opacity:0;visibility:hidden;transition:all 0.3s ease;z-index:999}.back-to-top.visible{opacity:1;visibility:visible}.back-to-top:hover{background:#8b1515;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}.back-to-top:active{transform:translateY(0)}.search-section{margin-top:16px;margin-bottom:24px}.subject-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.subject-btn{padding:6px 14px;font-size:13px;border:1px solid #ddd;border-radius:20px;background:#fff;color:#666;cursor:pointer;transition:all 0.2s}.subject-btn:hover{border-color:#999;color:#333}.subject-btn.active{background:#b31b1b;border-color:#b31b1b;color:#fff}.search-box{display:flex;gap:12px;max-width:600px}.search-box input{flex:1;padding:12px 16px;font-family:var(--font-sans);font-size:14px;border:1px solid #ddd;border-radius:8px;outline:none;transition:border-color 0.2s}.search-box input:focus{border-color:#333}.search-results{margin-bottom:32px}.search-results h3{font-size:18px;margin-bottom:16px}.books-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(160px, 1fr));gap:20px}.book-card{display:flex;flex-direction:column;text-decoration:none;border-radius:8px;overflow:hidden;transition:transform 0.2s, box-shadow 0.2s;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,0.06)}.book-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,0.12)}.book-card-cover{aspect-ratio:2/3;background:#f5f5f5;overflow:hidden}.book-card-cover img{width:100%;height:100%;object-fit:cover}.book-card-placeholder{display:flex;align-items:center;justify-content:center;color:#999;font-size:12px;background:#f0f0f0}.book-card-info{padding:12px}.book-card-title{font-size:14px;font-weight:600;color:#333;margin:0 0 4px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-card-author{font-size:12px;color:#666;margin:0 0 4px}.book-card-year{font-size:11px;color:#999;margin:0}.book-card-category{display:inline-block;margin-top:6px;padding:2px 8px;background:#f0f0f0;border-radius:10px;font-size:10px;color:#666;text-transform:capitalize}.book-card-publisher{font-size:11px;color:#888;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-card-meta{display:flex;gap:8px;margin-top:4px}.book-card-pages{font-size:11px;color:#888}.books-count{font-size:14px;color:#666;margin-bottom:20px}.book-detail{padding:24px 0}.book-title-mobile{display:none}.book-header-row{display:flex;gap:32px}.book-cover-wrapper{width:200px;flex-shrink:0}.book-cover-title{font-size:14px;font-weight:600;text-align:center;margin-bottom:8px;color:var(--color-text);line-height:1.3}.book-cover-img{width:100%;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,0.12)}.book-cover-placeholder{width:100%;aspect-ratio:2/3;background:#f0f0f0;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:12px;color:#999}.book-info-grid{flex:1;display:flex;flex-direction:column;gap:12px}.book-info-meta{display:flex;flex-direction:column;gap:8px}.book-info-main{display:flex;flex-direction:column;gap:8px}.book-link{display:inline-block;padding:10px 20px;background:#b31b1b;color:#fff;text-decoration:none;border-radius:6px;font-size:14px;font-weight:500;width:fit-content}.book-link:hover{background:#8b1515}.book-title{font-size:26px;font-weight:700;color:#111;margin:0;line-height:1.2}.book-authors{font-size:15px;color:#555;margin:0}.book-link{display:inline-block;margin-top:8px;padding:10px 20px;background:#b31b1b;color:#fff;text-decoration:none;border-radius:6px;font-size:14px;font-weight:500;width:fit-content}.book-link:hover{background:#8b1515}.meta-list{display:flex;flex-direction:column;gap:8px}.meta-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #eee}.meta-row:last-child{border-bottom:none}.meta-label{font-size:13px;color:#888}.meta-value{font-size:13px;color:#333;font-weight:500}.book-badges{display:flex;flex-wrap:wrap;gap:8px}.book-badge{display:inline-block;padding:5px 12px;background:#f0f0f0;border-radius:14px;font-size:12px;color:#555}.book-link{display:inline-block;padding:8px 16px;background:#333;color:#fff;text-decoration:none;border-radius:6px;font-size:13px}.book-link:hover{background:#555}.book-section{margin-top:24px}.book-section h3{font-size:16px;margin:0 0 12px;color:#333}.book-subjects{display:flex;flex-wrap:wrap;gap:8px}.book-tag{font-size:13px;color:#666}.book-description{font-size:14px;line-height:1.6;color:#444;margin:0}.book-actions-row{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding-top:20px;border-top:1px solid #eee}.back-link{color:#333;text-decoration:none;font-size:14px}.back-link:hover{text-decoration:underline}.book-buttons{display:flex;gap:8px}.btn-edit-book,.btn-delete-book{padding:8px 14px;font-size:13px;border-radius:6px;cursor:pointer}.btn-edit-book{background:#333;color:#fff;border:none}.btn-delete-book{background:#fff;color:#c00;border:1px solid #c00}.book-header{display:flex;gap:32px;margin-bottom:24px}.book-cover-large{width:220px;flex-shrink:0;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,0.15)}.book-cover-large img{width:100%;height:auto;display:block}.book-info{flex:1;min-width:0}.book-title{font-size:24px;font-weight:700;color:#333;margin:0 0 8px;line-height:1.2}.book-authors{font-size:15px;color:#666;margin:0 0 12px}.book-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:#666;margin-bottom:16px}.book-details-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:12px;margin:16px 0;padding:16px;background:#f8f8f8;border-radius:8px}.book-detail-item{display:flex;flex-direction:column;gap:2px}.book-detail-label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:0.5px;font-weight:600}.book-detail-value{font-size:14px;color:#333;font-weight:500}.book-isbn{font-size:13px;color:#999;margin:0 0 12px}.book-isbn-info{display:flex;flex-direction:column;gap:4px}.book-languages{font-size:13px;color:#666;margin:0 0 12px}.detail-meta{font-size:12px;color:#888;margin:4px 0 0}.book-link{display:inline-block;padding:8px 16px;background:#333;color:#fff;text-decoration:none;border-radius:6px;font-size:13px;transition:background 0.2s;margin-right:8px}.book-link:hover{background:#555}.book-link-pdf{background:#b31b1b}.book-link-pdf:hover{background:#8b1515}.book-category-badge{display:inline-block;padding:4px 12px;background:#e8f4e8;color:#2d5a2d;border-radius:20px;font-size:12px;font-weight:500;text-transform:capitalize}.book-links{margin-bottom:16px}.book-full-description{font-size:14px;line-height:1.7;color:#333}.book-full-description p{margin-bottom:12px}.btn-edit-book{padding:8px 16px;font-size:13px;font-weight:500;border:1px solid #333;border-radius:6px;background:#333;color:#fff;cursor:pointer;margin-right:8px}.btn-edit-book:hover{background:#555}.btn-delete-book{padding:8px 16px;font-size:13px;font-weight:500;border:1px solid #cc0000;border-radius:6px;background:#fff;color:#cc0000;cursor:pointer}.btn-delete-book:hover{background:#cc0000;color:#fff}.book-actions-row{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:20px;border-top:1px solid #eee}.book-actions{display:flex;gap:8px}.back-link{color:#333;text-decoration:none;font-size:14px}.back-link:hover{text-decoration:underline}.book-actions-row{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:24px;border-top:1px solid #eee}.book-actions{display:flex;gap:8px}.back-link{color:#333;text-decoration:none;font-size:14px;font-weight:500}.back-link:hover{text-decoration:underline}.book-isbn-row{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.book-publishers{font-size:14px;color:#555;margin:0}.selected-book-preview{display:flex;gap:16px;padding:16px;background:#f9f9f9;border-radius:8px;margin-bottom:20px}.selected-book-preview img{width:80px;border-radius:4px}.selected-book-details h4{margin:0 0 4px;font-size:16px}.selected-book-details p{margin:0;font-size:13px;color:#666}footer{position:fixed;bottom:0;left:0;right:0;padding:12px 24px;font-family:'Lucida Grande', Helvetica, Arial, Verdana, sans-serif;font-size:12px;color:#666;border-top:1px solid #e0e0e0;background:#fff;z-index:999}.main-content{padding-bottom:60px}.footer-content{display:flex;justify-content:space-between;align-items:center}.footer-left{color:#444}.footer-right{color:#888}footer a{color:#0066cc;text-decoration:none}@media (max-width: 640px){nav{padding:0 16px}.nav-toggle{display:flex;order:2;z-index:101}.nav-menu{position:fixed;top:56px;left:0;right:0;background:#b31b1b;flex-direction:column;padding:0;gap:0;max-height:0;overflow:hidden;transition:max-height 0.3s ease}.nav-menu.open{max-height:200px;box-shadow:0 4px 6px rgba(0,0,0,0.1)}.nav-menu a{padding:16px 24px;border-bottom:1px solid rgba(255,255,255,0.1);display:block}.nav-menu a:last-child{border-bottom:none}.container{padding:0 16px}.paper-item:hover{margin:0 -16px;padding:16px}.nav-search kbd{display:none}.form-row{grid-template-columns:1fr}.paper-detail{padding:20px 0}.paper-detail .paper-title{font-size:20px;line-height:1.3}.paper-code-top{font-size:11px;word-break:break-all}.paper-detail .paper-authors{font-size:13px;line-height:1.4}.paper-detail .paper-meta{font-size:12px;flex-wrap:wrap;gap:8px}.paper-summary{font-size:15px;line-height:1.6;word-wrap:break-word}.paper-detail .paper-tags{flex-wrap:wrap;gap:6px}.paper-detail .paper-tag,.paper-detail .tag-badge{font-size:11px;padding:3px 8px}.main-content{padding-bottom:100px}footer{padding:12px 16px}.footer-content{flex-direction:column;gap:4px;text-align:center}.back-to-top{bottom:100px;right:16px;width:40px;height:40px}.books-grid{grid-template-columns:repeat(auto-fill, minmax(120px, 1fr));gap:12px}.book-title-mobile{display:block;font-size:18px;font-weight:700;color:#111;margin:0 0 12px}.book-header-row{display:flex;flex-direction:row;gap:12px;align-items:flex-start}.book-info-grid{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.book-cover-wrapper{width:100px;flex-shrink:0}.book-info-grid{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.book-title-mobile{font-size:20px}.book-info-meta{display:flex;flex-direction:column;gap:4px}.book-title{display:none}.book-authors{font-size:14px;color:#555}.book-link{display:inline-block;padding:8px 14px;font-size:13px;margin-top:8px}.meta-list{display:flex;flex-wrap:wrap;gap:8px}.meta-row{display:flex;gap:4px;border:none;padding:0}.meta-label{font-size:12px;color:#888}.meta-value{font-size:13px;color:#333;font-weight:500}.book-link{display:inline-block;padding:6px 12px;font-size:12px;margin-top:6px}.meta-list{display:flex;flex-wrap:wrap;gap:8px}.meta-row{display:flex;gap:4px;border:none;padding:0}.meta-label{font-size:11px;color:#888}.meta-value{font-size:11px;color:#333;font-weight:500}.meta-row{border:none;padding:0;display:flex;gap:4px}.meta-label{font-size:10px}.meta-value{font-size:10px}.book-cover-large{width:180px;margin:0 auto}.book-details-grid{grid-template-columns:1fr}.book-actions-row{flex-direction:column;gap:16px}.search-box{flex-direction:column}.search-box input,.search-box button{width:100%}}.side-panel{position:fixed;top:0;right:-420px;width:420px;height:100vh;background:#fff;box-shadow:-4px 0 20px rgba(0,0,0,0.1);z-index:1001;transition:right 0.3s ease;display:flex;flex-direction:column}.side-panel.open{right:0}.side-panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #eee;background:#fafafa}.side-panel-header h3{margin:0;font-size:18px;font-weight:600}.side-panel-close{background:none;border:none;font-size:28px;color:#888;cursor:pointer;line-height:1}.side-panel-close:hover{color:#333}.side-panel-content{flex:1;overflow-y:auto;padding:20px}.panel-section{margin-bottom:24px}.panel-section label{display:block;font-size:13px;font-weight:600;color:#666;margin-bottom:10px;text-transform:uppercase;letter-spacing:0.5px}.parent-nodes-list{margin-bottom:10px}.no-parents,.no-resources{font-size:13px;color:#999;font-style:italic}.parent-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#f0f0f0;border-radius:8px;margin-bottom:8px}.parent-item span{font-size:14px;color:#333}.remove-parent{background:none;border:none;color:#888;font-size:18px;cursor:pointer;padding:0 4px}.remove-parent:hover{color:#ff4757}.btn-add-parent{width:100%;padding:10px;border:2px dashed #ddd;border-radius:8px;background:none;color:#666;font-size:14px;cursor:pointer;transition:all 0.2s}.btn-add-parent:hover{border-color:#b31b1b;color:#b31b1b}.resources-list{margin-bottom:10px}.resource-item{display:flex;align-items:center;gap:10px;padding:10px;background:#f8f9fa;border-radius:8px;margin-bottom:8px}.resource-item a{flex:1;color:#0066cc;text-decoration:none;font-size:14px}.resource-item a:hover{text-decoration:underline}.resource-type-badge{font-size:16px}.remove-resource{background:none;border:none;color:#888;font-size:18px;cursor:pointer;padding:0 4px}.remove-resource:hover{color:#ff4757}.btn-add-resource{width:100%;padding:10px;border:2px dashed #ddd;border-radius:8px;background:none;color:#666;font-size:14px;cursor:pointer;transition:all 0.2s}.btn-add-resource:hover{border-color:#3498db;color:#3498db}.panel-section textarea{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-family:var(--font-sans);font-size:14px;resize:vertical;min-height:100px}.panel-section input{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-family:var(--font-sans);font-size:14px}.panel-actions{display:flex;gap:10px;padding-top:20px;border-top:1px solid #eee}.panel-actions .btn-primary{flex:1;padding:12px;background:#1a1a2e;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.panel-actions .btn-primary:hover{background:#2d2d44}.panel-actions .btn-danger{padding:12px 20px;background:#fff;color:#ff4757;border:1px solid #ff4757;border-radius:8px;font-size:14px;cursor:pointer}.panel-actions .btn-danger:hover{background:#ff4757;color:#fff}
