:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}#root{width:100%;height:100vh}.App{min-height:100vh;padding:0}.App{width:100%;min-height:100vh;padding:0;margin:0}.menu-bar{display:flex;align-items:center;background-color:#2c3e50;color:#fff;padding:12px 20px;box-shadow:0 2px 4px #0000001a;position:relative;z-index:1000}.hamburger-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:background-color .2s;border-radius:4px}.hamburger-button:hover{background-color:#ffffff1a}.hamburger-icon{width:24px;height:20px;display:flex;flex-direction:column;justify-content:space-between}.hamburger-icon span{display:block;height:3px;background-color:#fff;border-radius:2px;transition:all .3s}.app-title{margin:0 0 0 20px;font-size:24px;font-weight:600;flex:1}.view-toggle{display:flex;gap:10px;margin-left:auto;margin-right:20px}.view-button{background-color:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;white-space:nowrap}.view-button:hover{background-color:#fff3;border-color:#ffffff4d}.view-button.active{background-color:#3498db;border-color:#2980b9;font-weight:600}.view-button:active{transform:scale(.98)}.user-info{display:flex;align-items:center;gap:15px}.user-name{font-size:14px;color:#ffffffe6;font-weight:500}.logout-button{background-color:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.logout-button:hover{background-color:#fff3;border-color:#ffffff4d}.logout-button:active{transform:scale(.98)}.split-view{display:flex;height:calc(100vh - 56px);position:relative}.overlay{display:none;position:fixed;inset:0;background-color:#00000080;z-index:800}.left-panel{position:absolute;left:-400px;top:0;bottom:0;width:400px;background-color:#fff;box-shadow:2px 0 8px #0000001a;overflow:auto;transition:left .3s ease-in-out;z-index:900}.left-panel.open{left:0}.right-panel{flex:1;min-width:0;overflow:hidden;margin:20px}.error-container{max-width:800px;margin:40px auto;padding:20px;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.error-container h1{margin:0 0 15px;font-size:24px;color:#333}.error-container p{margin:10px 0}@media(max-width:768px){.overlay{display:block}.menu-bar{padding:10px 16px}.app-title{margin-left:16px;font-size:20px}.split-view{height:calc(100vh - 52px)}.left-panel{width:100%;left:-100%}.right-panel{margin:10px}}@media(max-width:480px){.menu-bar{padding:8px 12px;flex-wrap:wrap}.app-title{margin-left:12px;font-size:18px}.view-toggle{order:3;width:100%;margin-left:0;margin-right:0;margin-top:8px}.view-button{flex:1;padding:6px 12px;font-size:12px}.hamburger-icon{width:22px;height:18px}.right-panel{margin:8px}.user-info{gap:10px}.user-name{display:none}.logout-button{padding:6px 12px;font-size:13px}}.floating-add-button{position:fixed;bottom:30px;right:30px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;font-size:2rem;font-weight:300;cursor:pointer;box-shadow:0 4px 12px #667eea66;transition:all .3s ease;z-index:999;display:flex;align-items:center;justify-content:center;line-height:1}.floating-add-button:hover{transform:scale(1.1) rotate(90deg);box-shadow:0 6px 20px #667eea99}.floating-add-button:active{transform:scale(1.05) rotate(90deg)}@media(max-width:768px){.floating-add-button{bottom:20px;right:20px;width:50px;height:50px;font-size:1.8rem}}.tree-node-content{display:flex;align-items:center;padding:6px 8px;cursor:pointer;transition:background-color .2s;border-radius:4px;margin:2px 0}.tree-node-content.has-children{cursor:pointer}.tree-node-content:hover{background-color:#e8f4f8}.tree-node-content.selected{background-color:#b3d9f2;font-weight:600}.tree-node-content.selected:hover{background-color:#9fc9e8}.tree-node-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:6px;font-size:14px;color:#666;font-weight:700}.tree-node-spacer{display:inline-block;width:22px}.tree-node-text{font-size:14px;color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.tree-node-children{margin-left:0}@media(max-width:768px){.tree-node-content{padding:10px 12px;margin:4px 0;min-height:44px}.tree-node-icon{width:20px;height:20px;margin-right:8px;font-size:16px}.tree-node-text{font-size:15px}.tree-node-spacer{width:28px}}@media(max-width:480px){.tree-node-content{padding:12px}.tree-node-text{font-size:16px}}.tree-view-container{height:100%;display:flex;flex-direction:column;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.tree-view-header{padding:20px;border-bottom:2px solid #e0e0e0;flex-shrink:0}.tree-view-header h1{margin:0 0 15px;font-size:24px;color:#333;font-weight:600}.tree-view-controls{display:flex;gap:15px;align-items:center}.tree-view-controls label{display:flex;align-items:center;gap:8px;font-size:14px;color:#555;cursor:pointer}.tree-view-controls input[type=checkbox]{cursor:pointer;width:16px;height:16px}.tree-view-content{flex:1;overflow:auto;padding:20px}.tree-view-content::-webkit-scrollbar{width:10px}.tree-view-content::-webkit-scrollbar-track{background:#f1f1f1}.tree-view-content::-webkit-scrollbar-thumb{background:#888;border-radius:5px}.tree-view-content::-webkit-scrollbar-thumb:hover{background:#555}@media(max-width:768px){.tree-view-container{border-radius:0;box-shadow:none}.tree-view-header{padding:16px}.tree-view-header h1{font-size:20px;margin:0 0 12px}.tree-view-controls{flex-direction:column;align-items:flex-start;gap:10px}.tree-view-controls label{font-size:15px;padding:8px 0;min-height:44px}.tree-view-content{padding:16px;-webkit-overflow-scrolling:touch}}@media(max-width:480px){.tree-view-header{padding:12px}.tree-view-header h1{font-size:18px}.tree-view-content{padding:12px}}.table-view-container{height:100%;display:flex;flex-direction:column;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.table-view-header{padding:20px;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.table-view-header h2{margin:0;font-size:24px;color:#333;font-weight:600}.table-view-count{font-size:14px;color:#666;background-color:#f0f0f0;padding:4px 12px;border-radius:12px}.mobile-hint{display:none;padding:8px 16px;background-color:#e3f2fd;color:#1976d2;font-size:12px;text-align:center;border-bottom:1px solid #bbdefb}.table-view-loading,.table-view-empty{padding:40px;text-align:center;color:#666;font-size:16px}.table-view-scroll{flex:1;overflow:auto;position:relative}.books-table{width:100%;border-collapse:collapse;font-size:14px}.books-table thead{position:sticky;top:0;background-color:#f8f9fa;z-index:10}.books-table th{padding:12px 16px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;border-right:1px solid #e9ecef;white-space:nowrap}.books-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .15s ease}.books-table th.sortable:hover{background-color:#e9ecef}.books-table th.narrow-column{width:1%;white-space:nowrap}.books-table tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .15s ease}.books-table tbody tr:nth-child(2n){background-color:#f8f9fa}.books-table tbody tr:hover{background-color:#e9ecef}.books-table td{padding:12px 16px;color:#495057;border-right:1px solid #e9ecef}.cell-number{text-align:left;font-variant-numeric:tabular-nums;width:1%;white-space:nowrap}.cell-author{font-weight:500;min-width:150px}.cell-title{min-width:200px;font-weight:500;color:#333}.cell-series{min-width:150px;color:#666}.cell-date{white-space:nowrap;font-variant-numeric:tabular-nums}.cell-rating{text-align:center;font-weight:500;font-size:16px;white-space:nowrap}.star-rating{display:inline-block;white-space:nowrap}.star-full{color:#fbbf24}.star-half{position:relative;display:inline-block;color:#d1d5db}.star-half:before{content:"★";position:absolute;left:0;color:#fbbf24;width:50%;overflow:hidden}.table-view-scroll::-webkit-scrollbar{width:10px;height:10px}.table-view-scroll::-webkit-scrollbar-track{background:#f1f1f1}.table-view-scroll::-webkit-scrollbar-thumb{background:#888;border-radius:5px}.table-view-scroll::-webkit-scrollbar-thumb:hover{background:#555}@media(max-width:768px){.mobile-hint{display:block}.table-view-header{padding:12px 16px;flex-direction:column;align-items:flex-start;gap:8px}.table-view-header h2{font-size:20px}.table-view-count{font-size:13px}.table-view-scroll{overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.books-table th{padding:10px 12px;font-size:13px;min-height:44px}.books-table td{padding:10px 12px;font-size:14px}.books-table th:nth-child(6),.books-table td:nth-child(6),.books-table th:nth-child(7),.books-table td:nth-child(7),.books-table th:nth-child(8),.books-table td:nth-child(8),.books-table th:nth-child(9),.books-table td:nth-child(9){display:none}.cell-author{min-width:120px}.cell-title{min-width:150px}.cell-series{min-width:100px}}@media(max-width:480px){.table-view-header{padding:10px 12px}.table-view-header h2{font-size:18px}.books-table th{padding:8px 10px;font-size:12px}.books-table td{padding:8px 10px;font-size:13px}.cell-author{min-width:100px}.cell-title{min-width:120px}}.tile-view-container{width:100%;height:100%;overflow-y:auto;padding:20px;background-color:#f5f5f5}.tiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(312px,1fr));gap:20px;padding:10px}.book-tile{width:312px;height:155px;display:flex;background-color:#e6f2ff;border:2px solid #000000;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s;cursor:pointer}.book-tile:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003}.tile-image{flex-shrink:0;width:100px;height:100%;display:flex;align-items:center;justify-content:center;background-color:#f0f0f0;overflow:hidden;position:relative}.tile-image img{width:100%;height:100%;object-fit:cover}.image-loading-spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;border:3px solid #f3f3f3;border-top:3px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;pointer-events:none}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.tile-content{flex:1;display:flex;flex-direction:column;padding:0;overflow:hidden}.tile-title{background-color:#000;color:#fff;padding:8px 12px;font-weight:700;font-size:14px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:40px}.tile-info{flex:1;padding:10px 12px;display:flex;flex-direction:column;gap:6px;background-color:#e6f2ff;overflow:hidden}.tile-author{color:#000;font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-series{color:#000;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-rating{margin-top:auto}.star-rating{color:gold;font-size:16px;letter-spacing:2px}.star-full{color:gold}.star-half{color:gold;opacity:.5}.unrated{color:#666;font-size:12px;font-style:italic}.loading-message,.no-books-message{display:flex;align-items:center;justify-content:center;height:100%;font-size:18px;color:#666}@media(max-width:768px){.tiles-grid{grid-template-columns:1fr;justify-items:center}.tile-view-container{padding:10px}}@media(max-width:480px){.book-tile{width:302px;max-width:calc(100vw - 20px)}.tile-view-container{padding:5px}.tiles-grid{padding:5px;gap:15px}}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:450px;padding:40px;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:30px}.auth-logo{max-width:250px;width:100%;height:auto;margin-bottom:15px}.auth-header h1{color:#333;font-size:28px;margin-bottom:8px;font-weight:600}.auth-header p{color:#666;font-size:14px;margin:0}.auth-tabs{display:flex;gap:10px;margin-bottom:30px;border-bottom:2px solid #e0e0e0}.auth-tab{flex:1;padding:12px;background:none;border:none;border-bottom:3px solid transparent;color:#666;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;margin-bottom:-2px}.auth-tab:hover{color:#667eea}.auth-tab.active{color:#667eea;border-bottom-color:#667eea}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#333;font-size:14px;font-weight:500}.form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:15px;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#667eea}.form-group input.error{border-color:#ef4444}.form-error{color:#ef4444;font-size:13px;margin-top:-12px}.auth-submit{padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;margin-top:10px}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-error{background:#fee;color:#c33;padding:12px;border-radius:8px;font-size:14px;text-align:center;margin-bottom:20px}.auth-footer{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0;color:#666;font-size:14px}.auth-footer button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;padding:0;margin-left:5px;text-decoration:underline}.auth-footer button:hover{color:#764ba2}.password-hint{font-size:12px;color:#666;margin-top:-12px;line-height:1.4}.auth-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.coming-soon-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.coming-soon-modal{background:#fff;border-radius:16px;padding:40px;max-width:400px;width:90%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.coming-soon-modal h2{color:#333;font-size:28px;margin-bottom:15px;font-weight:600}.coming-soon-modal p{color:#666;font-size:16px;line-height:1.6;margin-bottom:10px}.coming-soon-subtitle{font-size:14px!important;color:#999!important;margin-bottom:25px!important}.coming-soon-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:12px 32px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.coming-soon-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.coming-soon-button:active{transform:translateY(0)}@media(max-width:480px){.auth-container{padding:30px 20px}.auth-logo{max-width:180px}.auth-header h1{font-size:24px}.coming-soon-modal{padding:30px 20px}.coming-soon-modal h2{font-size:24px}}.landing-page{width:100%;min-height:100vh;height:100vh;position:relative;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh;background:linear-gradient(135deg,#667eea,#764ba2);overflow-x:hidden;overflow-y:auto}.landing-content{z-index:1;max-width:800px;width:100%;padding:20px;text-align:center}.landing-hero{background:#fffffff2;border-radius:20px;padding:60px 40px;box-shadow:0 20px 60px #0000004d;animation:fadeInUp .8s ease-out;margin:0 auto}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.landing-logo{max-width:300px;width:100%;height:auto;margin-bottom:30px;animation:fadeIn 1s ease-out .2s both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.landing-title{font-size:2.5rem;font-weight:700;color:#333;margin-bottom:20px;animation:fadeIn 1s ease-out .4s both;line-height:1.2}.landing-title-line1{font-size:2rem;font-weight:500;margin-bottom:5px}.landing-title-line2{font-size:2.8rem;font-weight:700}.landing-description{font-size:1.2rem;color:#555;line-height:1.8;margin-bottom:40px;max-width:600px;margin-left:auto;margin-right:auto;animation:fadeIn 1s ease-out .6s both}.landing-cta-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 48px;font-size:1.2rem;font-weight:600;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66;animation:fadeIn 1s ease-out .8s both}.landing-cta-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.landing-cta-button:active{transform:translateY(0)}.landing-corner-image{position:fixed;bottom:0;right:0;max-width:350px;max-height:350px;width:25vw;height:auto;opacity:.9;pointer-events:none;animation:slideInCorner 1s ease-out .5s both;z-index:0}@keyframes slideInCorner{0%{opacity:0;transform:translate(50px,50px)}to{opacity:.9;transform:translate(0)}}@media(max-width:768px){.landing-page{padding:20px 0;padding-top:8vh}.landing-content{padding:20px 15px;max-width:95%}.landing-hero{padding:40px 25px;margin:0 auto;max-width:90%}.landing-logo{max-width:180px;margin-bottom:20px}.landing-title{font-size:1.8rem}.landing-title-line1{font-size:1.5rem}.landing-title-line2{font-size:2rem}.landing-description{font-size:1rem;margin-bottom:30px}.landing-cta-button{padding:14px 36px;font-size:1rem}.landing-corner-image{max-width:200px;max-height:200px;width:30vw}}@media(max-width:480px){.landing-page{padding:15px 0;padding-top:6vh}.landing-content{padding:15px 10px}.landing-hero{padding:30px 20px;border-radius:15px;max-width:92%}.landing-logo{max-width:140px;margin-bottom:15px}.landing-title{font-size:1.4rem;margin-bottom:15px}.landing-title-line1{font-size:1.2rem}.landing-title-line2{font-size:1.6rem}.landing-description{font-size:.9rem;margin-bottom:25px;line-height:1.6}.landing-cta-button{padding:12px 28px;font-size:.95rem}.landing-corner-image{max-width:150px;max-height:150px;width:35vw}}@media(min-height:800px)and (max-width:480px){.landing-page{padding-top:15vh;align-items:center}.landing-content{margin-top:-5vh}}@media(min-height:900px)and (max-width:480px){.landing-page{padding-top:0;align-items:center}.landing-content{margin-top:0}}@media(min-width:769px)and (max-width:1024px){.landing-content{padding:30px 20px}.landing-hero{padding:50px 35px}.landing-corner-image{max-width:280px;max-height:280px;width:25vw}}.book-entry-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;overflow-y:auto;padding:20px}.book-entry-modal{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000004d;max-width:1200px;width:100%;max-height:90vh;display:flex;flex-direction:column;margin:auto}.book-entry-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:2px solid #e0e0e0;background-color:#f8f9fa;border-radius:12px 12px 0 0}.book-entry-header h2{margin:0;color:#333;font-size:1.8rem}.close-button{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s,color .2s}.close-button:hover{background-color:#e0e0e0;color:#333}.book-entry-form{display:flex;flex-direction:column;flex:1;overflow:hidden}.form-content{display:grid;grid-template-columns:400px 1fr;gap:30px;padding:30px;overflow-y:auto;flex:1}.form-column{display:flex;flex-direction:column;gap:20px}.form-section{background-color:#f8f9fa;border-radius:8px;padding:20px;border:1px solid #e0e0e0}.form-section h3{margin:0 0 15px;color:#333;font-size:1.2rem;border-bottom:2px solid #667eea;padding-bottom:8px}.cover-placeholder{display:flex;justify-content:center;margin-bottom:10px}.placeholder-image{width:100px;height:155px;background-color:#e0e0e0;border:2px dashed #999;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#666;font-size:.9rem;text-align:center}.placeholder-image span{font-size:2.5rem;margin-bottom:8px}.placeholder-image p{margin:5px 0;font-weight:500}.placeholder-image small{font-size:.75rem;color:#999}.form-group{margin-bottom:15px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:6px;font-weight:600;color:#444;font-size:.95rem}.form-group input[type=text],.form-group input[type=number],.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #ccc;border-radius:6px;font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.field-hint{display:block;margin-top:4px;font-size:.85rem;color:#666;font-style:italic}.author-input-group{display:flex;gap:8px;margin-bottom:8px}.author-input-group input{flex:1}.remove-button{background-color:#dc3545;color:#fff;border:none;border-radius:4px;width:32px;height:38px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.remove-button:hover{background-color:#c82333}.add-button{background-color:#667eea;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:.9rem;cursor:pointer;transition:background-color .2s;margin-top:8px;font-weight:500}.add-button:hover{background-color:#5568d3}.date-inputs{display:flex;gap:8px}.date-input-small{width:70px}.date-input-medium{flex:1}.rating-input-group{display:flex;align-items:center;gap:15px}.rating-slider{flex:1;height:8px;border-radius:4px;background:linear-gradient(to right,#ddd,#667eea);outline:none;-webkit-appearance:none}.rating-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;box-shadow:0 2px 4px #0003}.rating-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.rating-value{font-weight:700;font-size:1.1rem;color:#667eea;min-width:50px;text-align:right}.rating-stars{font-size:1.2rem;color:gold;margin-top:5px}.checkbox-label,.radio-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400;color:#333}.checkbox-label input[type=checkbox],.radio-label input[type=radio]{width:auto;margin:0;cursor:pointer}.radio-group{display:flex;gap:20px;flex-wrap:wrap}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.subject-input-group{display:flex;gap:8px}.subject-input-group input{flex:1}.subjects-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.subject-tag{background-color:#667eea;color:#fff;padding:6px 12px;border-radius:20px;font-size:.9rem;display:flex;align-items:center;gap:8px}.remove-tag-button{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.remove-tag-button:hover{background-color:#fff3}.form-actions{display:flex;justify-content:flex-end;gap:15px;padding:20px 30px;border-top:2px solid #e0e0e0;background-color:#f8f9fa;border-radius:0 0 12px 12px}.cancel-button,.save-button{padding:12px 30px;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.cancel-button{background-color:#6c757d;color:#fff}.cancel-button:hover{background-color:#5a6268}.save-button{background-color:#667eea;color:#fff}.save-button:hover{background-color:#5568d3;box-shadow:0 4px 8px #667eea4d}@media(max-width:1024px){.form-content{grid-template-columns:1fr}}@media(max-width:768px){.book-entry-modal{max-width:100%;margin:10px;max-height:95vh}.book-entry-header{padding:15px 20px}.book-entry-header h2{font-size:1.4rem}.form-content{padding:20px;gap:20px}.form-section{padding:15px}.form-row{grid-template-columns:1fr}.form-actions{padding:15px 20px;flex-direction:column-reverse}.cancel-button,.save-button{width:100%}}@media(max-width:480px){.book-entry-overlay{padding:10px}.date-inputs{flex-direction:column}.date-input-small,.date-input-medium{width:100%}.radio-group{flex-direction:column;gap:10px}}
