*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:#f5f5f5;color:#333;line-height:1.6}.container{flex:1;max-width:1200px;margin:0 auto;padding:20px;width:100%}header{background:#1a1a2e;color:#fff;padding:20px;margin-bottom:20px}header h1{font-size:1.5rem;font-weight:300;letter-spacing:.1em}nav{margin-top:10px}nav a{color:#888;text-decoration:none;margin-right:20px;font-size:.9rem}nav a:hover,nav a.active{color:#fff}.card{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.artifact-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px;width:100%}.artifact-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:transform .2s}.artifact-card:hover{transform:translateY(-2px)}.artifact-card img{width:100%;height:200px;object-fit:cover}.artifact-card .info{padding:15px}.artifact-card .info h3{font-size:.9rem;margin-bottom:5px}.artifact-card .info p{font-size:.8rem;color:#666}.artifact-view{display:grid;grid-template-columns:1fr 1fr;gap:30px}.artifact-view .image-pane img{width:100%;border-radius:8px}.artifact-view .text-pane{background:#fff;padding:30px;border-radius:8px;white-space:pre-wrap;font-family:Georgia,serif;line-height:1.8}.upload-zone{border:2px dashed #ccc;border-radius:8px;padding:60px;text-align:center;cursor:pointer;transition:border-color .2s}.upload-zone:hover,.upload-zone.dragover{border-color:#1a1a2e}.upload-zone input{display:none}button{background:#1a1a2e;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:.9rem}button:hover{background:#2a2a4e}button:disabled{background:#ccc;cursor:not-allowed}.loading{text-align:center;padding:40px;color:#666}@media(max-width:768px){.artifact-view{grid-template-columns:1fr}}header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.user-menu{display:flex;align-items:center;gap:15px}.user-name{font-size:.9rem;color:#ccc}.logout-btn{background:transparent;border:1px solid #555;color:#ccc;padding:6px 12px;font-size:.8rem}.logout-btn:hover{background:#333;border-color:#888}.login-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 200px)}.login-box{background:#fff;padding:40px;border-radius:8px;box-shadow:0 4px 12px #0000001a;width:100%;max-width:400px}.login-box h2{margin-bottom:30px;text-align:center;color:#1a1a2e}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-size:.9rem;color:#555}.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus{outline:none;border-color:#1a1a2e}.login-box button{width:100%;padding:14px;font-size:1rem;margin-top:10px}.error-message{background:#ffebee;color:#c62828;padding:12px;border-radius:4px;margin-bottom:20px;font-size:.9rem}.user-management .header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.user-management h2{font-size:1.3rem;color:#1a1a2e}.create-user-form{margin-bottom:20px}.create-user-form h3{margin-bottom:15px;font-size:1.1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-bottom:15px}.form-group select{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-size:1rem;background:#fff}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.users-table th{font-weight:600;color:#555;font-size:.85rem;text-transform:uppercase}.users-table tr.disabled-user{opacity:.6}.role-badge{padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.role-badge.admin{background:#e3f2fd;color:#1565c0}.role-badge.user{background:#f5f5f5;color:#666}.status-badge{padding:4px 8px;border-radius:4px;font-size:.75rem}.status-badge.active{background:#e8f5e9;color:#2e7d32}.status-badge.inactive{background:#ffebee;color:#c62828}.actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.action-btn{padding:6px 10px;font-size:.75rem;background:#f5f5f5;color:#333;border:1px solid #ddd}.action-btn:hover{background:#eee}.action-btn.danger{color:#c62828;border-color:#ffcdd2}.action-btn.danger:hover{background:#ffebee}.reset-password-inline{display:flex;gap:5px;margin-top:5px;width:100%}.reset-password-inline input{padding:6px;font-size:.8rem;border:1px solid #ddd;border-radius:4px;flex:1}.reset-password-inline button{padding:6px 10px;font-size:.75rem}@media(max-width:768px){.form-row{grid-template-columns:1fr}.users-table{font-size:.85rem}.actions{flex-direction:column;align-items:flex-start}}.upload-page{max-width:800px;margin:0 auto}.upload-header{margin-bottom:24px}.upload-header h2{margin-bottom:8px;color:#1a1a2e}.upload-subtitle{color:#666;font-size:.95rem}.upload-settings{margin-bottom:24px}.book-selector{display:flex;flex-direction:column;gap:8px}.book-selector label{font-weight:500;font-size:.9rem;color:#333}.book-selector select{padding:12px;font-size:1rem;border:1px solid #ddd;border-radius:6px;background:#fff;max-width:400px}.book-selector select:focus{outline:none;border-color:#1a1a2e}.new-book-input{display:flex;flex-direction:column;gap:4px;margin-top:8px}.new-book-input input{padding:12px;font-size:1rem;border:1px solid #ddd;border-radius:6px;max-width:400px}.new-book-input input:focus{outline:none;border-color:#1a1a2e}.input-hint{font-size:.8rem;color:#888}.loading-text{color:#666;font-size:.9rem}.upload-dropzone{border:2px dashed #ccc;border-radius:12px;padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s ease;background:#fafafa}.upload-dropzone:hover{border-color:#1a1a2e;background:#f5f5f5}.upload-dropzone.dragover{border-color:#1a1a2e;background:#f0f0f5;border-style:solid}.upload-dropzone.disabled{cursor:not-allowed;opacity:.6}.upload-dropzone.disabled:hover{border-color:#ccc;background:#fafafa}.upload-dropzone input{display:none}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:8px}.dropzone-icon{color:#888;margin-bottom:8px}.upload-dropzone:hover .dropzone-icon,.upload-dropzone.dragover .dropzone-icon{color:#1a1a2e}.dropzone-text{font-size:1.1rem;color:#333;font-weight:500}.dropzone-subtext{color:#888;font-size:.9rem}.dropzone-limit{margin-top:8px;font-size:.85rem;color:#888;background:#eee;padding:4px 12px;border-radius:12px}.staged-files{margin-top:24px;border-top:1px solid #eee;padding-top:24px}.staged-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.staged-header h3{font-size:1rem;color:#333}.file-list{display:flex;flex-direction:column;gap:8px}.file-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f9f9f9;border-radius:8px;transition:background .2s}.file-item.uploading{background:#fff8e1}.file-item.success{background:#e8f5e9}.file-item.error{background:#ffebee}.file-preview{width:48px;height:48px;border-radius:6px;overflow:hidden;flex-shrink:0}.file-preview img{width:100%;height:100%;object-fit:cover}.file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.file-name{font-size:.9rem;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-size{font-size:.8rem;color:#888}.file-status{flex-shrink:0}.file-status .status-badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500}.file-status .status-badge.pending{background:#e3f2fd;color:#1565c0}.file-status .status-badge.uploading{background:#fff3e0;color:#e65100}.file-status .status-badge.success{background:#e8f5e9;color:#2e7d32}.file-status .status-badge.error{background:#ffebee;color:#c62828}.file-actions{flex-shrink:0}.btn-icon{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;transition:all .2s}.btn-icon:hover{background:#f0f0f0;color:#333;border-color:#bbb}.upload-footer{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding-top:16px;border-top:1px solid #eee}.upload-summary{color:#666;font-size:.9rem}.btn-primary{background:#1a1a2e;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#2a2a4e}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{background:#fff;color:#333;border:1px solid #ddd;padding:10px 20px;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f5f5f5;border-color:#bbb}.upload-complete{margin-top:20px;padding:20px;background:#f0f9f4;border-radius:8px;border:1px solid #c8e6c9}.complete-message{display:flex;align-items:center;gap:12px;color:#2e7d32;font-weight:500;margin-bottom:16px}.complete-actions{display:flex;gap:12px}@media(max-width:600px){.upload-dropzone{padding:32px 16px}.file-item{flex-wrap:wrap}.file-info{flex:1 1 calc(100% - 60px)}.file-status,.file-actions{margin-left:60px}.upload-footer{flex-direction:column;gap:12px}.complete-actions{flex-direction:column;width:100%}.complete-actions button{width:100%}}.app-layout{display:flex;min-height:calc(100vh - 80px)}.app-layout.with-sidebar{padding-left:0}.books-sidebar{width:280px;background:#fff;border-right:1px solid #ddd;overflow-y:auto;transition:width .3s ease}.books-sidebar.collapsed{width:60px}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:1px solid #ddd}.sidebar-header h2{font-size:1.2rem;margin:0}.collapse-btn{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:5px}.sidebar-content{padding:15px}.view-all-link{display:block;padding:10px;background:#f0f0f0;text-align:center;border-radius:4px;margin-bottom:15px;text-decoration:none;color:#333}.view-all-link:hover{background:#e0e0e0}.book-list{display:flex;flex-direction:column;gap:10px}.book-item{display:flex;gap:10px;padding:10px;border-radius:4px;text-decoration:none;color:#333;transition:background .2s}.book-item:hover{background:#f5f5f5}.book-item.active{background:#e3f2fd;border-left:3px solid #1976d2}.book-thumbnail{width:50px;height:50px;object-fit:cover;border-radius:4px}.book-info{flex:1}.book-title{font-weight:500;margin-bottom:4px}.book-count{font-size:.85rem;color:#666}.breadcrumb{margin-bottom:20px;font-size:.9rem;color:#666}.breadcrumb a{color:#1976d2;text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.breadcrumb .current{color:#333;font-weight:500}.separator{margin:0 8px;color:#999}.artifact-navigator{display:flex;align-items:center;gap:15px;margin-bottom:20px;padding:15px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.nav-btn{padding:8px 16px;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.nav-btn:hover:not(:disabled){background:#1565c0}.nav-btn:disabled{background:#ccc;cursor:not-allowed}.nav-position{font-size:.9rem;color:#666}.back-to-book{margin-left:auto;color:#1976d2;text-decoration:none}.back-to-book:hover{text-decoration:underline}.books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-top:20px;width:100%}.book-card{background:#fff;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px #0000001a}.book-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.book-cover{width:100%;height:200px;object-fit:cover}.book-cover-placeholder{width:100%;height:200px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);font-size:4rem}.book-card-info{padding:15px}.book-card-title{font-size:1.1rem;margin-bottom:8px;color:#333}.book-card-description{font-size:.9rem;color:#666;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-card-meta{display:flex;justify-content:space-between;font-size:.85rem;color:#999}.library-header{margin-bottom:30px}.library-header h1{font-size:2rem;margin-bottom:8px}.library-header p{color:#666}.book-header{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #ddd}.book-header h1{font-size:2rem;margin-bottom:10px}.book-description{font-size:1.1rem;color:#666;margin-bottom:10px}.book-meta{font-size:.9rem;color:#999}.artifact-date{font-size:.8rem;color:#999;margin-top:5px}@media(max-width:768px){.books-sidebar{width:60px}.sidebar-content{display:none}.books-grid{grid-template-columns:1fr}.artifact-navigator{flex-wrap:wrap}.back-to-book{margin-left:0;width:100%;text-align:center}}
