.bookshelf-viewer{position:relative;width:100vw;height:100vh}.scene-container{position:relative;width:100%;height:100%}.controls{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:10px}.nav-button,.add-book-button,.view-button{padding:12px 24px;font-size:16px;color:#fff;border:none;border-radius:4px;cursor:pointer;box-shadow:0 2px 4px #0003;transition:background-color .3s}.nav-button{background-color:#2196f3}.nav-button:hover:not(:disabled){background-color:#1976d2}.view-button{background-color:#9c27b0}.view-button:hover:not(:disabled){background-color:#7b1fa2}.add-book-button{background-color:#4caf50}.add-book-button:hover:not(:disabled){background-color:#45a049}.nav-button:disabled,.view-button:disabled,.add-book-button:disabled{background-color:#ccc;cursor:not-allowed}.parse-pdf-button{padding:12px 24px;font-size:16px;color:#fff;background-color:#ff5722;border:none;border-radius:4px;cursor:pointer;box-shadow:0 2px 4px #0003;transition:background-color .3s}.parse-pdf-button:hover{background-color:#f4511e}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;padding:20px;border-radius:8px;min-width:300px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-close{background:none;border:none;font-size:20px;cursor:pointer}.url-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.url-input-row{display:flex;align-items:center;gap:8px;padding:8px;background:#f5f5f5;border-radius:4px}.remove-url{background:#f44;color:#fff;border:none;border-radius:4px;padding:0 10px;cursor:pointer}.add-url{background:#4caf50;color:#fff;border:none;border-radius:4px;padding:8px 16px;cursor:pointer;margin-bottom:20px}.submit-urls{background:#2196f3;color:#fff;border:none;border-radius:4px;padding:8px 16px;cursor:pointer;width:100%}#VRButton{position:fixed!important;bottom:90px!important;padding:12px 24px!important;border:1px solid #fff!important;border-radius:4px!important;background:#000c!important;color:#fff!important;font:13px sans-serif!important;text-align:center!important;opacity:.8!important;outline:none!important;z-index:999!important;cursor:pointer!important}#VRButton:hover{background:#000!important;opacity:1!important}.angle-control{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;background:#ffffffe6;padding:10px 20px;border-radius:20px;box-shadow:0 2px 5px #0003;z-index:1000}.angle-slider{width:200px;height:20px;-webkit-appearance:none;background:transparent}.angle-slider::-webkit-slider-thumb{-webkit-appearance:none;height:16px;width:16px;border-radius:50%;background:#4caf50;cursor:pointer;margin-top:-6px}.angle-slider::-webkit-slider-runnable-track{width:100%;height:4px;background:#ddd;border-radius:2px}.angle-slider:focus{outline:none}.reading-mode-button{padding:8px 16px;background:#9c27b0;color:#fff;border:none;border-radius:4px;cursor:pointer;white-space:nowrap;transition:background-color .3s}.reading-mode-button:hover{background:#7b1fa2}.page-controls{display:flex;gap:1rem;justify-content:center;align-items:center;margin-top:1rem}.page-nav-button{padding:.5rem 1rem;font-size:1.5rem;background-color:#4a4a4a;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.page-nav-button:hover{background-color:#666}.page-nav-button:active{background-color:#333}.uniform-mode-button{padding:.5rem 1rem;background-color:#ff9800;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;font-size:1rem;white-space:nowrap}.uniform-mode-button:hover{background-color:#f57c00}.uniform-mode-button:active{background-color:#ef6c00}.upload-section{margin:20px 0;text-align:center}.file-input{width:100%;padding:10px;border:2px dashed #ccc;border-radius:4px;margin-bottom:10px}.or-divider{color:#666;margin:15px 0}.file-entry{display:flex;justify-content:space-between;align-items:center;padding:8px;background:#f5f5f5;border-radius:4px;margin-bottom:8px}.file-entry span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:10px}.tabs{display:flex;border-bottom:1px solid #ddd;margin-bottom:20px}.tab{padding:10px 20px;border:none;background:none;cursor:pointer;font-size:16px;color:#666;border-bottom:2px solid transparent;transition:all .3s ease}.tab.active{color:#2196f3;border-bottom:2px solid #2196F3}.tab:hover{color:#2196f3}.tab-content{min-height:200px}.file-upload-area{border:2px dashed #ccc;border-radius:8px;padding:20px;text-align:center;cursor:pointer;transition:border-color .3s ease;margin-bottom:20px}.file-upload-area:hover{border-color:#2196f3}.file-input{display:none}.file-input-label{cursor:pointer;display:block}.upload-icon{font-size:32px;margin-bottom:10px}.upload-text{color:#666}.file-list{margin-top:20px}.file-list h3{margin-bottom:10px;color:#333;font-size:16px}.file-entry{background:#f5f5f5;padding:8px 12px;border-radius:4px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.submit-urls:disabled{background-color:#ccc;cursor:not-allowed}.url-tab,.file-tab{padding:10px 0}.count-selector{display:flex;align-items:center;gap:8px;margin:0 8px}.count-label{color:#666;font-size:14px;white-space:nowrap}.count-input{width:60px;padding:4px 8px;border:1px solid #ccc;border-radius:4px;font-size:14px;text-align:center}.count-input:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f31a}.url-input-row,.file-entry{display:flex;align-items:center;gap:8px;padding:8px;background:#f5f5f5;border-radius:4px}.url-input{flex:1;background:#fff}.count-input::-webkit-inner-spin-button,.count-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.count-input[type=number]{-moz-appearance:textfield}.download-button{position:absolute;top:10px;right:10px;padding:8px 16px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;z-index:1000;transition:background-color .3s}.download-button:hover{background-color:#45a049}.download-button:active{background-color:#3d8b40}.modal-buttons{display:flex;flex-direction:column;gap:10px;margin:20px 0}.modal-buttons button{padding:10px;border:none;border-radius:4px;background-color:#4caf50;color:#fff;cursor:pointer}.modal-buttons button:hover{background-color:#45a049}.close-button{width:100%;padding:8px;border:none;border-radius:4px;background-color:#f44336;color:#fff;cursor:pointer}.close-button:hover{background-color:#da190b}.load-collector-button{padding:8px 16px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer}.load-collector-button:hover{background-color:#1976d2}.book-design-studio{height:100vh;width:100%;display:flex;flex-direction:column}.studio-layout{flex:1;display:flex;flex-direction:row;height:100%}.side-controls{width:250px;padding:20px;background-color:#f5f5f5;border-right:1px solid #ddd;display:flex;flex-direction:column;gap:16px}.scene-container{flex:1;position:relative;background:#f0f0f0;min-height:0;display:flex}.scene-container canvas{width:100%!important;height:100%!important;display:block}.control-group{display:flex;flex-direction:column;gap:10px}.button-like{display:inline-block;padding:8px 16px;background-color:#4caf50;color:#fff;border-radius:4px;cursor:pointer;border:none;font-size:14px;text-align:center}.button-like:hover{background-color:#45a049}.clear-button{padding:8px 16px;background-color:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px}.clear-button:hover{background-color:#da190b}.main-nav{padding:1rem;background-color:#333}.main-nav a{color:#fff;text-decoration:none;margin-right:1rem;padding:.5rem 1rem}.main-nav a:hover{background-color:#444;border-radius:4px}.view-mode-button{padding:8px 16px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s}.view-mode-button:hover{background-color:#1976d2}.view-mode-button.active{background-color:#1565c0}.threejs-container{position:relative;width:100%;height:100%}.submit-button{padding:8px 16px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;margin-top:10px;transition:background-color .3s}.submit-button:hover{background-color:#45a049}.submit-button:disabled{background-color:#ccc;cursor:not-allowed}.selected-pdf-info{margin-top:1rem;padding:1rem;background:#f5f5f5;border-radius:4px}.selected-pdf-info h4{margin:0 0 .5rem;font-size:1rem}.selected-pdf-info p{margin:0 0 .5rem;word-break:break-all;font-size:.9rem}.book-controls-overlay{position:absolute;bottom:20px;left:50%;transform:translate(-50%);z-index:10;background-color:#ffffffe6;padding:10px;border-radius:8px;box-shadow:0 2px 8px #0003}.book-controls-overlay .angle-control{display:flex;flex-direction:column;gap:10px;min-width:200px}.book-controls-overlay .angle-slider{width:100%}.book-controls-overlay button{padding:8px 16px;border:none;border-radius:4px;background-color:#4a90e2;color:#fff;cursor:pointer;transition:background-color .2s}.book-controls-overlay button:hover{background-color:#357abd}.book-controls-overlay .page-controls{display:flex;gap:10px;justify-content:center}.book-controls-overlay .page-nav-button{font-size:1.2em;padding:4px 12px}
