.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;max-width:400px;width:100%;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;pointer-events:auto;animation:slideIn .3s ease-out;border-left:4px solid}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;border-radius:50%}.toast-message{flex:1;font-size:.9375rem;line-height:1.5;color:#2d3748}.toast-close{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;font-size:1.5rem;line-height:1;color:#718096;transition:color .2s;padding:0}.toast-close:hover{color:#2d3748}.toast-success{border-left-color:#48bb78}.toast-success .toast-icon{color:#48bb78;background:#f0fff4}.toast-error{border-left-color:#f56565}.toast-error .toast-icon{color:#f56565;background:#fff5f5}.toast-warning{border-left-color:#ed8936}.toast-warning .toast-icon{color:#ed8936;background:#fffaf0}.toast-info{border-left-color:#4299e1}.toast-info .toast-icon{color:#4299e1;background:#ebf8ff}@media (max-width: 640px){.toast-container{top:auto;bottom:1rem;left:1rem;right:1rem;max-width:none}.toast{padding:.875rem 1rem}.toast-message{font-size:.875rem}}.spinner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:9998}.spinner-wrapper{display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner-wrapper.spinner-fullscreen{padding:2rem}.spinner{display:inline-block;position:relative}.spinner-small{width:24px;height:24px}.spinner-medium{width:40px;height:40px}.spinner-large{width:64px;height:64px}.spinner-circle{box-sizing:border-box;display:block;position:absolute;width:100%;height:100%;border:3px solid;border-radius:50%;animation:spinner-rotate 1.2s cubic-bezier(.5,0,.5,1) infinite;border-color:#667eea transparent transparent transparent}.spinner-small .spinner-circle{border-width:2px}.spinner-large .spinner-circle{border-width:4px}.spinner-circle:nth-child(1){animation-delay:-.45s}.spinner-circle:nth-child(2){animation-delay:-.3s}.spinner-circle:nth-child(3){animation-delay:-.15s}@keyframes spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-message{font-size:1rem;color:#4a5568;text-align:center;margin:0;font-weight:500}.spinner-inline{display:inline-flex;align-items:center;gap:.5rem}.spinner-inline .spinner{vertical-align:middle}.spinner-inline .spinner-message{display:inline;font-size:.875rem}.profile-editor-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;overflow-y:auto}.profile-editor-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.profile-editor-header{display:flex;align-items:center;justify-content:space-between;padding:2rem;border-bottom:1px solid #e2e8f0;flex-shrink:0}.profile-editor-header h1{font-size:1.75rem;color:#213547;margin:0}.close-button{background:none;border:none;font-size:2rem;color:#6c757d;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-button:hover{background:#f8f9fa;color:#213547}.profile-editor-content{padding:2rem;overflow-y:auto;flex:1}.profile-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e2e8f0}.profile-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.profile-section h2{font-size:1.25rem;color:#213547;margin-bottom:1rem}.section-description{color:#6c757d;font-size:.875rem;margin-bottom:1rem}.form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:#495057;font-size:.875rem}.form-input{width:100%;padding:.75rem;border:1px solid #dee2e6;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:#646cff;box-shadow:0 0 0 3px #646cff1a}.form-input.disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.form-help{display:block;font-size:.75rem;color:#6c757d;margin-top:.25rem}.form-help.security-note{color:#dc3545;font-weight:500}.link-group{background:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:1rem;position:relative}.link-group .form-group{margin-bottom:.75rem}.link-group .form-group:last-child{margin-bottom:0}.btn-remove-link{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background-color .2s;margin-top:.5rem}.btn-remove-link:hover{background:#c82333}.tag{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#646cff;color:#fff;border-radius:20px;font-size:.875rem}.tag-remove:hover{background:#fff3}.tag-input-group{display:flex;gap:.5rem;align-items:flex-start;width:100%}.tag-input-wrapper{position:relative;flex:1;min-width:0}.tag-input-group .form-input{width:100%}.tag-input-group .btn-secondary{flex-shrink:0;white-space:nowrap;min-width:fit-content;max-width:120px}.tag-suggestion-item:hover,.tag-suggestion-item.selected{background:#f7fafc;color:#646cff}.profile-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid #e2e8f0;background:#f8f9fa;flex-shrink:0}.error-message{text-align:center;padding:2rem;color:#dc3545;font-size:1.1rem}@media (max-width: 768px){.profile-editor-overlay{padding:0}.profile-editor-modal{max-height:100vh;border-radius:0}.profile-editor-header,.profile-editor-content,.profile-actions{padding:1.5rem}.form-row{grid-template-columns:1fr}.profile-actions{flex-direction:column-reverse}.profile-actions button{width:100%}.tag-input-group{flex-direction:column;gap:.75rem}.tag-input-wrapper{min-width:auto}.tag-input-group button{width:100%}}@media (prefers-color-scheme: dark){.profile-editor-modal{background:#2a2a2a}.profile-editor-header{border-bottom-color:#3a3a3a}.profile-editor-header h1{color:#ffffffde}.close-button{color:#fff9}.close-button:hover{background:#3a3a3a;color:#ffffffde}.profile-section{border-bottom-color:#3a3a3a}.profile-section h2,.form-group label{color:#ffffffde}.form-input{background:#1e1e1e;border-color:#3a3a3a;color:#ffffffde}.form-input.disabled{background:#2a2a2a;color:#ffffff80}.form-help.security-note{color:#ff6b6b}.link-group{background:#1e1e1e}.profile-actions{border-top-color:#3a3a3a;background:#1e1e1e}.tag-suggestions-dropdown{background:#2a2a2a;border-color:#3a3a3a}.tag-suggestion-item{border-bottom-color:#3a3a3a;color:#ffffffde}.tag-suggestion-item:hover,.tag-suggestion-item.selected{background:#3a3a3a;color:#646cff}}.checkbox-group{margin-top:1rem}.checkbox-label{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;font-size:.9375rem;color:#2d3748}.checkbox-input{width:20px;height:20px;cursor:pointer;margin-top:.125rem;flex-shrink:0}.checkbox-label span{flex:1}.help-text{margin:.5rem 0 0 2rem;font-size:.8125rem;color:#718096;font-style:italic}.photo-upload-section{display:flex;flex-direction:column;gap:1rem}.current-photo{display:flex;align-items:center;gap:1rem}.profile-photo-preview{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid #e2e8f0}.no-photo{display:flex;align-items:center;gap:1rem}.photo-placeholder{width:80px;height:80px;border-radius:50%;background:#f8f9fa;border:2px dashed #dee2e6;display:flex;align-items:center;justify-content:center;color:#6c757d;font-size:.75rem}.photo-upload-controls{display:flex;flex-direction:column;gap:.5rem}.photo-input{display:none}.photo-input+label{display:inline-block;padding:.5rem 1rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s;text-align:center;max-width:150px}.photo-input+label:hover:not(.disabled){background:#e9ecef;border-color:#adb5bd}.photo-input+label.disabled{opacity:.6;cursor:not-allowed}.btn-remove-photo{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background-color .2s;max-width:150px}.btn-remove-photo:hover:not(:disabled){background:#c82333}.btn-remove-photo:disabled{opacity:.6;cursor:not-allowed}@media (prefers-color-scheme: dark){.photo-placeholder{background:#1e1e1e;border-color:#3a3a3a;color:#fff9}.profile-photo-preview{border-color:#3a3a3a}.photo-input+label{background:#1e1e1e;border-color:#3a3a3a;color:#ffffffde}.photo-input+label:hover:not(.disabled){background:#2a2a2a;border-color:#4a4a4a}}.password-change-section{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;margin-top:1rem}.password-actions{display:flex;gap:.75rem;margin-top:.5rem}.password-actions button{flex:1}@media (max-width: 768px){.password-actions{flex-direction:column}.password-actions button{width:100%}}@media (prefers-color-scheme: dark){.password-change-section{background:#1e1e1e}}.dashboard-layout{display:flex;min-height:100vh;width:100%}.dashboard-mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:60px;background-color:#1a1a2e;color:#fff;align-items:center;padding:0 1rem;z-index:200;box-shadow:0 2px 8px #0000001a}.mobile-menu-toggle{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:8px;transition:background-color .2s}.mobile-menu-toggle:hover{background-color:#ffffff1a}.mobile-menu-toggle:active{background-color:#fff3}.hamburger-icon{font-size:1.75rem;line-height:1}.mobile-header-title{font-size:1.25rem;font-weight:700;margin:0;flex:1;text-align:center}.mobile-header-spacer{width:44px}.mobile-menu-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:150;animation:fadeIn .2s ease-out}.dashboard-sidebar{width:260px;background-color:#1a1a2e;color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:100}.dashboard-sidebar-header{padding:2rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.dashboard-sidebar-header h1{font-size:1.75rem;margin:0;color:#fff;font-weight:700}.dashboard-nav{flex:1;padding:1.5rem 0;overflow-y:auto}.dashboard-nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.dashboard-nav li{margin:0;padding:0}.dashboard-sidebar .dashboard-nav .nav-button{display:flex;align-items:center;justify-content:flex-start;gap:1rem;padding:1rem 1.5rem;color:#fffc;text-decoration:none;transition:all .2s;border-left:3px solid transparent;background:none;border-top:none;border-right:none;border-bottom:none;width:100%;cursor:pointer;text-align:left;font-size:1rem;font-weight:500;font-family:inherit}.dashboard-sidebar .dashboard-nav .nav-button:hover{background-color:#ffffff0d;color:#fff}.dashboard-sidebar .dashboard-nav .nav-button.active{background-color:#646cff1a;color:#646cff;border-left-color:#646cff;font-weight:600}.dashboard-sidebar .nav-icon{font-size:1.25rem;width:1.5rem;text-align:center;flex-shrink:0}.dashboard-sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1);position:relative;background-color:#1a1a2e}.dashboard-sidebar .dashboard-sidebar-footer .dashboard-user-info{display:flex;align-items:center;gap:.75rem;padding:.875rem;border-radius:8px;background-color:#ffffff14;border:1px solid rgba(255,255,255,.1);width:100%;cursor:pointer;transition:all .2s;text-align:left;font-family:inherit}.dashboard-sidebar .dashboard-sidebar-footer .dashboard-user-info:hover{background-color:#ffffff26;border-color:#fff3}.dashboard-sidebar .dashboard-sidebar-footer .user-avatar{width:2.5rem;height:2.5rem;border-radius:50%;object-fit:cover;flex-shrink:0}.dashboard-sidebar .dashboard-sidebar-footer .user-avatar-placeholder{width:2.5rem;height:2.5rem;border-radius:50%;background:#ffffff26;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;color:#ffffffe6;flex-shrink:0}.dashboard-sidebar .dashboard-sidebar-footer .user-details{display:flex;flex-direction:column;gap:.125rem;flex:1;min-width:0;background:transparent!important;border-radius:0!important;padding:0!important;margin:0!important;border:none!important}.dashboard-sidebar .dashboard-sidebar-footer .user-name{font-size:.9375rem;color:#fff;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2;background:transparent!important;padding:0!important;margin:0!important;border:none!important;text-align:left!important}.dashboard-sidebar .dashboard-sidebar-footer .user-email{font-size:.75rem;color:#fff9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2;background:transparent!important;padding:0!important;margin:0!important;border:none!important;text-align:left!important}.dashboard-sidebar .dashboard-sidebar-footer .dropdown-arrow{font-size:.625rem;color:#ffffff80;flex-shrink:0}.profile-menu{position:absolute;bottom:100%;left:1rem;right:1rem;background:#2a2a3e;border-radius:8px;box-shadow:0 4px 12px #0000004d;margin-bottom:.5rem;overflow:hidden;animation:slideUp .2s ease-out;z-index:1000}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.profile-menu-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;color:#ffffffe6;text-decoration:none;border:none;background:transparent;width:100%;cursor:pointer;transition:background-color .2s;font-size:.875rem;text-align:left;font-family:inherit}.profile-menu-item .menu-icon{font-size:1rem;width:1.25rem;text-align:center;flex-shrink:0}.profile-menu-item:hover{background-color:#ffffff1a}.profile-menu-item.logout{color:#ff6b6b;border-top:1px solid rgba(255,255,255,.1)}.profile-menu-item.logout:hover{background-color:#ff6b6b1a}.dashboard-main{flex:1;margin-left:260px;background-color:#f8f9fa;min-height:100vh;padding:2rem}@media (max-width: 768px){.dashboard-mobile-header{display:flex}.dashboard-sidebar-header{display:none}.dashboard-sidebar{position:fixed;left:-100%;top:60px;width:280px;height:calc(100vh - 60px);transition:left .3s ease-out;z-index:160;box-shadow:2px 0 8px #0003}.dashboard-sidebar.mobile-open{left:0}.dashboard-sidebar.mobile-open~.mobile-menu-overlay{display:block}.dashboard-main{margin-left:0;margin-top:60px;padding:1.5rem 1rem;width:100%}.dashboard-nav{padding:1rem 0}.dashboard-sidebar .dashboard-nav .nav-button{padding:1rem 1.5rem;font-size:1rem}.dashboard-sidebar-footer{padding:1rem}.profile-menu{bottom:calc(100% + .5rem)}}@media (max-width: 480px){.dashboard-sidebar{width:260px}.dashboard-main{padding:1rem .75rem}.mobile-header-title{font-size:1.125rem}.dashboard-sidebar .dashboard-nav .nav-button{padding:.875rem 1.25rem;font-size:.9375rem}.dashboard-sidebar .dashboard-sidebar-footer .user-name{font-size:.875rem}.dashboard-sidebar .dashboard-sidebar-footer .user-email{font-size:.6875rem}}@media (max-width: 768px) and (orientation: landscape){.dashboard-mobile-header{height:50px}.dashboard-sidebar{top:50px;height:calc(100vh - 50px)}.dashboard-main{margin-top:50px}}.book-uploader{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a;max-width:600px;margin:0 auto}.book-uploader h2{margin-top:0;margin-bottom:1.5rem;color:#333;font-size:1.5rem}.upload-form{display:flex;flex-direction:column;gap:1.5rem}.author-search-wrapper{position:relative}.author-search-wrapper input{width:100%;padding:.75rem 2.5rem .75rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.author-search-wrapper input:focus{outline:none;border-color:#646cff}.clear-author{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:#e2e8f0;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.875rem;color:#4a5568;transition:background-color .2s}.clear-author:hover{background:#cbd5e0}.author-suggestions-dropdown{position:absolute;top:calc(100% + .25rem);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:4px;box-shadow:0 4px 12px #00000026;max-height:240px;overflow-y:auto;z-index:1000}.author-suggestion-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;cursor:pointer;transition:background-color .15s;border-bottom:1px solid #f7fafc}.author-suggestion-item:last-child{border-bottom:none}.author-suggestion-item:hover,.author-suggestion-item.selected{background:#f7fafc}.author-icon{font-size:1rem;flex-shrink:0}.author-email{flex:1;font-size:.9375rem;color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-group input[type=text],.form-group select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input[type=text]:focus,.form-group select:focus{outline:none;border-color:#3498db}.form-group input[type=text]:disabled,.form-group select:disabled{background-color:#f5f5f5;cursor:not-allowed}@media (max-width: 768px){.book-uploader{padding:1.5rem}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.header-image-preview{margin-top:1rem}.header-image-preview .preview-container{position:relative;max-width:100%;border-radius:8px;overflow:hidden;border:2px solid #e2e8f0}.header-image-preview img{width:100%;height:auto;max-height:300px;object-fit:cover;display:block}.remove-image-btn{position:absolute;top:.75rem;right:.75rem;background:#000000b3;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:600;transition:background-color .2s}.remove-image-btn:hover:not(:disabled){background:#000000d9}.remove-image-btn:disabled{cursor:not-allowed;opacity:.5}.book-editor{background:#fff;border-radius:8px;padding:2rem;box-shadow:none;max-width:100%;margin:0}.book-editor h2{margin-top:0;margin-bottom:1.5rem;color:#333;font-size:1.5rem}.book-info-section{background-color:#f8f9fa;border-radius:6px;padding:1rem;margin-bottom:2rem}.info-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #e9ecef}.info-row:last-child{border-bottom:none}.info-label{font-weight:600;color:#555;font-size:.9rem}.info-value{color:#666;font-size:.9rem}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.archived{background-color:#f8d7da;color:#721c24}.edit-form{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.required{color:#e74c3c}.form-group input[type=text],.form-group input[type=date]{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input[type=text]:focus,.form-group input[type=date]:focus{outline:none;border-color:#3498db}.form-group input[type=text]:disabled,.form-group input[type=date]:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-group input[type=file]{padding:.5rem;border:2px dashed #ddd;border-radius:4px;cursor:pointer;transition:border-color .2s}.form-group input[type=file]:hover:not(:disabled){border-color:#3498db}.form-group input[type=file]:disabled{cursor:not-allowed;opacity:.6}.selected-files{margin-top:.5rem;padding:.75rem;background-color:#f8f9fa;border-radius:4px}.files-label{font-size:.9rem;font-weight:600;color:#555;margin:0 0 .5rem}.selected-files ul{list-style:none;padding:0;margin:0}.selected-files li{padding:.25rem 0;font-size:.9rem;color:#666}.validation-errors{padding:1rem;background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px}.error-title{font-weight:600;color:#856404;margin:0 0 .5rem}.validation-errors ul{list-style:none;padding:0;margin:0}.validation-errors li{padding:.25rem 0;color:#856404;font-size:.9rem}.error-message{padding:1rem;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;font-size:.95rem}.form-actions{display:flex;gap:1rem;margin-top:.5rem}.btn-primary,.btn-secondary,.btn-danger,.btn-warning{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-danger{background-color:#e74c3c;color:#fff}.btn-danger:hover:not(:disabled){background-color:#c0392b}.btn-danger:disabled{background-color:#95a5a6;cursor:not-allowed}.danger-zone{border-top:2px solid #e9ecef;padding-top:2rem;margin-top:2rem}.danger-zone h3{color:#e74c3c;font-size:1.2rem;margin-top:0;margin-bottom:1.5rem}.danger-action{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border:1px solid #e9ecef;border-radius:6px;margin-bottom:1rem;background-color:#fff}.danger-action:last-child{margin-bottom:0}.danger-info{flex:1;margin-right:1rem}.danger-info h4{margin:0 0 .5rem;color:#333;font-size:1rem}.danger-info p{margin:0;color:#666;font-size:.9rem}.confirm-actions{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.confirm-text{font-weight:600;color:#e74c3c;margin:0 0 .5rem;font-size:.9rem}.confirm-actions button{padding:.5rem 1rem;font-size:.9rem;min-width:120px}@media (max-width: 768px){.book-editor{padding:1.5rem}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}.danger-action{flex-direction:column;align-items:stretch}.danger-info{margin-right:0;margin-bottom:1rem}.confirm-actions{align-items:stretch}.confirm-actions button{width:100%}}.tags-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;min-height:2rem}.tag{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:#e3f2fd;border:1px solid #90caf9;border-radius:16px;font-size:.875rem;color:#1976d2}.tag-remove{background:none;border:none;color:#1976d2;cursor:pointer;font-size:1.125rem;line-height:1;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;transition:color .2s}.tag-remove:hover:not(:disabled){color:#0d47a1}.tag-remove:disabled{cursor:not-allowed;opacity:.5}.tag-input-wrapper input{width:100%}.tag-suggestions-dropdown{position:absolute;bottom:calc(100% + .25rem);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:4px;box-shadow:0 -4px 12px #00000026;max-height:200px;overflow-y:auto;z-index:1000}.tag-suggestion-item{padding:.625rem .75rem;cursor:pointer;transition:background-color .15s;font-size:.9375rem;color:#2d3748}.tag-suggestion-item:hover,.tag-suggestion-item.selected{background:#f7fafc}.tag-input-group .btn-secondary{padding:.75rem 1rem;white-space:nowrap}.display-config-section{margin-top:1rem;padding-top:1.5rem;border-top:2px solid #e9ecef}.display-config-section h3{margin:0 0 .5rem;color:#333;font-size:1.1rem;font-weight:600}.section-description{margin:0 0 1rem;color:#666;font-size:.9rem}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.feedback-window-control{background:#fff;border-radius:8px;padding:1.5rem;border:1px solid #e9ecef;margin-top:1.5rem}.feedback-window-control h3{margin-top:0;margin-bottom:1.5rem;color:#333;font-size:1.2rem;border-bottom:2px solid #e9ecef;padding-bottom:.75rem}.feedback-status{background-color:#f8f9fa;border-radius:6px;padding:1rem;margin-bottom:1.5rem}.status-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.status-label{font-weight:600;color:#555;font-size:.95rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.status-badge.status-open{background-color:#d4edda;color:#155724}.status-badge.status-closed{background-color:#fff3cd;color:#856404}.status-badge.status-archived{background-color:#f8d7da;color:#721c24}.status-description{margin:0;color:#666;font-size:.9rem;line-height:1.5}.feedback-form{margin-bottom:2rem}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.form-group input[type=date]{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s;max-width:300px}.form-group input[type=date]:focus{outline:none;border-color:#3498db}.form-group input[type=date]:disabled{background-color:#f5f5f5;cursor:not-allowed}.help-text{font-size:.85rem;color:#666;margin:0;line-height:1.4}.btn-primary,.btn-secondary,.btn-warning{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-warning{background-color:#f39c12;color:#fff}.btn-warning:hover:not(:disabled){background-color:#e67e22}.btn-warning:disabled{background-color:#95a5a6;cursor:not-allowed}.archive-section{border-top:1px solid #e9ecef;padding-top:1.5rem;margin-top:1.5rem}.archive-info{margin-bottom:1rem}.archive-info h4{margin:0 0 .5rem;color:#333;font-size:1rem}.archive-info p{margin:0;color:#666;font-size:.9rem;line-height:1.5}.confirm-actions{margin-top:1rem}.confirm-text{font-weight:600;color:#856404;margin:0 0 1rem;font-size:.95rem;padding:.75rem;background-color:#fff3cd;border-radius:4px;border:1px solid #ffc107}.confirm-buttons{display:flex;gap:.75rem}.error-message{padding:1rem;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;font-size:.95rem;margin-top:1rem}@media (max-width: 768px){.feedback-window-control{padding:1rem}.form-group input[type=date]{max-width:100%}.confirm-buttons{flex-direction:column}.btn-primary,.btn-secondary,.btn-warning{width:100%}}.reader-group-manager{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px;width:100%;min-width:100%;margin:0 auto}.manager-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.manager-header h2{margin:0 0 8px;font-size:24px;color:#1f2937}.manager-header .book-title{margin:0;font-size:14px;color:#6b7280}.btn-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.btn-close:hover{background:#f3f4f6;color:#1f2937}.manager-content{display:grid;grid-template-columns:1fr 1fr;gap:24px;height:600px}.groups-panel,.members-panel{border:1px solid #e5e7eb;border-radius:8px;padding:16px;background:#f9fafb;display:flex;flex-direction:column;overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-shrink:0}.panel-header h3{margin:0;font-size:18px;color:#1f2937}.member-search{position:relative;margin-bottom:12px;flex-shrink:0}.member-search .search-input{width:100%;padding:8px 32px 8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.member-search .search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.member-search .clear-search{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#e5e7eb;border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;color:#4b5563;transition:background-color .2s}.member-search .clear-search:hover{background:#d1d5db}.search-results-info{font-size:13px;color:#6b7280;margin-bottom:8px;padding:6px 8px;background:#f3f4f6;border-radius:4px;flex-shrink:0}.panel-header-actions{display:flex;gap:8px}.btn-small{padding:6px 12px;font-size:14px;max-width:150px;white-space:nowrap}.create-group-form,.add-reader-form{background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:12px;margin-bottom:16px}.add-reader-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.add-reader-modal{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0003;width:90%;max-width:500px;max-height:80vh;overflow-y:auto}.add-reader-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.add-reader-modal .modal-header h3{margin:0;font-size:20px;color:#1f2937}.add-reader-modal .modal-body{padding:24px}.add-reader-modal .modal-body label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.add-reader-modal .modal-body input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;margin-bottom:16px}.add-reader-modal .modal-body input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-results{margin-top:16px}.results-section{margin-bottom:16px}.results-label{font-size:14px;font-weight:500;color:#374151;margin-bottom:12px}.results-label.error{color:#dc2626}.reader-result{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;margin-bottom:8px}.reader-result:last-child{margin-bottom:0}.reader-email{font-size:14px;color:#1f2937;font-weight:500}.invite-option{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:16px;text-align:center}.invite-option p{margin:0 0 12px;font-size:14px;color:#1f2937}.invite-option strong{color:#1e40af}.add-reader-form label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.create-group-form input,.add-reader-form select,.add-reader-form input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;margin-bottom:8px}.create-group-form input:focus,.add-reader-form select:focus,.add-reader-form input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.add-reader-form .help-text{font-size:12px;color:#6b7280;margin:0 0 8px;font-style:italic}.form-actions{display:flex;gap:8px}.groups-list,.members-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1}.group-item{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:12px;cursor:pointer;transition:all .2s}.group-item:hover{border-color:#3b82f6;box-shadow:0 2px 4px #0000000d}.group-item.selected{border-color:#3b82f6;background:#eff6ff;box-shadow:0 2px 4px #3b82f61a}.group-name{font-weight:600;color:#1f2937;margin-bottom:4px}.group-date{font-size:12px;color:#6b7280}.member-item{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:12px;display:flex;justify-content:space-between;align-items:center}.member-info{flex:1}.member-name{font-weight:600;color:#1f2937;margin-bottom:2px;font-size:15px}.member-email{font-weight:500;color:#6b7280;font-size:14px}.member-date{font-size:12px;color:#6b7280}.btn-danger{background:#ef4444;color:#fff;border:none;padding:8px 16px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-danger:disabled{background:#fca5a5;cursor:not-allowed}.empty-state{text-align:center;padding:40px 20px;color:#6b7280}.empty-state p{margin:8px 0}.empty-state .help-text{font-size:14px;color:#9ca3af}.error-message{background:#fee2e2;border:1px solid #fecaca;border-radius:6px;padding:12px 16px;margin-bottom:16px;color:#991b1b;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#991b1b;font-size:18px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.error-message button:hover{background:#fecaca}.loading{text-align:center;padding:40px;color:#6b7280;font-size:16px}@media (max-width: 768px){.manager-content{grid-template-columns:1fr}.manager-header{flex-direction:column;align-items:flex-start}.btn-close{align-self:flex-end;margin-top:-32px}}.invitations-section{margin-top:24px;padding-top:16px;border-top:2px solid #e5e7eb}.invitations-section h4{margin:0 0 12px;font-size:16px;color:#1f2937;font-weight:600}.invitations-list{display:flex;flex-direction:column;gap:8px}.invitation-item{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:12px;display:flex;justify-content:space-between;align-items:center}.invitation-item.expired{background:#fef2f2;border-color:#fecaca}.invitation-email{font-weight:500;color:#1f2937;font-size:14px;margin-bottom:4px}.invitation-status{display:flex;align-items:center;gap:8px;font-size:12px}.status-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.pending{background:#dbeafe;color:#1e40af}.status-badge.expired{background:#fee2e2;color:#991b1b}.invitation-date{color:#6b7280}.access-type-selector,.access-type-control{margin-bottom:16px;padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px}.access-type-selector label,.access-type-control label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.access-type-select{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;background:#fff;cursor:pointer;margin-bottom:8px}.access-type-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.access-type-selector .help-text,.access-type-control .help-text{font-size:12px;color:#6b7280;margin:0;font-style:italic;line-height:1.4}.access-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.access-badge.access-closed{background:#fee2e2;color:#991b1b}.access-badge.access-approval_required{background:#fef3c7;color:#92400e}.access-badge.access-open{background:#d1fae5;color:#065f46}.group-item{display:flex;justify-content:space-between;align-items:center;gap:12px}.group-info{flex:1;min-width:0}.group-info .group-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-viewer{background:#fff;border-radius:8px;padding:2rem;max-width:1200px;margin:0 auto}.comment-viewer-header{display:flex!important;flex-direction:column!important;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e9ecef;gap:1rem}.header-content{width:100%!important;flex:none!important}.comment-viewer-header h2{margin:0 0 .5rem;color:#333;font-size:1.5rem;word-wrap:break-word;overflow-wrap:break-word}.comment-count{margin:0;color:#666;font-size:.95rem}.header-actions{display:flex!important;gap:.75rem;width:100%!important;flex-wrap:wrap;flex-direction:row!important}.header-actions button{white-space:nowrap;flex:1 1 auto;min-width:150px}.error-message{padding:1rem;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;font-size:.95rem;margin-bottom:1.5rem}.empty-state{text-align:center;padding:4rem 2rem;color:#6c757d}.empty-state p{margin:0 0 .5rem;font-size:1.1rem}.empty-state-hint{font-size:.95rem;color:#999}.comments-list{display:flex;flex-direction:column;gap:1.5rem}.comment-card{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:1.5rem;transition:box-shadow .2s}.comment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.reader-info{display:flex;flex-direction:column;gap:.25rem}.reader-name{font-weight:600;color:#333;font-size:1rem}.reader-email{font-size:.875rem;color:#666}.comment-date{font-size:.875rem;color:#999;white-space:nowrap}.comment-context{background:#fff;border-left:3px solid #3498db;padding:.75rem 1rem;margin-bottom:1rem;border-radius:4px}.context-label{font-size:.75rem;text-transform:uppercase;font-weight:600;color:#666;letter-spacing:.5px;display:block;margin-bottom:.25rem}.context-snippet{font-style:italic;color:#555;font-size:.95rem;line-height:1.5}.comment-text{color:#333;font-size:1rem;line-height:1.6;margin-bottom:1rem;white-space:pre-wrap;word-wrap:break-word}.comment-location{display:flex;align-items:center;gap:.5rem;padding-top:.75rem;border-top:1px solid #dee2e6}.location-icon{font-size:.875rem}.location-text{font-size:.875rem;color:#666}@media (max-width: 768px){.comment-viewer{padding:1.5rem}.header-actions{flex-direction:column}.header-actions button{width:100%;min-width:auto}.comment-card{padding:1rem}.comment-header{flex-direction:column}.comment-date{align-self:flex-start}}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.dashboard-container{max-width:1400px;margin:0 auto;padding:2rem;position:relative}.dashboard-container:has(.modal-overlay){height:auto;overflow:visible}.modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:#00000080;z-index:9999;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;pointer-events:auto}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:800px;width:100%;max-height:calc(100vh - 4rem);overflow-y:auto!important;overflow-x:hidden;padding:0;animation:modalSlideIn .2s ease-out;position:relative;-webkit-overflow-scrolling:touch;pointer-events:auto}.modal-content.reader-group-modal,.modal-content.comment-viewer-modal{max-width:1200px!important}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{margin-bottom:2rem}.dashboard-header-content{display:flex;justify-content:space-between;align-items:flex-start}.dashboard-header-left{flex:1}.dashboard-header h1{font-size:2rem;margin-bottom:.5rem;color:#213547}.dashboard-subtitle{color:#6c757d;font-size:1rem}.btn-add-book{white-space:nowrap;margin-left:2rem;max-width:200px;flex-shrink:0}.search-filter{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.books-section{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.section-header-left,.filter-controls{display:flex;align-items:center;gap:1rem}.role-filter-buttons{display:flex;gap:.5rem}.btn-filter{padding:.5rem 1rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;font-size:.875rem;color:#495057;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-filter:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}.btn-filter.active{background:#6366f1;border-color:#6366f1;color:#fff}.btn-filter.active:hover{background:#4f46e5;border-color:#4f46e5}.section-header h2{font-size:1.5rem;color:#213547;margin:0}.btn-toggle-archived{padding:.5rem 1rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;font-size:.875rem;color:#495057;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-toggle-archived:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}.btn-toggle-archived:active{transform:translateY(0)}.empty-state{text-align:center;padding:3rem 1rem;color:#6c757d}.empty-state p{margin-bottom:1.5rem;font-size:1.1rem}.book-card{background:#f8f9fa;border:1px solid #dee2e6;border-radius:12px;padding:1.5rem;transition:transform .2s,box-shadow .2s}.book-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.book-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem;min-height:140px;max-height:140px;padding:1rem;border-radius:12px;background:#f8f9fa}.book-title{font-size:1.25rem;color:#213547;margin:0;flex:1;word-break:break-word;text-align:left;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.book-status{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;white-space:nowrap}.status-active{background-color:#d4edda;color:#155724}.status-closed{background-color:#fff3cd;color:#856404}.status-archived{background-color:#f8d7da;color:#721c24}.book-card-body{margin-bottom:1.5rem}.book-info{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #dee2e6}.book-info:last-child{border-bottom:none}.info-label{color:#6c757d;font-size:.875rem;font-weight:500}.info-value{color:#213547;font-size:.875rem}.book-card-actions{display:flex;gap:.5rem;flex-direction:column}.book-card-actions button{width:100%;font-size:.875rem;padding:.5rem 1rem}@media (max-width: 768px){.books-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:stretch;gap:1rem}.section-header-left{flex-direction:column;align-items:stretch;gap:.75rem}.section-header button,.btn-toggle-archived{width:100%}.book-card-actions{flex-direction:column}.book-card-actions button{width:100%}.modal-overlay{padding:1rem}.modal-content{width:calc(100% - 2rem)}}@media (prefers-color-scheme: dark){.dashboard-header h1,.section-header h2,.book-title,.info-value{color:#ffffffde}.books-section{background:#2a2a2a;box-shadow:0 2px 8px #0000004d}.book-card{background:#1e1e1e;border-color:#3a3a3a}.section-header,.book-info{border-bottom-color:#3a3a3a}.btn-toggle-archived{background:#1e1e1e;border-color:#3a3a3a;color:#ffffffde}.btn-toggle-archived:hover{background:#2a2a2a;border-color:#4a4a4a}}.user-manager-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.user-manager-modal{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h2{font-size:1.5rem;font-weight:600;color:#1a202c;margin:0}.close-button{background:none;border:none;font-size:2rem;color:#a0aec0;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-button:hover{background:#edf2f7;color:#4a5568}.user-form{padding:1.5rem}.form-group label{display:block;font-size:.875rem;font-weight:600;color:#4a5568;margin-bottom:.5rem}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #cbd5e0;border-radius:8px;font-size:.9375rem;color:#2d3748;transition:all .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled,.form-group select:disabled{background:#f7fafc;cursor:not-allowed}.form-hint{display:block;font-size:.8125rem;color:#718096;margin-top:.375rem}.error-message{background:#fed7d7;color:#c53030;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;margin-bottom:1.5rem;border-left:4px solid #fc8181}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.form-actions button{padding:.75rem 1.5rem;border-radius:8px;border:none;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s}.form-actions .btn-primary{background:#667eea;color:#fff}.form-actions .btn-primary:hover:not(:disabled){background:#5a67d8;transform:translateY(-1px);box-shadow:0 4px 6px #667eea4d}.form-actions .btn-primary:disabled{background:#cbd5e0;cursor:not-allowed}.form-actions .btn-secondary{background:#edf2f7;color:#4a5568}.form-actions .btn-secondary:hover:not(:disabled){background:#e2e8f0}.form-actions .btn-secondary:disabled{opacity:.5;cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.form-row .form-group{margin-bottom:0}.tags-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;min-height:2rem}.tag{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#667eea;color:#fff;border-radius:20px;font-size:.875rem}.tag-remove{background:transparent;border:none;color:#fff;font-size:1.25rem;line-height:1;cursor:pointer;padding:0;width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.tag-remove:hover:not(:disabled){background:#fff3}.tag-remove:disabled{opacity:.5;cursor:not-allowed}.tag-input-group{display:flex;gap:.5rem;align-items:flex-start}.tag-input-wrapper{position:relative;flex:1}.tag-input{width:100%;padding:.75rem;border:1px solid #cbd5e0;border-radius:8px;font-size:.9375rem;color:#2d3748;transition:all .2s;box-sizing:border-box}.tag-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.tag-input:disabled{background:#f7fafc;cursor:not-allowed}.tag-suggestions-dropdown{position:absolute;bottom:calc(100% + .5rem);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:240px;overflow-y:auto;z-index:1000}.tag-suggestion-item{padding:.75rem 1rem;cursor:pointer;transition:background-color .15s;border-bottom:1px solid #f7fafc;font-size:.9375rem;color:#2d3748}.tag-suggestion-item:last-child{border-bottom:none}.tag-suggestion-item:hover,.tag-suggestion-item.selected{background:#f7fafc;color:#667eea}.btn-small{padding:.75rem 1rem!important;font-size:.875rem!important}@media (max-width: 640px){.user-manager-modal{max-width:100%;margin:0;border-radius:0;max-height:100vh}.modal-header{padding:1rem}.modal-header h2{font-size:1.25rem}.user-form{padding:1rem}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.form-row{grid-template-columns:1fr}.tag-input-group{flex-direction:column}.tag-input-group button{width:100%}}.superadmin-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.superadmin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.superadmin-header h1{font-size:2rem;font-weight:600;color:#1a202c;margin:0}.btn-add-user{white-space:nowrap;margin-left:2rem;max-width:200px;flex-shrink:0}.superadmin-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.superadmin-error p{color:#e53e3e;font-size:1.125rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;text-align:center}.stat-value{font-size:2.5rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.stat-label{font-size:.875rem;color:#718096;text-transform:uppercase;letter-spacing:.05em}.users-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a}.section-header{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem}.filters-row{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.filter-divider{width:1px;height:32px;background:#e2e8f0;flex-shrink:0}.role-filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.role-filter-btn{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.role-filter-btn:hover{background:#f7fafc;border-color:#cbd5e0}.role-filter-btn.active{background:#667eea;color:#fff;border-color:#667eea}.role-filter-btn.active:hover{background:#5a67d8;border-color:#5a67d8}.status-filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.status-filter-btn{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.status-filter-btn:hover{background:#f7fafc;border-color:#cbd5e0}.status-filter-btn.active{background:#667eea;color:#fff;border-color:#667eea}.status-filter-btn.active:hover{background:#5a67d8;border-color:#5a67d8}.header-actions{display:flex;align-items:center;gap:1rem;width:100%}.search-filter{position:relative;flex:1;min-width:250px}.search-input{width:100%;padding:.4rem 2.5rem .4rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff;color:#2d3748;transition:border-color .2s;line-height:1.5}.clear-search{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:#e2e8f0;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.875rem;color:#4a5568;transition:background-color .2s}.role-filter{display:flex;align-items:center;gap:.5rem}.role-filter label{font-size:.875rem;font-weight:600;color:#4a5568;white-space:nowrap;line-height:1.5;margin:0;padding:0}.role-select{padding:.4rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff;color:#2d3748;cursor:pointer;transition:border-color .2s;min-width:200px;line-height:1.5}.role-select:hover{border-color:#cbd5e0}.role-select:hover{border-color:#667eea}.role-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-results-info{margin-bottom:1rem;padding:.75rem 1rem;background:#f7fafc;border-radius:8px;font-size:.875rem;color:#4a5568;font-weight:500}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:#f7fafc;border-bottom:2px solid #e2e8f0}.users-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:#4a5568;text-transform:uppercase;letter-spacing:.05em}.users-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .2s}.users-table tbody tr.clickable-row:hover,.users-table tbody tr:hover{background:#f7fafc}.users-table tbody tr.current-user-row{background:#fef5e7}.users-table tbody tr.current-user-row:hover{background:#fdebd0}.users-table td{padding:1rem;font-size:.9375rem;color:#2d3748}.current-user-badge{display:inline-block;margin-left:.5rem;padding:.25rem .5rem;background:#667eea;color:#fff;border-radius:4px;font-size:.75rem;font-weight:600}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.action-buttons{display:flex;gap:.5rem}.btn-small{padding:.375rem .75rem;font-size:.875rem;border-radius:6px;border:none;cursor:pointer;font-weight:500;transition:all .2s}.btn-small.btn-secondary{background:#edf2f7;color:#4a5568}.btn-small.btn-secondary:hover{background:#e2e8f0}.btn-small.btn-danger{background:#fed7d7;color:#c53030}.btn-small.btn-danger:hover{background:#fc8181;color:#fff}.btn-small:disabled{opacity:.5;cursor:not-allowed}.btn-small:disabled:hover{background:#edf2f7;color:#4a5568;transform:none}.btn-small.btn-danger:disabled:hover{background:#fed7d7;color:#c53030}.empty-state p{font-size:1.125rem;margin:0}.btn-primary{background:#667eea;color:#fff;padding:.4rem 1.5rem;border-radius:8px;border:none;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1.5}.btn-primary:hover{background:#5a67d8;transform:translateY(-1px);box-shadow:0 4px 6px #667eea4d}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#edf2f7;color:#4a5568;padding:.75rem 1.5rem;border-radius:8px;border:none;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s}@media (max-width: 768px){.superadmin-dashboard{padding:1rem}.superadmin-header{flex-direction:column;align-items:flex-start;gap:1rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.role-filter-buttons{width:100%}.role-filter-btn{flex:1;min-width:0;font-size:.75rem;padding:.5rem}.header-actions{width:100%;flex-direction:column;align-items:stretch}.search-filter{width:100%;min-width:unset}.users-table{font-size:.875rem}.users-table th,.users-table td{padding:.75rem .5rem}.action-buttons{flex-direction:column}.btn-small{width:100%}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.stat-value{font-size:2rem}}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-right:.5rem}.status-pending{background:#fff3cd;color:#856404}.status-active{background:#d4edda;color:#155724}.status-suspended{background:#f8d7da;color:#721c24}.verification-badge{display:inline-block;padding:.25rem .5rem;background:#ffc107;color:#856404;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.btn-small.btn-success{background:#d4edda;color:#155724}.btn-small.btn-success:hover{background:#c3e6cb}.btn-small.btn-warning{background:#fff3cd;color:#856404}.btn-small.btn-warning:hover{background:#ffeaa7}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.btn-small.btn-admin{background:#e9d5ff;color:#6b46c1}.btn-small.btn-admin:hover{background:#ddd6fe}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0;border-bottom:1px solid #e2e8f0;margin-bottom:1.5rem}.modal-header h2{font-size:1.25rem;font-weight:600;color:#1a202c;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:#718096;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f7fafc;color:#4a5568}.modal-body{padding:0 1.5rem 1.5rem}.warning-text{background:#fef5e7;border:1px solid #f6e05e;border-radius:8px;padding:1rem;color:#744210;font-size:.875rem;margin-bottom:1.5rem}.user-details{background:#f7fafc;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.user-details p{margin:.5rem 0;font-size:.875rem;color:#4a5568}.user-details p:first-child{margin-top:0}.user-details p:last-child{margin-bottom:0}.password-confirmation{margin-bottom:1.5rem}.password-confirmation label{display:block;font-size:.875rem;font-weight:600;color:#4a5568;margin-bottom:.5rem}.password-input{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;transition:border-color .2s}.password-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e2e8f0;margin-top:1.5rem}.modal-footer button{padding:.75rem 1.5rem;border-radius:8px;border:none;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.action-bar{display:flex;justify-content:space-between;align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;margin-bottom:1rem;min-height:60px}.action-bar .selection-info{font-size:.875rem;font-weight:600;color:#4a5568}.current-user-warning{color:#d69e2e;font-weight:500;font-size:.8rem}.action-bar .action-buttons{display:flex;gap:.75rem;flex-wrap:wrap;min-height:36px;align-items:center}.action-bar .action-buttons button{min-width:140px!important;width:140px;padding:.5rem 1rem!important;border-radius:6px;border:none;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;white-space:nowrap;box-sizing:border-box}.action-bar .action-buttons .btn-warning,.action-bar .action-buttons .btn-success,.action-bar .action-buttons .btn-admin,.action-bar .action-buttons .btn-danger,.action-bar .action-buttons .btn-secondary{min-width:140px!important;width:140px;padding:.5rem 1rem!important}.btn-warning{background:#fff3cd;color:#856404}.btn-warning:hover{background:#ffeaa7}.btn-warning:disabled{opacity:.5;cursor:not-allowed}.btn-success{background:#d4edda;color:#155724}.btn-success:hover{background:#c3e6cb}.btn-success:disabled{opacity:.5;cursor:not-allowed}.btn-admin{background:#e9d5ff;color:#6b46c1}.btn-admin:hover{background:#ddd6fe}.btn-admin:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:#fed7d7;color:#c53030}.btn-danger:hover{background:#fc8181;color:#fff}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-danger:disabled:hover{background:#fed7d7;color:#c53030}.btn-secondary{background:#edf2f7;color:#4a5568}.btn-secondary:hover{background:#e2e8f0}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.users-table tbody tr.selected{background:#ebf8ff}.users-table tbody tr.selected:hover{background:#bee3f8}.users-table tbody tr.selected.current-user-row{background:#fef5e7}.users-table tbody tr.selected.current-user-row:hover{background:#fdebd0}.clickable-cell{cursor:pointer}.users-to-elevate{background:#f7fafc;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.users-to-elevate h3{font-size:1rem;font-weight:600;color:#4a5568;margin:0 0 .75rem}.users-to-elevate ul{list-style:none;padding:0;margin:0}.users-to-elevate li{padding:.5rem 0;border-bottom:1px solid #e2e8f0;font-size:.875rem;color:#4a5568}.users-to-elevate li:last-child{border-bottom:none}.stats-page-container{max-width:1400px;margin:0 auto;padding:2rem}.stats-page-header{margin-bottom:2rem}.stats-page-header h1{font-size:2rem;margin-bottom:.5rem;color:#213547}.stats-subtitle{color:#6c757d;font-size:1rem;margin:0}.stats-search-filter{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.search-input-wrapper{position:relative;display:flex;align-items:center;max-width:600px}.search-icon{position:absolute;left:1rem;font-size:1.25rem;pointer-events:none;opacity:.5;z-index:1}.search-input{flex:1;padding:.875rem 3rem .875rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;background:#fff;transition:border-color .2s,box-shadow .2s;width:100%}.search-input:hover{border-color:#cbd5e0}.search-input:focus{outline:none;border-color:#646cff;box-shadow:0 0 0 3px #646cff1a}.clear-search{position:absolute;right:.75rem;background:#e2e8f0;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.875rem;color:#4a5568;transition:background-color .2s;z-index:1}.clear-search:hover{background:#cbd5e0}.suggestions-dropdown{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:320px;overflow-y:auto;z-index:1000}.suggestion-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background-color .15s;border-bottom:1px solid #f7fafc}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item.selected{background:#f7fafc}.suggestion-icon{font-size:1.125rem;flex-shrink:0}.suggestion-text{flex:1;font-size:.9375rem;color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.suggestion-type{font-size:.75rem;color:#718096;text-transform:uppercase;letter-spacing:.05em;font-weight:600;flex-shrink:0}.search-results-info{margin-top:.75rem;font-size:.875rem;color:#6c757d;font-weight:500}.stats-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.stats-error p{color:#dc3545;font-size:1.125rem}.stats-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:2rem;margin-bottom:2rem}.stats-section h2{font-size:1.5rem;color:#213547;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.stats-section h3{font-size:1.25rem;color:#213547;margin-bottom:1rem;margin-top:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-card{background:#f8f9fa;padding:1.5rem;border-radius:12px;text-align:center;transition:transform .2s,box-shadow .2s;border:2px solid transparent}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-card-success{background:#d4edda;border-color:#c3e6cb}.stat-card-warning{background:#fff3cd;border-color:#ffeaa7}.stat-value{font-size:2.5rem;font-weight:700;color:#646cff;margin-bottom:.5rem}.stat-card-success .stat-value{color:#155724}.stat-card-warning .stat-value{color:#856404}.stat-label{color:#6c757d;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.author-breakdown{margin-top:2rem}.author-list{display:flex;flex-direction:column;gap:.75rem}.author-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border-radius:8px;transition:background-color .2s}.author-item:hover{background:#e9ecef}.author-email{font-size:.9375rem;color:#495057;font-weight:500}.author-count{font-size:.875rem;color:#6c757d;font-weight:600;padding:.25rem .75rem;background:#fff;border-radius:20px}.stats-actions{display:flex;justify-content:center;margin-top:2rem}.stats-info-box{background:#f0f7ff;border:1px solid #b3d9ff;border-radius:8px;padding:1.5rem;margin-top:1.5rem;text-align:center}.stats-info-box p{margin:0;color:#2c5282;font-size:.9375rem;line-height:1.5}@media (max-width: 768px){.stats-page-container{padding:1rem}.stats-section{padding:1.5rem}.stats-grid{grid-template-columns:1fr}.stat-value{font-size:2rem}.author-item{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (prefers-color-scheme: dark){.stats-page-header h1,.stats-section h2,.stats-section h3{color:#ffffffde}.stats-search-filter{background:#2a2a2a}.search-input{background:#1e1e1e;border-color:#3a3a3a;color:#ffffffde}.search-input:hover{border-color:#4a4a4a}.search-input:focus{border-color:#646cff}.search-input::placeholder{color:#fff6}.clear-search{background:#3a3a3a;color:#ffffffde}.clear-search:hover{background:#4a4a4a}.suggestions-dropdown{background:#2a2a2a;border-color:#3a3a3a}.suggestion-item{border-bottom-color:#3a3a3a}.suggestion-item:hover,.suggestion-item.selected{background:#3a3a3a}.suggestion-text{color:#ffffffde}.suggestion-type{color:#fff9}.stats-section{background:#2a2a2a}.stats-section h2{border-bottom-color:#3a3a3a}.stat-card{background:#1e1e1e}.stat-card:hover{background:#2a2a2a}.stat-card-success{background:#1e3a1e;border-color:#2d5a2d}.stat-card-warning{background:#3a3a1e;border-color:#5a5a2d}.author-item{background:#1e1e1e}.author-item:hover{background:#2a2a2a}.author-email{color:#ffffffde}.author-count{background:#2a2a2a;color:#fff9}.stats-info-box{background:#1e3a4a;border-color:#2d5a6d}.stats-info-box p{color:#a0d4f0}}.find-readers-container{padding:2rem;max-width:1400px;margin:0 auto}.find-readers-header{margin-bottom:2rem}.find-readers-header h1{font-size:2rem;font-weight:600;color:#1a202c;margin:0 0 .5rem}.search-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.search-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.search-field{display:flex;flex-direction:column;gap:.5rem}.search-field label{font-size:.875rem;font-weight:600;color:#4a5568}.search-input-wrapper,.genre-input-wrapper{position:relative}.search-input{width:100%;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9375rem;transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-input::placeholder{color:#a0aec0}.clear-button{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.25rem;color:#a0aec0;cursor:pointer;padding:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.clear-button:hover{background:#f7fafc;color:#4a5568}.clear-button:active{background:#edf2f7}.book-selection{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e2e8f0}.book-selection label{font-size:.875rem;font-weight:600;color:#4a5568}.book-select{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9375rem;background:#fff;cursor:pointer;transition:border-color .2s}.book-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.results-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.results-header h2{font-size:1.5rem;font-weight:600;color:#1a202c;margin:0}.results-count{font-size:.875rem;color:#718096;font-weight:500}.privacy-notice{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:1.5rem}.privacy-icon{font-size:1.25rem;flex-shrink:0}.privacy-text{font-size:.875rem;color:#4a5568;line-height:1.5}.empty-state{text-align:center;padding:3rem;color:#718096}.empty-state p{font-size:1.125rem;margin:.5rem 0}.empty-state .help-text{font-size:.9375rem;color:#a0aec0}.readers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.reader-card{background:#f9fafb;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;transition:all .2s}.reader-card:hover{border-color:#cbd5e0;box-shadow:0 2px 8px #00000014}.reader-info{flex:1}.reader-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.reader-name{font-size:1.125rem;font-weight:600;color:#1a202c;margin:0}.role-badge{display:inline-block;padding:.25rem .625rem;border-radius:12px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.role-reader{background:#bee3f8;color:#2c5282}.role-author{background:#c6f6d5;color:#2f855a}.role-admin{background:#fed7d7;color:#c53030}.reader-email{font-size:.875rem;color:#718096;margin:0 0 1rem}.reader-genres{display:flex;flex-wrap:wrap;gap:.5rem}.genre-tag{display:inline-block;padding:.25rem .75rem;background:#667eea;color:#fff;border-radius:20px;font-size:.75rem;font-weight:600}.genre-mismatch-notice{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;margin-top:.75rem}.mismatch-icon{font-size:1rem;flex-shrink:0}.mismatch-text{font-size:.8125rem;color:#856404;font-weight:500}.invite-button{width:100%;padding:.75rem 1.5rem;font-size:.9375rem;margin-top:.75rem}.invite-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 1024px){.search-row{grid-template-columns:1fr}}@media (max-width: 768px){.find-readers-container{padding:1rem}.search-section,.results-section{padding:1.5rem}.readers-grid{grid-template-columns:1fr}}.genre-suggestions-dropdown{position:absolute;top:calc(100% + .25rem);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:240px;overflow-y:auto;z-index:1000}.genre-suggestion-item{padding:.75rem 1rem;cursor:pointer;transition:background-color .15s;border-bottom:1px solid #f7fafc;font-size:.9375rem;color:#2d3748}.genre-suggestion-item:last-child{border-bottom:none}.genre-suggestion-item:hover,.genre-suggestion-item.selected{background:#f7fafc;color:#667eea}@media (prefers-color-scheme: dark){.genre-suggestions-dropdown{background:#2a2a2a;border-color:#3a3a3a}.genre-suggestion-item{border-bottom-color:#3a3a3a;color:#ffffffde}.genre-suggestion-item:hover,.genre-suggestion-item.selected{background:#3a3a3a;color:#667eea}.clear-button{color:#fff9}.clear-button:hover{background:#3a3a3a;color:#ffffffde}.clear-button:active{background:#4a4a4a}.book-selection{border-bottom-color:#3a3a3a}}.no-books-message{margin-top:.5rem;padding:.75rem;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;color:#856404;font-size:.875rem;line-height:1.4}@media (prefers-color-scheme: dark){.no-books-message{background:#3a2f1a;border-color:#ffc107;color:#ffc107}}.access-requests{padding:2rem;max-width:1200px;margin:0 auto}.access-requests-header{margin-bottom:2rem}.access-requests-header h1{font-size:2rem;color:#1a202c;margin:0 0 .5rem}.subtitle{font-size:1rem;color:#718096;margin:0}.requests-list{display:flex;flex-direction:column;gap:1rem}.request-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;transition:all .2s}.request-card:hover{box-shadow:0 4px 12px #0000001a}.request-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.request-info{flex:1}.reader-name{font-size:1.25rem;font-weight:600;color:#1a202c;margin:0 0 .25rem}.reader-email{font-size:.875rem;color:#718096;margin:0}.request-date{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.date-label{font-size:.75rem;color:#718096;text-transform:uppercase;letter-spacing:.5px}.date-value{font-size:.875rem;color:#2d3748;font-weight:600}.request-body{padding:1rem;background:#f8fafc;border-radius:8px;margin-bottom:1rem}.book-info{display:flex;gap:.5rem;align-items:baseline}.book-label{font-size:.875rem;color:#718096;font-weight:500}.book-title{font-size:1rem;color:#1a202c;font-weight:600}.request-footer{display:flex;gap:1rem;justify-content:flex-end}.btn-approve,.btn-deny{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;min-width:120px}.btn-approve{background-color:#10b981;color:#fff}.btn-approve:hover:not(:disabled){background-color:#059669;transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.btn-deny{background-color:#ef4444;color:#fff}.btn-deny:hover:not(:disabled){background-color:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.btn-approve:disabled,.btn-deny:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.access-requests{padding:1rem}.access-requests-header h1{font-size:1.5rem}.request-header{flex-direction:column}.request-date{align-items:flex-start}.request-footer{flex-direction:column}.btn-approve,.btn-deny{width:100%}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:3rem;width:100%;max-width:420px}.login-title{font-size:2rem;font-weight:700;color:#1a202c;margin:0 0 .5rem;text-align:center}.login-subtitle{font-size:1rem;color:#718096;margin:0 0 2rem;text-align:center}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{font-size:.875rem;font-weight:600;color:#2d3748}.form-group input{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:6px;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f7fafc;cursor:not-allowed}.error-message{padding:.75rem 1rem;background-color:#fed7d7;color:#c53030;border-radius:6px;font-size:.875rem;border:1px solid #fc8181}.login-button{margin-top:.5rem;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;border-radius:6px;transition:all .2s}.login-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 480px){.login-card{padding:2rem 1.5rem}.login-title{font-size:1.5rem}.login-subtitle{font-size:.875rem}}.login-footer{margin-top:2rem;padding-top:2rem;border-top:1px solid #e2e8f0;text-align:center}.login-footer p{color:#6c757d;margin:0;font-size:.875rem}.toggle-mode-button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;padding:0;font-size:.875rem;text-decoration:none}.toggle-mode-button:hover{text-decoration:underline}.role-selection{display:flex;gap:1rem;margin-top:.5rem}.role-option{flex:1;display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;transition:all .2s}.role-option:hover{border-color:#cbd5e0;background-color:#f7fafc}.role-option input[type=radio]{margin:0;cursor:pointer}.role-option input[type=radio]:checked+span{font-weight:600;color:#667eea}.role-option:has(input[type=radio]:checked){border-color:#667eea;background-color:#667eea0d}.role-option span{font-size:.875rem;color:#2d3748}.success-message{padding:.75rem 1rem;background-color:#c6f6d5;color:#22543d;border-radius:6px;font-size:.875rem;border:1px solid #9ae6b4}.signup-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.signup-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:3rem;max-width:500px;width:100%}.signup-card h1{font-size:2rem;margin-bottom:.5rem;color:#213547;text-align:center}.signup-subtitle{text-align:center;color:#6c757d;margin-bottom:2rem}.signup-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label{font-weight:500;color:#495057;font-size:.875rem}.form-input{padding:.75rem;border:1px solid #dee2e6;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-full-width{width:100%;margin-top:.5rem}.signup-footer{margin-top:2rem;text-align:center;padding-top:2rem;border-top:1px solid #e2e8f0}.signup-footer p{color:#6c757d;margin:0}.signup-link{color:#667eea;text-decoration:none;font-weight:600}.signup-link:hover{text-decoration:underline}.verification-card{text-align:center;max-width:600px}.verification-icon{font-size:4rem;margin-bottom:1rem}.verification-message{font-size:1.125rem;color:#495057;margin-bottom:1rem}.verification-message strong{color:#667eea}.verification-instructions{color:#6c757d;line-height:1.6;margin-bottom:2rem}.dev-verification{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:1rem;margin-bottom:2rem}.dev-note{font-size:.875rem;color:#856404;margin-bottom:.5rem;font-weight:600}.verification-link{display:inline-block;color:#667eea;text-decoration:none;font-weight:600;word-break:break-all}.verification-link:hover{text-decoration:underline}.verification-actions{display:flex;flex-direction:column;gap:1rem}.verification-actions button,.verification-actions a{width:100%;text-align:center;text-decoration:none}@media (max-width: 768px){.signup-container{padding:1rem}.signup-card{padding:2rem}.signup-card h1{font-size:1.5rem}.form-row{grid-template-columns:1fr}}@media (prefers-color-scheme: dark){.signup-card{background:#2a2a2a}.signup-card h1{color:#ffffffde}.signup-subtitle,.verification-instructions{color:#fff9}.form-group label{color:#ffffffde}.form-input{background:#1e1e1e;border-color:#3a3a3a;color:#ffffffde}.signup-footer{border-top-color:#3a3a3a}.signup-footer p{color:#fff9}.verification-message{color:#ffffffde}}.password-requirements{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:1rem;margin-top:.5rem;font-size:.875rem}.requirements-title{font-weight:600;color:#495057;margin:0 0 .5rem}.password-requirements ul{margin:0;padding-left:1.5rem;list-style-type:disc}.password-requirements li{color:#6c757d;margin-bottom:.25rem;line-height:1.4}@media (prefers-color-scheme: dark){.password-requirements{background:#1e1e1e;border-color:#3a3a3a}.requirements-title{color:#ffffffde}.password-requirements li{color:#fff9}}.verify-email-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.verify-email-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:3rem;max-width:500px;width:100%;text-align:center}.status-icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;margin:0 auto 1.5rem;font-weight:700}.success-icon{background:#d4edda;color:#155724}.error-icon{background:#f8d7da;color:#721c24}.verify-email-card h1{font-size:2rem;margin-bottom:1rem;color:#213547}.status-message{font-size:1.125rem;color:#495057;margin-bottom:1.5rem;line-height:1.6}.redirect-message{color:#6c757d;font-size:.875rem;margin-bottom:1.5rem}.error-actions{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.error-actions a{text-decoration:none;width:100%}@media (max-width: 768px){.verify-email-container{padding:1rem}.verify-email-card{padding:2rem}.verify-email-card h1{font-size:1.5rem}.status-icon{width:60px;height:60px;font-size:2rem}}@media (prefers-color-scheme: dark){.verify-email-card{background:#2a2a2a}.verify-email-card h1,.status-message{color:#ffffffde}.redirect-message{color:#fff9}}.invitation-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.invitation-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:3rem;max-width:500px;width:100%;text-align:center}.invitation-card.error-card{max-width:400px}.invitation-icon,.error-icon{font-size:4rem;margin-bottom:1rem}.invitation-card h1{font-size:2rem;color:#213547;margin-bottom:1.5rem}.invitation-details{background:#f8f9fa;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.invitation-message{color:#6c757d;margin-bottom:1rem;font-size:1rem}.book-title{font-size:1.5rem;color:#646cff;margin:1rem 0;font-weight:600}.group-name{color:#6c757d;font-size:.9rem;margin:0}.invitation-form{text-align:left}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#213547;font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:.875rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:#646cff;box-shadow:0 0 0 3px #646cff1a}.form-group input:disabled{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.email-display{background:#f8f9fa!important;font-weight:500}.info-text{color:#6c757d;font-size:.9rem;margin-bottom:1.5rem;text-align:center}.accept-button{width:100%;padding:1rem;font-size:1.1rem;margin-top:1rem}.decline-button{width:100%;padding:1rem;font-size:1rem;margin-top:.75rem;background:#fff;color:#666;border:2px solid #ddd}.decline-button:hover{background:#f5f5f5;border-color:#999;color:#333}.invitation-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.expires-text{color:#9ca3af;font-size:.85rem;margin:0 0 .5rem}.help-text{color:#9ca3af;font-size:.8rem;margin:0;font-style:italic}.error-message{background:#fee2e2;border:1px solid #fecaca;border-radius:8px;padding:1rem;margin-bottom:1.5rem;color:#991b1b;font-size:.9rem}.error-text{color:#dc3545;font-size:1.1rem;margin:1.5rem 0}@media (max-width: 768px){.invitation-container{padding:1rem}.invitation-card{padding:2rem 1.5rem}.invitation-card h1{font-size:1.5rem}.book-title{font-size:1.25rem}}@media (prefers-color-scheme: dark){.invitation-card{background:#1e1e1e}.invitation-card h1{color:#ffffffde}.invitation-details{background:#2a2a2a}.form-group label{color:#ffffffde}.form-group input{background:#2a2a2a;border-color:#3a3a3a;color:#ffffffde}.form-group input:focus{border-color:#646cff}.form-group input:disabled{background:#1e1e1e;color:#ffffff80}}.reader-comment-viewer{display:flex;flex-direction:column;height:100%;background:#fff;border-radius:12px;overflow:hidden}.comment-viewer-header{position:relative;display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #e2e8f0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.header-content{flex:1;min-width:0}.header-content h2{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:#fff}.comment-count{margin:0;font-size:.875rem;opacity:.9}.btn-close{background:transparent;border:none;color:#fff;font-size:2rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s;line-height:1;padding:0;flex-shrink:0;margin-left:auto;order:2}.btn-close:hover{background:#fff3}.error-message{padding:1rem;margin:1rem 2rem;background-color:#fed7d7;color:#c53030;border-radius:6px;border:1px solid #fc8181}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:#718096}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state p{margin:.5rem 0;font-size:1rem}.empty-state-hint{font-size:.875rem;color:#a0aec0}.comments-list{flex:1;overflow-y:auto;padding:1.5rem 2rem;display:flex;flex-direction:column;gap:1rem}.comment-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.25rem;transition:box-shadow .2s}.comment-card:hover{box-shadow:0 2px 8px #0000001a}.comment-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.comment-date{font-size:.875rem;color:#718096}.comment-edited{font-size:.75rem;color:#a0aec0;font-style:italic}.comment-context{margin-bottom:.75rem;padding:.75rem;background:#fff;border-left:3px solid #667eea;border-radius:4px}.context-label{font-size:.75rem;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:.25rem}.context-snippet{font-style:italic;color:#4a5568;font-size:.9375rem}.comment-text{margin-bottom:.75rem;line-height:1.6;color:#2d3748;white-space:pre-wrap;word-wrap:break-word}.comment-edit-form{margin-bottom:.75rem}.comment-edit-textarea{width:100%;padding:.75rem;border:2px solid #cbd5e0;border-radius:6px;font-size:1rem;font-family:inherit;resize:vertical;min-height:100px;margin-bottom:.75rem}.comment-edit-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.comment-edit-textarea:disabled{background:#f7fafc;cursor:not-allowed}.comment-edit-actions{display:flex;gap:.5rem}.comment-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.comment-location{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#718096}.location-icon{font-size:1rem}.location-text{font-size:.875rem}.comment-actions{display:flex;gap:.5rem}.btn-edit,.btn-delete{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-edit{background:#edf2f7;color:#4a5568}.btn-edit:hover:not(:disabled){background:#e2e8f0;color:#2d3748}.btn-delete{background:#fed7d7;color:#c53030}.btn-delete:hover:not(:disabled){background:#fc8181;color:#fff}.btn-edit:disabled,.btn-delete:disabled{opacity:.5;cursor:not-allowed}.btn-primary,.btn-secondary{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5568d3}.btn-secondary:hover:not(:disabled){background:#cbd5e0}@media (max-width: 768px){.comment-viewer-header{padding:1rem 1.5rem}.header-content h2{font-size:1.25rem}.comments-list,.comment-card{padding:1rem}.comment-footer{flex-direction:column;align-items:flex-start}.comment-actions{width:100%;justify-content:flex-end}}.book-list-container{min-height:100vh;padding:2rem;overflow-x:hidden}.book-list-container *:focus,.book-list-container *:focus-visible{outline:none!important;box-shadow:none!important}.book-list-container::-webkit-scrollbar-x{display:none}.book-list-container{-ms-overflow-style:none;scrollbar-width:none}.book-list-header{margin-bottom:1.5rem}.header-content{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.book-list-title{font-size:2.5rem;font-weight:700;color:#1a202c;margin:0}.btn-upgrade-author{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d;white-space:nowrap}.btn-upgrade-author:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.upgrade-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.upgrade-panel{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:700px;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s ease}.upgrade-panel-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;font-size:2rem;color:#718096;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;line-height:1;padding:0;z-index:1}.upgrade-panel-close:hover{background:#f7fafc;color:#2d3748}.upgrade-panel-header{text-align:center;padding:3rem 2rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px 16px 0 0}.upgrade-icon{font-size:4rem;margin-bottom:1rem}.upgrade-panel-header h2{font-size:2rem;font-weight:700;margin:0 0 .5rem}.upgrade-subtitle{font-size:1.125rem;margin:0;opacity:.95}.upgrade-benefits{padding:2rem;display:grid;gap:1.5rem}.benefit-item{display:flex;gap:1rem;align-items:start}.benefit-icon{font-size:2rem;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#f7fafc;border-radius:12px}.benefit-content h3{font-size:1.125rem;font-weight:600;color:#1a202c;margin:0 0 .25rem}.benefit-content p{font-size:.9375rem;color:#718096;margin:0;line-height:1.5}.upgrade-panel-footer{padding:2rem;border-top:1px solid #e2e8f0;background:#f7fafc;border-radius:0 0 16px 16px}.upgrade-note{text-align:center;font-size:.875rem;color:#718096;margin:0 0 1.5rem}.upgrade-actions{display:flex;gap:1rem;justify-content:center}.btn-upgrade{padding:1rem 2rem;font-size:1.125rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none}.btn-upgrade:hover{background:linear-gradient(135deg,#5568d3,#653a8b)}.btn-upgrade:disabled{opacity:.6;cursor:not-allowed}.book-list-subtitle{font-size:1.125rem;color:#718096;margin:.5rem 0 0}.book-filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-button{padding:.75rem 1.5rem;background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;color:#666}.filter-button:hover{border-color:#667eea;color:#667eea;background:#f8f9ff}.filter-button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.filter-button.active:hover{background:linear-gradient(135deg,#5568d3,#653a8b)}.loading-spinner{display:flex;justify-content:center;align-items:center;min-height:50vh;font-size:1.25rem;color:#4a5568}.book-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;min-width:0}.book-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.book-card-header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #e2e8f0;overflow:hidden;min-height:140px;max-height:140px;display:flex;align-items:center;border-radius:12px 12px 0 0}.book-title{font-size:1.25rem;font-weight:600;color:#1a202c;margin:0;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;text-align:left;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.book-card-body{padding:1rem 1.5rem;flex:1;display:flex;flex-direction:column;gap:1rem;overflow:hidden}.book-metadata{display:flex;flex-direction:column;gap:.5rem;min-width:0;align-items:center}.metadata-item{display:flex;justify-content:center;font-size:.875rem;gap:.5rem;min-width:0}.metadata-label{color:#718096;font-weight:500;flex-shrink:0}.metadata-value{color:#2d3748;font-weight:600;word-wrap:break-word;overflow-wrap:break-word;text-align:center;min-width:0}.progress-section{display:flex;flex-direction:column;gap:.5rem}.progress-header{display:flex;justify-content:space-between;align-items:center}.progress-label{font-size:.875rem;font-weight:600;color:#4a5568}.progress-percentage{font-size:.875rem;font-weight:700;color:#667eea}.progress-bar{height:8px;background-color:#e2e8f0;border-radius:4px;overflow:hidden;display:none}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;border-radius:4px;display:none}.book-status{display:flex;gap:.5rem;justify-content:center}.status-archived{background-color:#e2e8f0;color:#4a5568}.book-card-footer{padding:1rem 1.5rem 1.5rem;display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.read-button{flex:1;min-width:120px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:8px;outline:none;border:none}.read-button:focus,.read-button:focus-visible{outline:none;box-shadow:none}.archive-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:8px;background:#fff;color:#666;border:2px solid #e0e0e0;cursor:pointer;transition:all .2s ease;white-space:nowrap}.archive-button:hover{background:#f5f5f5;border-color:#999;color:#333}.archive-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.book-list-container{padding:1rem}.book-list-title{font-size:2rem}.book-list-subtitle{font-size:1rem}.books-grid{grid-template-columns:1fr}.header-content{flex-direction:column;align-items:stretch}.btn-upgrade-author{width:100%}.upgrade-panel-header{padding:2.5rem 1.5rem 1.5rem}.upgrade-panel-header h2{font-size:1.5rem}.upgrade-subtitle{font-size:1rem}.upgrade-benefits,.upgrade-panel-footer{padding:1.5rem}.upgrade-actions{flex-direction:column}.upgrade-actions button{width:100%}}@media (max-width: 480px){.book-list-container{padding:1rem}.book-list-title{font-size:2rem}.upgrade-icon{font-size:3rem}.benefit-item{gap:.75rem}.benefit-icon{font-size:1.5rem;width:40px;height:40px}}.invitations-banner{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:2rem;margin-bottom:2rem;color:#fff;box-shadow:0 4px 12px #667eea4d}.invitations-header{margin-bottom:1.5rem}.invitations-header h2{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:#fff}.invitations-header p{font-size:.9375rem;margin:0;color:#ffffffe6}.invitations-list{display:grid;gap:1rem}.invitation-card{background:#fff;border-radius:8px;padding:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;box-shadow:0 2px 8px #0000001a}.invitation-info{flex:1}.invitation-info h3{font-size:1.125rem;font-weight:600;color:#1a202c;margin:0 0 .5rem}.invitation-from{font-size:.875rem;color:#718096;margin:0 0 .25rem}.invitation-expires{font-size:.8125rem;color:#a0aec0;margin:0}.accept-button{padding:.75rem 1.5rem;font-size:.9375rem;white-space:nowrap}@media (max-width: 640px){.invitation-card{flex-direction:column;align-items:stretch}.accept-button{width:100%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:900px;max-height:90vh;overflow:hidden;animation:slideUp .3s ease}.comment-viewer-modal{display:flex;flex-direction:column}.view-comments-button{white-space:nowrap}.find-books{padding:2rem;max-width:1400px;margin:0 auto}.find-books-header{margin-bottom:2rem}.find-books-header h1{font-size:2rem;color:#1a202c;margin:0 0 .5rem}.privacy-notice{background-color:#fef3c7;color:#92400e;padding:.75rem 1rem;border-radius:8px;border:1px solid #fbbf24;font-size:.875rem;margin:1rem 0}.search-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.filter-group{display:flex;flex-direction:column;gap:.5rem}.genre-filter-group,.autocomplete-wrapper{position:relative}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #cbd5e0;border-top:none;border-radius:0 0 8px 8px;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 4px 6px #0000001a}.autocomplete-item{padding:.75rem;cursor:pointer;transition:background-color .2s}.autocomplete-item:hover{background-color:#f7fafc}.autocomplete-item:active{background-color:#edf2f7}.clear-button{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#718096;font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s;z-index:10}.clear-button:hover{color:#2d3748}.clear-button:focus{outline:2px solid #6366f1;outline-offset:2px;border-radius:4px}.filter-group label{font-size:.875rem;font-weight:600;color:#4a5568}.filter-input{padding:.75rem 2.5rem .75rem 1rem;border:1px solid #cbd5e0;border-radius:8px;font-size:1rem;transition:all .2s;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:none;background-color:#fff}.filter-input::-webkit-search-decoration,.filter-input::-webkit-search-cancel-button,.filter-input::-webkit-search-results-button,.filter-input::-webkit-search-results-decoration{display:none}.filter-input::-webkit-input-placeholder{padding-left:0}.filter-input::-moz-placeholder{padding-left:0}.filter-input::placeholder{padding-left:0}.filter-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;font-size:1.25rem;color:#4a5568}.spinner{width:50px;height:50px;border:5px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1.5rem}.error-message{padding:1rem;background-color:#fed7d7;color:#c53030;border-radius:8px;margin-bottom:1rem;border:1px solid #fc8181}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;color:#718096}.empty-state h2{font-size:1.5rem;color:#2d3748;margin:0 0 .5rem}.empty-state p{font-size:1rem;margin:0}.books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.book-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;transition:all .2s;display:flex;flex-direction:column}.book-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.book-card-header{padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-height:140px;max-height:140px;display:flex;align-items:center;overflow:hidden;border-radius:12px 12px 0 0}.book-title{font-size:1.25rem;font-weight:600;margin:0;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word;text-align:left;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.book-card-body{padding:1.5rem;flex:1;display:flex;flex-direction:column;gap:1rem}.book-author{font-size:.875rem;color:#718096;margin:0;font-weight:500}.book-genres{display:flex;flex-wrap:wrap;gap:.5rem}.genre-tag{padding:.375rem .75rem;background-color:#e0e7ff;color:#4338ca;border-radius:6px;font-size:.75rem;font-weight:600}.feedback-deadline{display:flex;justify-content:center;align-items:center;gap:.5rem;font-size:.875rem}.deadline-label{color:#718096;font-weight:500}.deadline-value{color:#2d3748;font-weight:600}.book-status{display:flex;justify-content:center;gap:.5rem}.status-badge{padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-open{background-color:#c6f6d5;color:#22543d}.status-closed{background-color:#fed7d7;color:#742a2a}.book-card-footer{padding:1rem 1.5rem 1.5rem;display:flex;justify-content:center}.btn-primary,.btn-secondary,.btn-success{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;width:100%}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:#e2e8f0;color:#4a5568;cursor:default}.btn-success{background-color:#10b981;color:#fff;cursor:default}@media (max-width: 768px){.find-books{padding:1rem}.find-books-header h1{font-size:1.5rem}.search-filters,.books-grid{grid-template-columns:1fr}}.invitations-container{max-width:1200px;margin:0 auto;padding:2rem}.invitations-header{margin-bottom:2rem}.invitations-title{font-size:2rem;font-weight:600;color:#1a1a1a;margin:0 0 .5rem}.invitations-subtitle{font-size:1rem;color:#666;margin:0}.error-message{background-color:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem}.empty-state{text-align:center;padding:4rem 2rem;background:#f9f9f9;border-radius:12px;margin-top:2rem}.empty-state-icon{font-size:4rem;margin-bottom:1rem}.empty-state h2{font-size:1.5rem;color:#333;margin:0 0 .5rem}.empty-state p{color:#666;margin:.5rem 0;font-size:1rem}.empty-state .help-text{color:#999;font-size:.9rem;margin-top:1rem}.invitations-content{margin-top:2rem}.invitations-count{font-size:.9rem;color:#666;margin-bottom:1.5rem;font-weight:500}.invitations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.invitation-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;overflow:hidden;transition:all .2s ease;box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:column}.invitation-card.declined{opacity:.8;border-color:#ccc}.invitation-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.invitation-card.declined:hover{opacity:1}.invitation-card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;gap:1rem}.invitation-card.declined .invitation-card-header{background:linear-gradient(135deg,#999,#666)}.invitation-badge{background:#ffffff4d;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.invitation-time{font-size:.85rem;opacity:.9;background:#ffffff4d;padding:.25rem .75rem;border-radius:12px;font-weight:600}.invitation-card-body{padding:1.25rem;overflow:hidden}.invitation-book-title{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0 0 1.25rem;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word}.invitation-details{display:flex;flex-direction:column;gap:1rem}.invitation-detail-item{display:flex;align-items:flex-start;gap:.75rem}.detail-icon{font-size:1.25rem;line-height:1;margin-top:.1rem}.detail-content{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0;overflow:hidden}.detail-label{font-size:.75rem;color:#999;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.detail-value{font-size:.95rem;color:#333;font-weight:500;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word}.declined-notice{margin-top:1rem;padding:.75rem;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;font-size:.9rem;color:#856404;word-wrap:break-word;overflow-wrap:break-word}.invitation-card-footer{padding:1.25rem;background:#f9f9f9;border-top:1px solid #e0e0e0;display:flex;gap:.75rem}.accept-invitation-button{flex:1;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.accept-invitation-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.accept-invitation-button:active{transform:translateY(0)}.decline-invitation-button{padding:.75rem 1.5rem;background:#fff;color:#666;border:1px solid #ddd;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.decline-invitation-button:hover{background:#f5f5f5;border-color:#999;color:#333}@media (max-width: 768px){.invitations-container{padding:1rem}.invitations-title{font-size:1.5rem}.invitations-grid{grid-template-columns:1fr;gap:1rem}.empty-state{padding:3rem 1.5rem}.empty-state-icon{font-size:3rem}}.reading-preferences-container{max-width:900px;margin:0 auto;padding:2rem}.reading-preferences{background:#fff;border-radius:12px;padding:2.5rem;box-shadow:0 2px 8px #0000001a}.reading-preferences h1{margin:0 0 .5rem;color:#333;font-size:2rem}.preferences-description{margin:0 0 2rem;color:#666;font-size:1rem;line-height:1.5}.preferences-form{display:flex;flex-direction:column;gap:2rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#333;font-size:.95rem}.form-group select,.form-group input[type=text]{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group select:focus,.form-group input[type=text]:focus{outline:none;border-color:#3498db}.form-group select:disabled,.form-group input[type=text]:disabled{background-color:#f5f5f5;cursor:not-allowed}.help-text{font-size:.85rem;color:#666;margin:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.color-input-group{display:flex;gap:.5rem;align-items:center}.color-input-group input[type=color]{width:60px;height:40px;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:2px}.color-input-group input[type=color]:disabled{cursor:not-allowed;opacity:.6}.color-text-input{flex:1;font-family:monospace;text-transform:uppercase}.section-heading{margin:1.5rem 0 1rem;color:#333;font-size:1.1rem;font-weight:600;padding-bottom:.5rem;border-bottom:1px solid #e9ecef}.section-heading:first-of-type{margin-top:0}.preview-section{margin-top:1rem;padding-top:2rem;border-top:2px solid #e9ecef}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.preview-header h3{margin:0;color:#333;font-size:1.2rem;font-weight:600}.preview-mode-toggle{display:flex;gap:.5rem;background:#f5f5f5;padding:4px;border-radius:6px}.mode-toggle-btn{padding:.5rem 1rem;border:none;border-radius:4px;background:transparent;color:#666;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.mode-toggle-btn:hover:not(:disabled){background:#e0e0e0}.mode-toggle-btn.active{background:#fff;color:#333;box-shadow:0 1px 3px #0000001a}.mode-toggle-btn:disabled{cursor:not-allowed;opacity:.6}.preview-box{padding:2rem;border:2px solid #ddd;border-radius:8px;min-height:200px;transition:all .3s}.preview-box p{margin:0 0 1rem;line-height:1.8;font-size:1.1rem}.preview-box p:last-child{margin-bottom:0}.form-actions{display:flex;gap:1rem;margin-top:1rem}.btn-primary,.btn-secondary{padding:.875rem 1.75rem;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2980b9}.btn-primary:disabled{background-color:#95a5a6;cursor:not-allowed}.btn-secondary{background-color:#ecf0f1;color:#333}.btn-secondary:hover:not(:disabled){background-color:#bdc3c7}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.reading-preferences-container{padding:1rem}.reading-preferences{padding:1.5rem}.reading-preferences h1{font-size:1.5rem}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}.preview-box{padding:1.5rem}.preview-box p{font-size:1rem}.preview-header{flex-direction:column;align-items:flex-start;gap:1rem}.preview-mode-toggle{width:100%}.mode-toggle-btn{flex:1}}.comment-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.comment-panel{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}.comment-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.comment-panel-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#333}.close-button{background:none;border:none;font-size:2rem;line-height:1;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s;min-width:44px;min-height:44px}.close-button:hover{background-color:#f5f5f5;color:#333}.close-button:focus{outline:2px solid #007bff;outline-offset:2px}.comment-panel-content{padding:1.5rem}.selected-text-preview{margin-bottom:1.5rem}.selected-text-preview label{display:block;font-weight:600;color:#555;margin-bottom:.5rem;font-size:.9rem}.selected-text{background-color:#f8f9fa;border-left:4px solid #007bff;padding:1rem;margin:0;font-style:italic;color:#333;border-radius:4px;max-height:150px;overflow-y:auto;line-height:1.6}.form-group{margin-bottom:1rem}.form-group label{display:block;font-weight:600;color:#555;margin-bottom:.5rem;font-size:.9rem}.comment-textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:1rem;line-height:1.5;resize:vertical;transition:border-color .2s}.comment-textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.comment-textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.9rem;border-left:4px solid #c33}.success-message{background-color:#efe;color:#3c3;padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.9rem;border-left:4px solid #3c3}.comment-panel-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s;min-height:44px}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-primary:focus:not(:disabled){outline:2px solid #007bff;outline-offset:2px}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-secondary:active:not(:disabled){transform:scale(.98)}.btn-secondary:focus:not(:disabled){outline:2px solid #6c757d;outline-offset:2px}.btn-secondary:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.comment-panel-overlay{padding:0;align-items:flex-end}.comment-panel{max-width:100%;border-radius:8px 8px 0 0;max-height:85vh}.comment-panel-header,.comment-panel-content{padding:1rem}.comment-panel-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.comment-indicator{z-index:100;cursor:pointer;-webkit-user-select:none;user-select:none}.comment-marker{display:inline-block;font-size:1.2rem;line-height:1;padding:2px 4px;background-color:#ffeb3b4d;border-radius:4px;transition:all .2s ease}.comment-indicator:hover .comment-marker{background-color:#ffeb3b99;transform:scale(1.1)}.comment-indicator:focus{outline:2px solid #2196F3;outline-offset:2px;border-radius:4px}.comment-tooltip{position:absolute;left:50%;transform:translate(-50%);width:300px;max-width:90vw;background-color:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:12px;z-index:1000;animation:fadeIn .2s ease}.comment-tooltip.top{bottom:calc(100% + 8px)}.comment-tooltip.bottom{top:calc(100% + 8px)}.comment-tooltip:before{content:"";position:absolute;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent}.comment-tooltip.top:before{bottom:-8px;border-top:8px solid white}.comment-tooltip.bottom:before{top:-8px;border-bottom:8px solid white}.comment-tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #eee}.comment-date{font-size:.75rem;color:#666}.comment-tooltip-context{margin-bottom:8px;padding:8px;background-color:#f5f5f5;border-radius:4px;font-size:.85rem;color:#555;font-style:italic;line-height:1.4}.comment-tooltip-text{font-size:.9rem;color:#333;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 768px){.comment-tooltip{width:280px;font-size:.9rem}.comment-marker{font-size:1rem}}.comment-overlay{position:relative;pointer-events:none}.comment-overlay>*{pointer-events:auto}.comment-highlight{background-color:#ffeb3b4d;border-radius:2px;padding:0 2px;transition:background-color .2s ease}.comment-highlight:hover{background-color:#ffeb3b80}.comment-digest-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.comment-digest{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.comment-digest-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e0e0e0;background-color:#f8f9fa}.comment-digest-header h2{margin:0;font-size:1.5rem;color:#333}.comment-digest-header .close-button{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s;min-width:44px;min-height:44px}.comment-digest-header .close-button:hover{background-color:#e0e0e0;color:#333}.comment-digest-header .close-button:focus{outline:2px solid #007bff;outline-offset:2px}.comment-digest-content{flex:1;overflow-y:auto;padding:1.5rem}.no-comments{text-align:center;padding:3rem 1rem;color:#666}.no-comments p{margin:.5rem 0;font-size:1rem}.no-comments .hint{font-size:.9rem;color:#999;font-style:italic}.comment-list{display:flex;flex-direction:column;gap:1rem}.comment-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s}.comment-item:hover{background:#e9ecef;border-color:#007bff;box-shadow:0 2px 8px #007bff1a;transform:translateY(-1px)}.comment-item:focus{outline:2px solid #007bff;outline-offset:2px}.comment-item-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.comment-number{background:#007bff;color:#fff;font-size:.75rem;font-weight:700;padding:.25rem .5rem;border-radius:4px;min-width:32px;text-align:center}.comment-location{font-size:.875rem;color:#666;font-weight:500}.comment-context{margin-bottom:.75rem}.context-snippet{margin:0;padding:.5rem .75rem;background:#fff;border-left:3px solid #007bff;font-size:.875rem;color:#555;font-style:italic;line-height:1.5}.comment-text{font-size:.95rem;color:#333;line-height:1.6;margin-bottom:.5rem;white-space:pre-wrap;word-wrap:break-word}.comment-meta{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid #e0e0e0}.comment-date{font-size:.75rem;color:#999}.comment-digest-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-top:1px solid #e0e0e0;background-color:#f8f9fa}.comment-count{font-size:.875rem;color:#666;font-weight:500}.btn-secondary{background-color:#6c757d;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:4px;font-size:.95rem;cursor:pointer;transition:background-color .2s;min-height:44px}.btn-secondary:focus{outline:2px solid #6c757d;outline-offset:2px}@media (max-width: 768px){.comment-digest-overlay{padding:0}.comment-digest{max-width:100%;max-height:100vh;border-radius:0}.comment-digest-header{padding:1rem}.comment-digest-header h2{font-size:1.25rem}.comment-digest-content{padding:1rem}.comment-item{padding:.875rem}.comment-item-header{flex-wrap:wrap}.comment-location,.context-snippet{font-size:.8rem}.comment-text{font-size:.875rem}}.comment-digest-content::-webkit-scrollbar{width:8px}.comment-digest-content::-webkit-scrollbar-track{background:#f1f1f1}.comment-digest-content::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.comment-digest-content::-webkit-scrollbar-thumb:hover{background:#555}.paginated-content-wrapper{display:flex;flex-direction:column;height:calc(100vh - 60px);width:100%;background:#fff;margin-top:60px}.paginated-content-viewport{flex:1;overflow:hidden;position:relative;padding:2rem;scroll-behavior:smooth;-webkit-user-select:text;user-select:text;cursor:text}.paginated-content{min-height:100%;-webkit-user-select:text;user-select:text;cursor:text}.html-content{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:18px;line-height:1.7;max-width:800px;margin:0 auto}.txt-content{font-family:Courier New,Courier,monospace;font-size:16px;line-height:1.6;white-space:pre-wrap;max-width:900px;margin:0 auto}.paginated-content h1{font-size:2em;margin-top:.67em;margin-bottom:.67em;font-weight:700}.paginated-content h2{font-size:1.5em;margin-top:.83em;margin-bottom:.83em;font-weight:700}.paginated-content h3{font-size:1.17em;margin-top:1em;margin-bottom:1em;font-weight:700}.paginated-content p{margin-bottom:1em}.paginated-content ul,.paginated-content ol{margin-bottom:1em;padding-left:2.5em}.paginated-content li{margin-bottom:.5em}.paginated-content a{color:#646cff;text-decoration:underline}.paginated-content a:hover{color:#535bf2}.pagination-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:#f5f5f5;border-top:1px solid #ddd;gap:1rem;flex-shrink:0}.pagination-info-bar{text-align:center;padding:.5rem;font-size:.875rem;color:#666;background:#fafafa;border-top:1px solid #e0e0e0;font-weight:500}.pagination-button{padding:.75rem 1.5rem;font-size:.9375rem;background:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s;white-space:nowrap;font-weight:500;flex:1;max-width:150px}.add-comment-button{padding:.75rem 1.5rem;font-size:.9375rem;background:#10b981;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s;white-space:nowrap;font-weight:500;flex:2;max-width:200px}.add-comment-button:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 2px 8px #10b9814d}.add-comment-button:active:not(:disabled){transform:translateY(0)}.add-comment-button:disabled{background:#cbd5e0;color:#718096;cursor:not-allowed;opacity:.6}.return-to-furthest-button{padding:.75rem 1.25rem;font-size:.9375rem;background:#f59e0b;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s;white-space:nowrap;font-weight:600;flex:1;max-width:150px}.return-to-furthest-button:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 2px 8px #f59e0b4d}.return-to-furthest-button:active{transform:translateY(0)}.pagination-button:hover:not(:disabled){background:#535bf2;transform:translateY(-1px);box-shadow:0 2px 8px #646cff4d}.pagination-button:disabled{background:#ccc;cursor:not-allowed;opacity:.5}.pagination-button:active:not(:disabled){transform:translateY(0)}@media (prefers-color-scheme: dark){.paginated-content-wrapper{background:#1a1a1a}.paginated-content-viewport{color:#e0e0e0}.pagination-footer{background:#2a2a2a;border-top-color:#444}.pagination-info{color:#e0e0e0}.paginated-content a{color:#8b95ff}.paginated-content a:hover{color:#a5adff}}@media (max-width: 768px){.paginated-content-viewport{padding:1rem}.html-content{font-size:16px}.txt-content{font-size:14px}.pagination-footer{padding:.75rem 1rem}.pagination-button{padding:.5rem 1rem;font-size:.875rem;max-width:120px}.add-comment-button{padding:.5rem 1rem;font-size:.875rem;max-width:150px}}.mobile-reader{position:fixed;top:0;left:0;right:0;bottom:0;background:#faf8f5;display:flex;flex-direction:column;overflow:hidden;font-family:Georgia,Times New Roman,serif;-webkit-user-select:none;user-select:none;transition:background-color .3s ease}.mobile-reader-loading,.mobile-reader-error,.mobile-reader-epub-notice{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:2rem;text-align:center}.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.mobile-reader-loading p,.mobile-reader-error p{color:#4a5568;font-size:1rem;margin:.5rem 0}.mobile-reader-epub-notice h2{color:#1a202c;margin-bottom:1rem}.mobile-reader-epub-notice p{color:#4a5568;margin:.5rem 0}.mobile-reader-epub-notice .btn-primary,.mobile-reader-epub-notice .btn-secondary{margin:.5rem}.mobile-reader-header{position:fixed;top:0;left:0;right:0;height:60px;background:#fff;display:flex;align-items:center;padding:0 1rem;z-index:100;border-bottom:1px solid rgba(0,0,0,.1);gap:1rem;transition:background-color .3s ease,border-color .3s ease}.mobile-reader-header.dark-mode{background:#2d3748;border-bottom:1px solid rgba(255,255,255,.1)}.mobile-reader-header .book-title{flex:1;font-size:1rem;font-weight:600;margin:0;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#333}.back-button{background:#f8f9fa;border:1px solid #dee2e6;color:#495057;font-size:.9rem;cursor:pointer;padding:.5rem 1rem;border-radius:6px;transition:all .2s;white-space:nowrap;min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.back-button.dark-mode{background:#4a5568;border:1px solid #718096;color:#e2e8f0}.back-button:hover{background:#e9ecef}.back-button.dark-mode:hover{background:#5a6778}.back-button:focus{outline:2px solid #6366f1;outline-offset:2px}.theme-toggle-button{background:#f8f9fa;border:1px solid #dee2e6;color:#495057;font-size:1.3rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s;min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center;margin-left:auto}.chapter-list-button{background:#f8f9fa;border:1px solid #dee2e6;color:#495057;font-size:1.3rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s;min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.chapter-list-button.dark-mode{background:#4a5568;border:1px solid #718096;color:#e2e8f0}.chapter-list-button:hover{background:#e9ecef;transform:scale(1.05)}.chapter-list-button.dark-mode:hover{background:#5a6778}.chapter-list-button:active{transform:scale(.95)}.chapter-list-button:focus{outline:2px solid #6366f1;outline-offset:2px}.theme-toggle-button.dark-mode{background:#4a5568;border:1px solid #718096;color:#e2e8f0}.theme-toggle-button:hover{background:#e9ecef;transform:scale(1.05)}.theme-toggle-button.dark-mode:hover{background:#5a6778}.theme-toggle-button:active{transform:scale(.95)}.theme-toggle-button:focus{outline:2px solid #6366f1;outline-offset:2px}.mobile-reader-content{position:fixed;top:60px;bottom:70px;left:0;right:0;overflow:hidden;padding:2rem 1.5rem;cursor:pointer;-webkit-user-select:text;user-select:text;display:flex;align-items:flex-start;justify-content:center}.page-content{max-width:700px;width:100%;line-height:1.8;font-size:1.1rem;color:inherit;overflow:hidden}.page-content h1{font-size:2rem;font-weight:700;color:inherit;margin:2rem 0 1rem;line-height:1.3}.page-content h2{font-size:1.6rem;font-weight:600;color:inherit;margin:1.5rem 0 1rem;line-height:1.3}.page-content h3{font-size:1.3rem;font-weight:600;color:inherit;margin:1.5rem 0 .75rem;line-height:1.3}.page-content p{margin:1rem 0;text-align:justify}.page-content blockquote{border-left:4px solid currentColor;opacity:.7;padding-left:1rem;margin:1.5rem 0;font-style:italic}.page-content code{background:#edf2f7;padding:.2rem .4rem;border-radius:3px;font-family:Courier New,monospace;font-size:.9em}.page-content pre{background:#2d3748;color:#e2e8f0;padding:1rem;border-radius:6px;overflow-x:auto;margin:1.5rem 0}.page-content pre code{background:none;padding:0;color:inherit}.page-content ul,.page-content ol{margin:1rem 0;padding-left:2rem}.page-content li{margin:.5rem 0}.page-content img{max-width:100%;height:auto;border-radius:6px;margin:1.5rem 0}.mobile-reader-footer{position:fixed;bottom:0;left:0;right:0;height:70px;background:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:100;border-top:1px solid rgba(0,0,0,.1);box-shadow:0 -2px 4px #0000000d;transition:background-color .3s ease,border-color .3s ease}.mobile-reader-footer.dark-mode{background:#2d3748;border-top:1px solid rgba(255,255,255,.1);box-shadow:0 -2px 4px #0000004d}.nav-button{background:#6366f1;color:#fff;border:none;width:50px;height:50px;border-radius:8px;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;min-height:44px;min-width:44px}.nav-button:hover:not(:disabled){background:#4f46e5;transform:scale(1.05)}.nav-button.dark-mode:hover:not(:disabled){background:#5a67d8}.nav-button:active:not(:disabled){transform:scale(.95)}.nav-button:focus:not(:disabled){outline:2px solid #6366f1;outline-offset:2px}.nav-button:disabled{background:#cbd5e0;cursor:not-allowed;opacity:.6}.nav-button.dark-mode:disabled{background:#4a5568}.add-comment-button-footer{background:#10b981;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;min-height:44px}.add-comment-button-footer:hover:not(:disabled){background:#059669;transform:scale(1.05)}.add-comment-button-footer.dark-mode:hover:not(:disabled){background:#0d9f6e}.add-comment-button-footer:active:not(:disabled){transform:scale(.95)}.add-comment-button-footer:focus:not(:disabled){outline:2px solid #10b981;outline-offset:2px}.add-comment-button-footer:disabled{background:#cbd5e0;color:#718096;cursor:not-allowed;opacity:.6}.add-comment-button-footer.dark-mode:disabled{background:#4a5568;color:#a0aec0}.return-to-furthest-button{background:#f59e0b;color:#fff;border:none;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;min-height:44px;display:flex;align-items:center;gap:.25rem}.return-to-furthest-button.dark-mode{background:#d97706}.return-to-furthest-button:hover{background:#d97706;transform:scale(1.05)}.return-to-furthest-button.dark-mode:hover{background:#b45309}.return-to-furthest-button:active{transform:scale(.95)}.return-to-furthest-button:focus{outline:2px solid #f59e0b;outline-offset:2px}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;text-decoration:none;display:inline-block}.btn-primary{background:#6366f1;color:#fff}.btn-secondary{background:#e2e8f0;color:#4a5568}.btn-secondary:hover{background:#cbd5e0}@media (max-width: 768px){.mobile-reader-content{padding:1.5rem 1rem}.page-content{font-size:1rem}.page-content h1{font-size:1.75rem}.page-content h2{font-size:1.4rem}.page-content h3{font-size:1.2rem}.nav-button{padding:.6rem 1rem;font-size:.9rem}.book-title{font-size:.9rem}}@media (max-width: 480px){.mobile-reader-content{padding:1rem .75rem}.page-content{font-size:.95rem}.nav-button{padding:.5rem .75rem;font-size:.85rem}.page-indicator{font-size:.9rem}}.chapter-list-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.chapter-list-content{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease-out}.chapter-list-content.dark-mode{background:#2d3748;color:#e2e8f0}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chapter-list-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e2e8f0}.chapter-list-content.dark-mode .chapter-list-header{border-bottom:1px solid #4a5568}.chapter-list-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#1a202c}.chapter-list-content.dark-mode .chapter-list-header h2{color:#e2e8f0}.chapter-list-header .close-button{background:none;border:none;font-size:1.5rem;color:#718096;cursor:pointer;padding:.25rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.chapter-list-header .close-button:hover{background:#f7fafc;color:#2d3748}.chapter-list-content.dark-mode .chapter-list-header .close-button{color:#a0aec0}.chapter-list-content.dark-mode .chapter-list-header .close-button:hover{background:#4a5568;color:#e2e8f0}.chapter-list-items{overflow-y:auto;padding:.5rem;flex:1}.chapter-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:.5rem;cursor:pointer;transition:all .2s;text-align:left;width:100%;font-size:1rem}.chapter-list-content.dark-mode .chapter-item{background:#1a202c;border:1px solid #4a5568;color:#e2e8f0}.chapter-item:hover{background:#f7fafc;border-color:#cbd5e0;transform:translate(4px)}.chapter-list-content.dark-mode .chapter-item:hover{background:#2d3748;border-color:#718096}.chapter-item.active{background:#eef2ff;border-color:#6366f1;font-weight:600}.chapter-list-content.dark-mode .chapter-item.active{background:#4c51bf;border-color:#6366f1;color:#fff}.chapter-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#e2e8f0;color:#4a5568;border-radius:6px;font-weight:600;font-size:.9rem;flex-shrink:0}.chapter-list-content.dark-mode .chapter-number{background:#4a5568;color:#e2e8f0}.chapter-item.active .chapter-number{background:#6366f1;color:#fff}.chapter-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.current-indicator{color:#6366f1;font-size:1.2rem;flex-shrink:0}.chapter-list-content.dark-mode .current-indicator{color:#a5b4fc}@media (max-width: 768px){.chapter-list-modal{padding:.5rem}.chapter-list-content{max-height:90vh}.chapter-list-header{padding:1rem}.chapter-list-header h2{font-size:1.25rem}.chapter-item{padding:.75rem;font-size:.95rem}.chapter-number{width:28px;height:28px;font-size:.85rem}}@media (prefers-reduced-motion: no-preference){.mobile-reader,.desktop-reader{transition:all .3s ease-in-out}.mobile-reader-header,.mobile-reader-footer,.desktop-reader-header,.desktop-reader-sidebar{transition:transform .3s ease-in-out,opacity .3s ease-in-out}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media (prefers-contrast: high){.mobile-reader,.desktop-reader,.nav-button,.back-button,.comment-digest-button,.add-comment-button{border:2px solid currentColor}}:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.skip-to-content{position:absolute;top:-40px;left:0;background:#6366f1;color:#fff;padding:8px;text-decoration:none;z-index:10000}.skip-to-content:focus{top:0}@media (min-width: 768px) and (max-width: 1024px){.mobile-reader .page-content,.desktop-reader .chapter-content{font-size:1.0625rem}.desktop-reader-sidebar{width:240px}.desktop-reader-content{margin-left:240px}}@media (min-width: 1440px){.desktop-reader-content{max-width:1000px}.chapter-content{font-size:1.1875rem}}@media (max-height: 500px) and (orientation: landscape){.mobile-reader-header,.mobile-reader-footer{height:50px}.mobile-reader-content{padding:1rem}.page-content{font-size:.95rem}}@media print{.mobile-reader-header,.mobile-reader-footer,.desktop-reader-header,.desktop-reader-sidebar,.scroll-to-top,.comment-digest-button,.add-comment-button,.back-button{display:none!important}.mobile-reader-content,.desktop-reader-content{padding:0;margin:0}.page-content,.chapter-content{font-size:12pt;line-height:1.5}}@media (hover: none) and (pointer: coarse){button,a,.chapter-nav-item{min-height:48px;min-width:48px}.nav-button:hover,.back-button:hover,.comment-digest-button:hover,.add-comment-button:hover{transform:none}}@media (hover: hover) and (pointer: fine){button,a{transition:all .2s ease}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.modal-open{overflow:hidden}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}.loading-spinner[role=status]{position:relative}.loading-spinner[role=status]:after{content:"Loading...";position:absolute;left:-9999px}.error-message[role=alert],.success-message[role=status]{position:relative}.reader-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f7fafc}.reader-placeholder,.reader-loading,.reader-error{text-align:center;padding:3rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-width:500px}.reader-placeholder h1,.reader-error h1{font-size:2rem;color:#1a202c;margin:0 0 1rem}.reader-placeholder p,.reader-loading p,.reader-error p{font-size:1rem;color:#718096;margin:.5rem 0}.reader-placeholder button,.reader-error button{margin-top:2rem}.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.btn-primary{background:#6366f1;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover{background:#4f46e5;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.landing-page{min-height:100vh;background:#fff}.landing-nav{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 0;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000d}.landing-nav-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.landing-nav-brand{font-size:1.5rem;font-weight:700;color:#667eea}.landing-nav-login{background:transparent;border:2px solid #667eea;color:#667eea;padding:.5rem 1.5rem;font-size:1rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s ease}.landing-nav-login:hover{background:#667eea;color:#fff}.login-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:420px;position:relative;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.login-modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;font-size:2rem;color:#718096;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;line-height:1;padding:0}.login-modal-close:hover{background:#f7fafc;color:#2d3748}.login-modal-card{padding:3rem}.login-modal-title{font-size:1.75rem;font-weight:700;color:#1a202c;margin:0 0 .5rem;text-align:center}.login-modal-subtitle{font-size:1rem;color:#718096;margin:0 0 2rem;text-align:center}.login-modal-form{display:flex;flex-direction:column;gap:1.5rem}.login-modal-form .form-group{display:flex;flex-direction:column;gap:.5rem}.login-modal-form .form-group label{font-size:.875rem;font-weight:600;color:#2d3748}.login-modal-form .form-group input{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:6px;font-size:1rem;transition:all .2s}.login-modal-form .form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-modal-form .form-group input:disabled{background-color:#f7fafc;cursor:not-allowed}.login-modal-form .error-message{padding:.75rem 1rem;background-color:#fed7d7;color:#c53030;border-radius:6px;font-size:.875rem;border:1px solid #fc8181}.login-modal-form .login-button{margin-top:.5rem;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;border-radius:6px;transition:all .2s;background:#667eea;color:#fff;border:none;cursor:pointer}.login-modal-form .login-button:hover{background:#5568d3}.login-modal-form .login-button:disabled{opacity:.6;cursor:not-allowed}.login-modal-footer{margin-top:2rem;padding-top:2rem;border-top:1px solid #e2e8f0;text-align:center}.login-modal-footer p{color:#6c757d;margin:0;font-size:.875rem}.login-modal-footer .toggle-mode-button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;padding:0;font-size:.875rem;text-decoration:none}.login-modal-footer .toggle-mode-button:hover{text-decoration:underline}.hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;min-height:600px}.hero-content{max-width:600px}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.1;margin:0 0 1.5rem}.hero-subtitle{font-size:1.25rem;line-height:1.6;margin:0 0 2rem;opacity:.95}.cta-button{background:#fff;color:#667eea;border:none;padding:1rem 2.5rem;font-size:1.125rem;font-weight:700;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px #00000026}.cta-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0003}.cta-button.large{padding:1.25rem 3rem;font-size:1.25rem}.hero-note{margin-top:1rem;font-size:.875rem;opacity:.9}.hero-image{display:flex;align-items:center;justify-content:center}.hero-image img{max-width:100%;height:auto;border-radius:12px;box-shadow:0 20px 60px #0000004d}.screenshot-placeholder{background:linear-gradient(135deg,#f7fafc,#e2e8f0);border:2px dashed #cbd5e0;border-radius:8px;display:flex;align-items:center;justify-content:center;min-height:300px;position:relative;overflow:hidden}.screenshot-placeholder:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.hero-screenshot{min-height:400px;background:linear-gradient(135deg,#667eea,#764ba2);border:none}.hero-screenshot .placeholder-content{color:#fff}.placeholder-content{text-align:center;z-index:1;position:relative}.placeholder-icon{font-size:4rem;margin-bottom:1rem;opacity:.8}.placeholder-content p{font-size:1.125rem;font-weight:600;color:#4a5568;margin:0}.hero-screenshot .placeholder-content p{color:#fff;opacity:.9}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.section-title{font-size:2.5rem;font-weight:700;text-align:center;margin:0 0 1rem;color:#1a202c}.section-subtitle{font-size:1.125rem;text-align:center;color:#718096;margin:0 0 3rem}.features{padding:5rem 0;background:#f7fafc}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.feature-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #00000014;transition:transform .3s ease,box-shadow .3s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{font-size:1.25rem;font-weight:700;margin:0 0 .75rem;color:#2d3748}.feature-card p{color:#718096;line-height:1.6;margin:0}.how-it-works{padding:5rem 0;background:#fff}.steps{display:flex;flex-direction:column;gap:4rem}.step{display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:start}.step:nth-child(2n){direction:rtl}.step:nth-child(2n) .step-content{direction:ltr}.step-number{width:60px;height:60px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}.step-content h3{font-size:1.75rem;font-weight:700;margin:0 0 .75rem;color:#2d3748}.step-content p{font-size:1.125rem;color:#718096;line-height:1.6;margin:0 0 1.5rem}.step-image{border-radius:12px;overflow:hidden;box-shadow:0 8px 24px #0000001f;background:#f7fafc;min-height:300px;display:flex;align-items:center;justify-content:center}.step-image img{max-width:100%;height:auto;display:block}.benefits{padding:5rem 0;background:#f7fafc}.benefits-split{display:grid;grid-template-columns:1fr 1fr;gap:4rem}.benefits-content h2{font-size:2rem;font-weight:700;margin:0 0 2rem;color:#2d3748}.benefits-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1.5rem}.benefits-list li{display:flex;gap:1rem;align-items:start}.check{width:28px;height:28px;background:#48bb78;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;font-size:1rem}.benefits-list strong{display:block;font-size:1.125rem;color:#2d3748;margin-bottom:.25rem}.benefits-list p{color:#718096;margin:0;line-height:1.5}.cta-section{padding:5rem 0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center}.cta-section h2{font-size:2.5rem;font-weight:700;margin:0 0 1rem}.cta-section>.container>p{font-size:1.25rem;margin:0 0 2rem;opacity:.95}.cta-note{margin-top:1rem;font-size:.875rem;opacity:.9}.footer{background:#2d3748;color:#fff;padding:3rem 0 1.5rem}.footer-content{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:2rem}.footer-brand h3{font-size:1.5rem;margin:0 0 .5rem}.footer-brand p{color:#a0aec0;margin:0}.footer-links h4{font-size:1rem;font-weight:700;margin:0 0 1rem}.footer-links ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.footer-links a{color:#a0aec0;text-decoration:none;transition:color .2s}.footer-links a:hover{color:#fff}.footer-bottom{border-top:1px solid #4a5568;padding-top:1.5rem;text-align:center}.footer-bottom p{color:#a0aec0;margin:0;font-size:.875rem}.footer-company-link{color:#a0aec0;text-decoration:none;transition:color .2s}.footer-company-link:hover{color:#fff;text-decoration:underline}@media (max-width: 1024px){.hero{grid-template-columns:1fr;gap:2rem;text-align:center}.hero-content{max-width:100%}.hero-title{font-size:2.5rem}.benefits-split{grid-template-columns:1fr;gap:3rem}.footer-content{grid-template-columns:1fr;gap:2rem}}@media (max-width: 768px){.hero{padding:3rem 1.5rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.125rem}.section-title{font-size:2rem}.features-grid{grid-template-columns:1fr}.step{grid-template-columns:1fr;gap:1rem}.step:nth-child(2n){direction:ltr}.step-number{width:50px;height:50px;font-size:1.25rem}.step-content h3{font-size:1.5rem}.cta-section h2{font-size:2rem}.login-modal-card{padding:2rem 1.5rem}.login-modal-title{font-size:1.5rem}}@media (max-width: 480px){.hero-title{font-size:1.75rem}.cta-button{width:100%;padding:1rem 1.5rem}.cta-button.large{padding:1.125rem 2rem;font-size:1.125rem}.landing-nav-content{padding:0 1rem}.landing-nav-brand{font-size:1.25rem}.landing-nav-login{padding:.5rem 1rem;font-size:.875rem}}.legal-page{min-height:100vh;background:#f7fafc;padding:2rem 1rem}.legal-container{max-width:900px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.legal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:3rem 2rem}.back-link{color:#fff;text-decoration:none;font-size:.9375rem;opacity:.9;transition:opacity .2s;display:inline-block;margin-bottom:1rem}.back-link:hover{opacity:1}.legal-header h1{font-size:2.5rem;font-weight:700;margin:0 0 .5rem}.last-updated{font-size:.9375rem;opacity:.9;margin:0}.legal-content{padding:3rem 2rem}.legal-content section{margin-bottom:2.5rem}.legal-content section:last-child{margin-bottom:0}.legal-content h2{font-size:1.75rem;font-weight:700;color:#2d3748;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.legal-content h3{font-size:1.25rem;font-weight:600;color:#4a5568;margin:1.5rem 0 .75rem}.legal-content p{color:#4a5568;line-height:1.7;margin:0 0 1rem}.legal-content p:last-child{margin-bottom:0}.legal-content ul{color:#4a5568;line-height:1.7;margin:0 0 1rem;padding-left:1.5rem}.legal-content li{margin-bottom:.5rem}.legal-content li:last-child{margin-bottom:0}.legal-content strong{color:#2d3748;font-weight:600}.legal-content a{color:#667eea;text-decoration:none;font-weight:600;transition:color .2s}.legal-content a:hover{color:#764ba2;text-decoration:underline}.legal-footer{padding:2rem;background:#f7fafc;border-top:1px solid #e2e8f0;display:flex;gap:1rem;justify-content:center}.btn-secondary{padding:.75rem 1.5rem;background:#fff;color:#4a5568;border:1px solid #e2e8f0;border-radius:6px;text-decoration:none;font-weight:600;transition:all .2s;display:inline-block}.btn-secondary:hover{background:#f7fafc;border-color:#cbd5e0;color:#2d3748}@media (max-width: 768px){.legal-page{padding:1rem .5rem}.legal-header{padding:2rem 1.5rem}.legal-header h1{font-size:2rem}.legal-content{padding:2rem 1.5rem}.legal-content h2{font-size:1.5rem}.legal-content h3{font-size:1.125rem}.legal-footer{flex-direction:column}.btn-secondary{width:100%;text-align:center}}@media (max-width: 480px){.legal-header h1{font-size:1.75rem}.legal-content,.legal-footer{padding:1.5rem 1rem}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.error-boundary-content{background:#fff;border-radius:12px;padding:3rem;max-width:600px;width:100%;box-shadow:0 20px 60px #0000004d;text-align:center}.error-icon{font-size:4rem;margin-bottom:1rem}.error-title{font-size:2rem;font-weight:700;color:#1a202c;margin-bottom:1rem}.error-message{font-size:1.125rem;color:#4a5568;margin-bottom:2rem;line-height:1.6}.error-details{text-align:left;margin:2rem 0;padding:1rem;background:#f7fafc;border-radius:8px;border:1px solid #e2e8f0}.error-details summary{cursor:pointer;font-weight:600;color:#2d3748;margin-bottom:.5rem}.error-stack{margin-top:1rem;padding:1rem;background:#2d3748;color:#f7fafc;border-radius:4px;overflow-x:auto;font-size:.875rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.error-actions .btn-primary,.error-actions .btn-secondary{min-width:140px}@media (max-width: 640px){.error-boundary-content{padding:2rem 1.5rem}.error-title{font-size:1.5rem}.error-message{font-size:1rem}.error-actions{flex-direction:column}.error-actions .btn-primary,.error-actions .btn-secondary{width:100%}}#root{width:100%;min-height:100vh;margin:0;padding:0}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary-color: #646cff;--primary-hover: #535bf2;--secondary-color: #6c757d;--success-color: #28a745;--danger-color: #dc3545;--warning-color: #ffc107;--info-color: #17a2b8;--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-dark: #242424;--text-primary: #213547;--text-secondary: #6c757d;--border-color: #dee2e6}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;min-width:320px;min-height:100vh;overflow-x:hidden;position:relative}body:after{content:none!important;display:none!important}body::-webkit-scrollbar-x{display:none}html{overflow-x:hidden;position:relative}html:after{content:none!important;display:none!important}html::-webkit-scrollbar-x{display:none}*:before,*:after{border-bottom:none!important}progress{display:none!important}[style*="bottom: 0"],[style*="bottom:0"]{display:none!important}#root{width:100%;min-height:100vh}h1{font-size:2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--primary-color);color:#fff;cursor:pointer;transition:all .25s}button:hover{background-color:var(--primary-hover)}button:focus,button:focus-visible{outline:none}button::-moz-focus-inner{border:0}*:focus{outline:none}*:focus-visible{outline:none}.btn-primary{background-color:var(--primary-color);color:#fff;border:none}.btn-primary:hover{background-color:var(--primary-hover)}.btn-secondary{background-color:var(--secondary-color);color:#fff;border:none}.btn-secondary:hover{background-color:#5a6268}.btn-danger{background-color:var(--danger-color);color:#fff;border:none}.btn-danger:hover{background-color:#c82333}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;font-size:1.2em;color:var(--text-secondary)}.error{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;color:var(--danger-color)}
